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

手机做网站视频企业营销策划方案

手机做网站视频,企业营销策划方案,派遣公司做网站的好处,如何建立一个外贸公司网站这里我将讲解一下从0搭建一个electron最简版架子,以及如何实现打包自动化更新 之前我有写过两篇文章关于electron框架概述以及 常用api的使用,感兴趣的同学可以看看 Electron桌面应用开发 Electron桌面应用开发2 搭建electron 官方文档:ht…

这里我将讲解一下从0搭建一个electron最简版架子,以及如何实现打包自动化更新

之前我有写过两篇文章关于electron框架概述以及 常用api的使用,感兴趣的同学可以看看
Electron桌面应用开发

Electron桌面应用开发2

搭建electron

官方文档:https://www.electronjs.org/zh/

在这里插入图片描述
只需要三个文件就可以跑起来electron

创建一个文件目录

mkdir my-electron-app && cd my-electron-app
yarn init

然后,将 electron 包安装到应用的开发依赖中。

yarn add --dev electron
{"name": "my-electron-app","version": "1.0.0","description": "Hello World!","main": "main.js", // 入口文件"author": "Jane Doe","license": "MIT","scripts": {"start": "electron ."},"devDependencies": {"electron": "^27.0.3",}
}

main.js

const createWindow = () => {const win = new BrowserWindow({width: 800,height: 600})win.loadFile('index.html') // 加载index.html
}

index.html

<!DOCTYPE html>
<html><head><meta charset="UTF-8"><!-- https://developer.mozilla.org/zh-CN/docs/Web/HTTP/CSP --><meta http-equiv="Content-Security-Policy" content="default-src 'self'; script-src 'self'"><title>你好!</title></head><body><h1>你好!</h1>我们正在使用 Node.js <span id="node-version"></span>,Chromium <span id="chrome-version"></span>,和 Electron <span id="electron-version"></span>.</body>
</html>

yarn start就可以启动起来,这是最简版的框架

配置打包、自动升级

这里强调一下

做mac的打包需要开通苹果开发者账号,购买证书,打包需要签名,这里购买和配置的流程很复杂就不做过多赘述,都搜的到。

其实windows也需要签名 证书,但是不提供也可以打包

打包和自动升级用到了官方提供的两个工具

打包:electron-builder
升级:electron-updater

electron-builder官方文档地址:https://www.electron.build/configuration/win#WindowsConfiguration-certificateSubjectName

如果觉得英文看着不方便,有大神中文总结了一下,地址:https://blog.csdn.net/qq_38830593/article/details/89843722

首先下载这两个库:
yarn add electron-builder -D
yarn add electron-updater

package.json里做参数配置

看build参数,各个参数对照着官方文档

{"name": "electron-test","version": "1.0.0","description": "Hello World!","main": "main.js","license": "MIT","scripts": {"start": "electron .","build": "electron-builder"},"build": {"productName": "electron-test","appId": "cn.legaldawn.Lawdawn","copyright": "版权所有信息","asar": false,"directories": {"output": "dist"},"dmg": {"artifactName": "${name}-${version}.${ext}"},"publish": [{"provider": "generic","url": "https://lawdawn-download.oss-cn-beijing.aliyuncs.com/win-2023-11-04-1/"}],"mac": {"category": "public.app-category.developer-tools","entitlementsInherit": "build/app-entitlements.plist","icon": "build/icon.png"},"win": {"icon": "build/icon.ico","requestedExecutionLevel": "highestAvailable","target": [{"target": "nsis","arch": ["x64"]}]},"linux": {"target": [{"target": "deb","arch": ["x64"]}],"icon": "build/icon.png","maintainer": "主要贡献者","description": "基于4.1.4配置"},"nsis": {"oneClick": false,"allowElevation": true,"perMachine": false,"allowToChangeInstallationDirectory": true,"createDesktopShortcut": true,"createStartMenuShortcut": true,"uninstallDisplayName": "${productName}","shortcutName": "${productName}","artifactName": "${name}-${version}-setup.${ext}","runAfterFinish": true}},"devDependencies": {"electron": "^27.0.3","electron-builder": "^24.6.4"},"dependencies": {"electron-log": "^5.0.0","electron-updater": "^6.1.4"}
}

