当前位置: 首页 > wzjs >正文

用flash做网站公司简介怎么写 范文

用flash做网站,公司简介怎么写 范文,哈尔滨网站定制公司,网站前台模块包括什么electron入门使用 背景how to start第一步 创建一个vite-vue3项目第二步 装各种依赖第三步 配置vite.config.jspackage.jsonelectron入口 启动重写关闭、隐藏、最大化最小化 背景 最近对electron比较感兴趣,折腾一段时间后有了点眉目,记录一下 how to …

electron入门使用

  • 背景
  • how to start
    • 第一步 创建一个vite-vue3项目
    • 第二步 装各种依赖
    • 第三步 配置
      • vite.config.js
      • package.json
      • electron入口
    • 启动
    • 重写关闭、隐藏、最大化最小化

背景

最近对electron比较感兴趣,折腾一段时间后有了点眉目,记录一下

how to start

第一步 创建一个vite-vue3项目

# 选vue3但是不要用ts,用js会舒服得多
npm create vite -n test-electron

第二步 装各种依赖

# 命令1
npm i electron -d -s
# 命令2
npm install vite-plugin-optimizer --save-dev
# 命令3
npm install vite-plugin-node-polyfills --save-dev
# 命令4
npm install @electron/remote
# 命令5
npm install element-plus --save
# 命令6
npm i vue-router

注意,命令1可能需要反复执行反复失败才会成功,推测是网的原因,而且我自己测试用yarn和pnpm必报错,只有npm才行

第三步 配置

vite.config.js

import { defineConfig } from 'vite'
import vue from '@vitejs/plugin-vue'
import { nodePolyfills } from 'vite-plugin-node-polyfills'
import optimizer from 'vite-plugin-optimizer'// https://vite.dev/config/
export default defineConfig({plugins: [vue(), // 添加 Node.js 内置模块的 polyfillnodePolyfills({include: ['path'],globals: { Buffer: true, global: true, process: true },protocolImports: true,}),optimizer({electron: `const { ipcRenderer } = require('electron'); export { ipcRenderer };`})],build: {rollupOptions: {output: {manualChunks: {// 将第三方库分割到单独的代码块'vendor': ['element-plus'],}}}},server: {port: 8888,cors: true, // 允许跨域hmr: true, // 开启热更新},"base": "./"
})

package.json

{"name": "ele-pro","private": true,"version": "0.0.0","type": "module","main": "electron/main.cjs","scripts": {"dev": "vite","build": "vite build","preview": "vite preview","electron:serve": "vite build && electron ."},"dependencies": {"@electron/remote": "^2.1.2","electron-reload": "^2.0.0-alpha.1","element-plus": "^2.9.7","vue": "^3.5.13","vue-router": "^4.5.0"},"devDependencies": {"@vitejs/plugin-vue": "^5.2.1","electron": "^35.1.3","vite": "^6.2.0","vite-plugin-node-polyfills": "^0.23.0","vite-plugin-optimizer": "^1.4.3"}
}

一定要重点关注入口:“main”: “electron/main.cjs”,和electron启动命令:“electron:serve”: “vite build && electron .”

electron入口

在项目的根目录下新建文件夹/electron。
在文件夹中新建文件main.cjs
注意,一定要是.cjs,不是.js

// 控制应用生命周期和创建原生浏览器窗口的模组
const { app, BrowserWindow, Menu } = require('electron')
const path = require('path')
require('@electron/remote/main').initialize()function createWindow() {// 创建浏览器窗口const mainWindow = new BrowserWindow({width: 1200,height: 800,frame: false, // 隐藏默认的标题栏webPreferences: {// 书写渲染进程中的配置nodeIntegration: true, //开启true这一步很重要,目的是为了vue文件中可以引入node和electron相关的APIcontextIsolation: false, // 可以使用require方法},})require('@electron/remote/main').enable(mainWindow.webContents)let env = 'pro'// 配置热更新if (env == 'pro') {const elePath = path.join(__dirname, '../node_modules/electron')require('electron-reload')('../', {electron: require(elePath),})// 热更新监听窗口mainWindow.loadURL('http://localhost:8888')// 打开开发工具mainWindow.webContents.openDevTools()} else {// 生产环境中要加载文件,打包的版本// Menu.setApplicationMenu(null)// 加载 index.htmlmainWindow.loadFile(path.resolve(__dirname, '../dist/index.html')) // 新增}
}
// 这段程序将会在 Electron 结束初始化
// 和创建浏览器窗口的时候调用
// 部分 API 在 ready 事件触发后才能使用。
app.whenReady().then(() => {// 关闭默认菜单栏Menu.setApplicationMenu(null)createWindow()app.on('activate', function () {// 通常在 macOS 上,当点击 dock 中的应用程序图标时,如果没有其他// 打开的窗口,那么程序会重新创建一个窗口。if (BrowserWindow.getAllWindows().length === 0) createWindow()})
})// 除了 macOS 外,当所有窗口都被关闭的时候退出程序。 因此,通常对程序和它们在
// 任务栏上的图标来说,应当保持活跃状态,直到用户使用 Cmd + Q 退出。
app.on('window-all-closed', function () {if (process.platform !== 'darwin') app.quit()
})

启动

打开两个终端窗口,需要都在该项目的根目录。
先运行npm run dev
再运行npm run electron:serve
这样,electron就能根据vue的内容实时渲染

重写关闭、隐藏、最大化最小化

在vue的根组件App.vue中:

<script setup>
import {Close,FullScreen,ArrowDown
} from '@element-plus/icons-vue'
import { getCurrentWindow } from '@electron/remote'
// 关闭
const closeApp = () => {const currentWindow = getCurrentWindow()currentWindow.close()
}
// 全屏/退出全屏应用
const fullScreenApp = () => {const currentWindow = getCurrentWindow()if (currentWindow.isFullScreen()) {currentWindow.setFullScreen(false)} else {currentWindow.setFullScreen(true)}
}// 最小化应用
const hideApp = () => {const currentWindow = getCurrentWindow()currentWindow.minimize()
}
</script><template><div><div style="padding: 10pt; text-align: right;"><el-button type="warning" size="small" circle :icon="ArrowDown" @click="hideApp"></el-button><el-button type="success" size="small" :icon="FullScreen" circle @click="fullScreenApp" /><el-button type="danger" size="small" :icon="Close" circle @click="closeApp" /></div><router-view></router-view></div>
</template><style scoped>
#app {font-family: Avenir, Helvetica, Arial, sans-serif;color: #2c3e50;
}
</style>

先到这里,后面有什么好玩的继续更新


文章转载自:

http://00000000.pnLjy.cn
http://00000000.pnLjy.cn
http://00000000.pnLjy.cn
http://00000000.pnLjy.cn
http://00000000.pnLjy.cn
http://00000000.pnLjy.cn
http://00000000.pnLjy.cn
http://00000000.pnLjy.cn
http://00000000.pnLjy.cn
http://00000000.pnLjy.cn
http://00000000.pnLjy.cn
http://00000000.pnLjy.cn
http://00000000.pnLjy.cn
http://00000000.pnLjy.cn
http://00000000.pnLjy.cn
http://00000000.pnLjy.cn
http://00000000.pnLjy.cn
http://00000000.pnLjy.cn
http://00000000.pnLjy.cn
http://00000000.pnLjy.cn
http://00000000.pnLjy.cn
http://00000000.pnLjy.cn
http://00000000.pnLjy.cn
http://00000000.pnLjy.cn
http://00000000.pnLjy.cn
http://00000000.pnLjy.cn
http://00000000.pnLjy.cn
http://00000000.pnLjy.cn
http://00000000.pnLjy.cn
http://00000000.pnLjy.cn
http://www.dtcms.com/wzjs/618858.html

相关文章:

  • 做公司网站有用吗为什么最近好多网站打不开了
  • 南宁经典网站建设做个营销型网站要多少钱
  • 邯郸做网站推广多少钱这些网站涵盖了不同的主题和类型
  • 深圳手机企业网站设计网络营销策划方案15篇要求
  • 那些行业需要做网站贡井区建设局网站?
  • 线上网站开发相关书籍怎么制作自己的链接
  • 北京网站制作网站优化苏州建网站公司
  • 乐山网站开发公司电话wordpress书插件
  • 如何制作网站教程视频网站后台设置关键词在哪设
  • 在哪网站可以做农信社模拟试卷昌邑网页定制
  • 泸州市网站建设企业信息服务规划与建设
  • wordpress站点管理服务器建设网站软件下载
  • 青岛网站建设方案公司石家庄购物网站排名
  • 众创空间网站建设方案网站外链是什么意思
  • 做网站年赚千万域名购买一般多少钱
  • 怎么做企业网站建设wordpress开发的网站有哪些
  • 如何做视频网站1688官网商家版
  • 网站屏蔽收录宿迁市住房城乡建设局网站
  • 贵阳市网站建设html网站设计模板下载
  • 怎么做电影网站appseo推广人员
  • 海阳网网站网站建设所用软件
  • 网站开发公司 经营范围wordpress生成速度显示代码
  • 手机网站赏析网站优化西安
  • 网站后台系统访问wordpress首页导航栏
  • 做安居客网站需要什么浏览器简历生成网站
  • 网站开发专业有什么工作无锡企业网站排名
  • 哪些网站百度不收录外贸流程全步骤外贸篇
  • 网站栏目框架创业做app哪个网站好
  • 合肥网站推广优化公司上海做网站优化的公司
  • 坪地网站建设价位太原代理记账公司