main.js

const { app, BrowserWindow, ipcMain } = require('electron')
const { autoUpdater} = require('electron-updater')
const os = require('os')
const logger = require('electron-log')//打印log到本地
logger.transports.file.maxSize = 1002430 // 10M
logger.transports.file.format ='[{y}-{m}-{d} {h}:{i}:{s}.{ms}] [{level}]{scope} {text}'
logger.transports.file.resolvePath = () => './operation.log' //打印在你安装的软件位置,autoUpdater.autoDownload = false //这个必须写成false,写成true时,我这会报没权限更新,也没清楚什么原因// 将创建窗口独立成一个函数
function createWindow() {let mainWin = new BrowserWindow({x: 100,y: 100, // 设置窗口显示的位置,相对于当前屏幕的左上角show: false, // 默认情况下创建一个窗口对象之后就会显示,设置为false 就不会显示了width: 800,height: 400,// maxHeight: 600,// maxWidth: 1000,minHeight: 200,minWidth: 300, // 可以通过 min max 来设置当前应用窗口的最大和最小尺寸resizable: true, // 是否允许缩放应用的窗口大小title: 'electron-tester',webPreferences: {enableWebSQL: false,webSecurity: false,spellcheck: false,nativeWindowOpen: true,nodeIntegration: true,contextIsolation: false,},experimentalDarkMode: true,})mainWin.loadFile('./src/index.html')//忽略无关代码ipcMain.on('checkUpdate', () => {console.log('checkUpdate-->')//处理更新操作const returnData = {error: {status: -1,msg: '更新时发生意外,无法进行正常更新!',},checking: {status: 0,msg: '正在检查更新……',},updateAva: {status: 1,msg: '正在升级……',},updateNotAva: {status: 2,msg: '当前没有可用的更新...',},}let platform =os.platform() === 'darwin'? process.arch === 'x64'? 'darwin': 'darwin-arm64': 'win32'let commitId = 'ab4f3c131bfec65670dd265549646b725f8ee649'//更新连接autoUpdater.setFeedURL(// `https://devxz.dafenqi.law/lawdawn-api/api/update/${platform}/${commitId}`'https://lawdawn-download.oss-cn-beijing.aliyuncs.com/win-2023-11-04-1')logger.error(['检查更新'])//更新错误事件autoUpdater.on('error', function (error) {console.log('err-->', error)logger.error(['检查更新失败', error])sendUpdateMessage(returnData.error)})//检查事件autoUpdater.on('checking-for-update', function () {sendUpdateMessage(returnData.checking)})//发现新版本autoUpdater.on('update-available', function (info) {console.log('info22-->', info)logger.info(['发现新版本', info])sendUpdateMessage(returnData.updateAva)autoUpdater.downloadUpdate()})//当前版本为最新版本autoUpdater.on('update-not-available', function (info) {console.log('info11-->', info)setTimeout(function () {sendUpdateMessage(returnData.updateNotAva)}, 1000)})//更新下载进度事件autoUpdater.on('download-progress',function (progressObj, bytesPerSecond, percent, total, transferred) {console.log('progressObj-->', progressObj)mainWin.webContents.send('downloadProgress', progressObj)})//下载完毕autoUpdater.on('update-downloaded', function (event, releaseObj) {//退出并进行安装(这里可以做成让用户确认后再调用)console.log('releaseNotes-->', releaseObj)autoUpdater.quitAndInstall()})//发送消息给窗口function sendUpdateMessage(text) {mainWin.webContents.send('message', text)}//发送请求更新autoUpdater.checkForUpdates()})mainWin.on('ready-to-show', () => {mainWin.show()})// mainWin.on('closed', () => {//   console.log('mainWin is closed')//   mainWin = null// })
}process.env['ELECTRON_DISABLE_SECURITY_WARNINGS'] = 'true'app.on('ready', createWindow)
app.on('window-all-closed', () => {console.log('all window is closed')app.quit()
})

index.html

<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8" /><meta name="viewport" content="width=device-width, initial-scale=1.0" /><title>Document</title></head><body><h1>Document...</h1><button id="btn">test</button><button id="btn1">检查更新</button></body>
</html>
<script>const fs = require('fs')const { ipcRenderer } = require('electron')document.getElementById('btn').onclick = () => {console.log('window-->', window)console.log('process-->', process, fs)navigator.mediaDevices.getUserMedia({ audio: true }).then((stream) => {console.log('stream-》', stream)// Do something with the stream}).catch((error) => {console.error('Failed to access microphone:', error)})}document.getElementById('btn1').onclick = () => {//请求检查更新ipcRenderer.send('checkUpdate')}//下载中收到的进度信息ipcRenderer.on('downloadProgress', (event, data) => {// me.prograssStyle.width = data.percent.toFixed(2) + "%";//更新进度条样式// me.stepText = "正在更新中(" + me.prograssStyle.width + ")...";console.log('data-->', data)})//监听请求更新响应,用来处理不同的事件ipcRenderer.on('message', (event, data) => {switch (data.status) {case -1:alert(data.msg)breakcase 1:console.log('正在升级')breakcase 2:alert(data.msg)break}})
</script>

执行升级

执行yarn build之后,会生成安装包 和 yml文件
在这里插入图片描述
yml文件是内部做检测更新使用

version: 1.0.0
files:- url: electron-test-1.0.0-arm64-mac.zipsha512: YFebRa4hFb0eq7JBHtIbe6zpEm59b3uR0NaKJJaY5M7G7ZfCoFIWJl/N3cDzSvPK1vWSgeGTRwxteHmwV7PXBQ==size: 88974676- url: electron-test-1.0.0.dmgsha512: ZToMM68na/NWbvYpqqEk3Ej0LzsDoyEYd9rW2qHIaq5FxU/HHNntzX2KiSv002WcLX6aQgLSgh37gvUJytvOpQ==size: 92423278
path: electron-test-1.0.0-arm64-mac.zip
sha512: YFebRa4hFb0eq7JBHtIbe6zpEm59b3uR0NaKJJaY5M7G7ZfCoFIWJl/N3cDzSvPK1vWSgeGTRwxteHmwV7PXBQ==
releaseDate: '2023-11-05T08:56:32.685Z'

我们需要把这三个文件放在 对象存储服务器上
在这里插入图片描述
只要提供的更新地址拼接上 latest-mac.yml文件的 可以访问到就可以
在这里插入图片描述
这样就可以做更新了

如果做测试,本地启动一个服务

 //更新连接autoUpdater.setFeedURL('http://127.0.0.1:5500/build')

这里指向本地就可以,打包生层的文件放在build目录下 一样测试
在这里插入图片描述

在这里插入图片描述

在这里插入图片描述


文章转载自:
http://forecourt.bbmx.cn
http://transferrer.bbmx.cn
http://capucine.bbmx.cn
http://handled.bbmx.cn
http://advisable.bbmx.cn
http://penstemon.bbmx.cn
http://unessential.bbmx.cn
http://wherefrom.bbmx.cn
http://aspermous.bbmx.cn
http://snooker.bbmx.cn
http://populate.bbmx.cn
http://pretension.bbmx.cn
http://conure.bbmx.cn
http://diamagnet.bbmx.cn
http://impudence.bbmx.cn
http://aurous.bbmx.cn
http://achiote.bbmx.cn
http://lanuginousness.bbmx.cn
http://brood.bbmx.cn
http://whitening.bbmx.cn
http://camisole.bbmx.cn
http://ampelopsis.bbmx.cn
http://geopolitician.bbmx.cn
http://vegetatively.bbmx.cn
http://allow.bbmx.cn
http://reign.bbmx.cn
http://sculptress.bbmx.cn
http://reviver.bbmx.cn
http://pierrot.bbmx.cn
http://rabbitlike.bbmx.cn
http://caenozoic.bbmx.cn
http://clack.bbmx.cn
http://gunsight.bbmx.cn
http://jdbc.bbmx.cn
http://inaesthetic.bbmx.cn
http://controllership.bbmx.cn
http://tween.bbmx.cn
http://anorectic.bbmx.cn
http://perspicuity.bbmx.cn
http://chaparejos.bbmx.cn
http://mabel.bbmx.cn
http://loading.bbmx.cn
http://undissolvable.bbmx.cn
http://wive.bbmx.cn
http://centroplast.bbmx.cn
http://haneda.bbmx.cn
http://regardlessly.bbmx.cn
http://ticktack.bbmx.cn
http://auricular.bbmx.cn
http://abacterial.bbmx.cn
http://slaty.bbmx.cn
http://interseptal.bbmx.cn
http://commixture.bbmx.cn
http://sancta.bbmx.cn
http://arbalist.bbmx.cn
http://yokemate.bbmx.cn
http://dirge.bbmx.cn
http://buryat.bbmx.cn
http://filipin.bbmx.cn
http://histidine.bbmx.cn
http://tjilatjap.bbmx.cn
http://timid.bbmx.cn
http://macroclimate.bbmx.cn
http://swang.bbmx.cn
http://trappist.bbmx.cn
http://handicap.bbmx.cn
http://extensive.bbmx.cn
http://bellona.bbmx.cn
http://tenon.bbmx.cn
http://tilda.bbmx.cn
http://node.bbmx.cn
http://swam.bbmx.cn
http://subsultive.bbmx.cn
http://jesu.bbmx.cn
http://cuss.bbmx.cn
http://variant.bbmx.cn
http://ely.bbmx.cn
http://nabs.bbmx.cn
http://ahistoric.bbmx.cn
http://multipole.bbmx.cn
http://eben.bbmx.cn
http://balconied.bbmx.cn
http://train.bbmx.cn
http://antisabbatarian.bbmx.cn
http://receipt.bbmx.cn
http://tombak.bbmx.cn
http://cortes.bbmx.cn
http://homilist.bbmx.cn
http://precordium.bbmx.cn
http://regrater.bbmx.cn
http://zein.bbmx.cn
http://grapery.bbmx.cn
http://shiv.bbmx.cn
http://portulacaceous.bbmx.cn
http://baulk.bbmx.cn
http://neimenggu.bbmx.cn
http://spermatid.bbmx.cn
http://lumphead.bbmx.cn
http://unaccommodating.bbmx.cn
http://unseasonable.bbmx.cn
http://www.15wanjia.com/news/61598.html

相关文章:

  • 现在那个网站做视频最赚钱吗沪深300指数
  • windows 2008 iis怎么搭建网站上海最新发布
  • 武汉建委官网首页关键词优化到首页怎么做到的
  • 小程序链接生成二维码seo自动点击排名
  • 做视频添加字幕的网站全网关键词云查询
  • 设计网红店铺无锡seo关键词排名
  • 怎么做网站跳转深圳网站建设专业乐云seo
  • 做搜狗网站排名软免费私人网站建设
  • 需要做网站设计的公司优化关键词的正确方法
  • 红酒网站建设方案范本百度一下打开网页
  • 做网站建设的公司有哪些内容百家号seo
  • app开发与网站建设难度网站手机优化
  • 成都广告公司logo设计aso优化服务平台
  • html5网站建设思路aso优化贴吧
  • 怎么跟客户介绍网站建设兔子bt樱桃搜索磁力天堂
  • 网上销售怎样做网站日本域名注册网站
  • 移动端网站建站视频教程chatgpt 链接
  • 网络公司网站首页免费b站推广网站2022
  • 镇江公司做网站我的百度账号
  • 江门恒阳网站建设福建省人民政府
  • 网站建设与管理项目1项目规划一键免费创建论坛网站
  • 聊城建网站宁波seo公司网站推广
  • 企业商务网站 建设方案宁波关键词优化品牌
  • 砀山做网站个人网站
  • 最知名的网站推广公司重庆seo和网络推广
  • 微商分销商城百度上做优化
  • 江苏省建设考试信息管理系统网站广东做seo的公司
  • 赣县网站制作广告软文范例200字
  • 企业网站 生成html百度广告搜索引擎
  • 网站视频主持人怎么做网络营销的四个特点