基于vue + electron创造一个随心开发组件的跨端桌面应用(持续更新~)(二)

简介: 下面我会从这个应用的一些功能的实现细节讲起,包括初始化,托盘菜单,开机自启,存储用户数据,GitHub信息健康,翻页时钟,打包配置除此之外还有还有项目的使用方式与功能介绍,希望可以给掘友带来帮助。

翻页时钟

在苹果商店中我下载了一款翻页时钟,感觉非常好用,所以我想在插件中加入这个功能,参考了zhuanlan.zhihu.com/p/93519427的…

翻页时钟分为两个功能,一个是时钟功能,一个是翻页功能

1.webp.jpg

下面我会从切换数字,**

切换数字

在翻页中的核心其实是切换数字,将切换数字封装成一个函数,在此之前,需要将时钟的状态进行一个初始化,如下,形成一个数组包含六个元素,分别对应着时钟的六个格子,false为翻转结束状态即数字未改动

let fliping = [false, false, false, false, false, false]
复制代码

数字切换函数体如下

const changeNumber = (digit, num) => {
  // 正在翻转中则返回
  if (fliping[digit]) return
  fliping[digit] = true
  // 获取 DOM
  const flip = document.querySelectorAll('.flip')[digit]
  const front = document.querySelectorAll('.front')[digit]
  const back = document.querySelectorAll('.back')[digit]
  // 更改背后数字 & 增加动画
  back.setAttribute('class', `digital back n-${num}`)
  flip.classList.add('go')
  // 600ms 后清除动画 & 修改前面数字
  setTimeout(() => {
    flip.classList.remove('go')
    front.setAttribute('class', `digital front n-${num}`)
    // 翻转结束
    fliping[digit] = false
  }, 600)
}
复制代码

切换数字函数中包含两个参数,digit为数组下标即要切换的格子,num为切换数字值 除此之外还需要对时钟的状态进行判断,避免出现快速连续翻转情况,其是通过fliping[digit]来判断,在此并没有采用响应式的方法,所以是直接通过DOM获取各格子并进行赋值,在翻页场景下使用双向绑定可能会有些麻烦。

定时回调

在整个翻页时钟三个功能是通过定时器的回调来进行控制的,即interval,在初始状态定义为null

let interval = null
复制代码

当需要进行定时or倒计时or开启时钟时,都需要进行一个停止计时器的操作

interval && clearInterval(interval)
复制代码

钟的核心理念

下面以番茄钟代码举例

const pomodoroClock = () => {
  interval && clearInterval(interval)
  // 番茄工作时间
  let pomodoro = [0, 25, 0]
  interval = setInterval(() => {
     pomodoro[2]--
     if (pomodoro[2] === -1) {
      pomodoro[2] = 59
      pomodoro[1]--
     }
     if(pomodoro[1] === -1) {
      pomodoro = [0,5,0]
     }
     // 转为字符串
     const timeStr = numToStr(pomodoro[0], 2) + numToStr(pomodoro[1], 2) + numToStr(pomodoro[2], 2)
     // 遍历时间字符串
     for (let i = 0, len = timeStr.length; i < len; i++) {
      // 判断数字是否修改
      if (timeStr[i] !== old[i]) {
        // 修改翻牌器数字
        changeNumber(i, timeStr[i])
      }
    }
    old = timeStr
  },1000)
}
复制代码

时间的数据格式

数据格式在处理状态下是通过数值形式来进行处理的,比如说在番茄钟的倒计时减法,初始状态下是使用以数值为数组元素的数组进行一个时间的初始化,再通过字符串转换,将数值形式的时间转换为字符串再通过遍历循环来进行时间的更新,计时和时钟都是根据这个进行翻页。

数据留存

因为这个翻页时钟开发了三个时间功能,所以在功能切换上肯定会存在更新问题,所以特别要注意的是需要使用old来对数据进行一个留存,比如在时钟与番茄中的切换上在没有留存的情况下会导致数据不更新问题,所以在时钟,番茄钟,倒计时要留存数据比如番茄钟的 old = timeStr,还有就是因为在判断时间更新的情况下是需要用到old来进行判断的

时间的回溯与流逝

番茄钟和计时器其本质是时间的回溯与流逝,所以在数据判断上需要一个对时分秒的判断与更改 时间前进就对60秒1分进位,60分1时进位,时间倒退则为,0秒分减位,以此类推,如上述番茄钟

if (pomodoro[2] === -1) {
      pomodoro[2] = 59
      pomodoro[1]--
}
复制代码

打包配置

因为是基于vue+electron,所以打包需要在vue.config.json进行配置

electronBuilder: {
      nodeIntegration: true,
      mainProcessFile: 'app/main.js',
      rendererProcessFile: 'pages/main.js',
      builderOptions: {
        productName: 'Monit',
        appId: 'com.fzf404.monit',
        artifactName: '${productName}-${version}-${os}-${arch}.${ext}',
        linux: {
          target: 'AppImage',
          publish: ['github'],
        },
        mac: {
          target: {
            target: 'dmg',
            arch: ['x64', 'arm64'],
          },
        },
      },
    },
复制代码

配置了主进程和渲染进程的入口文件路径,以及相关的构建选项

  • 主进程入口: mainProcessFile
  • 渲染进程入口:rendererProcessFile
  • 构建选项: builderOptions
  • 打包后exe文件前缀: productName
  • 包名:appId
  • 工件文件名模板:artifactName
  • 不同端口的打包形式:linux&mac&win

如何使用

掘友们想基于现在的版本继续向上开发,比如说:一个实时监测掘金信息的桌面应用(我也想这么干来着)

克隆下来二次开发:项目传送门:监控github信息的桌面小组件 (github.com)

又或者直接下载使用,支持linux,window,mac

  1. 下载地址: fzf404/Monit (github.com)
  2. 当前版本(0.2.4):

🚨 v0.3.0 版本前的最终版,v0.3.0 起会引入插件机制,除 Github 外还支持其他平台及电脑控制。

✨ Mac 系统安装可能会提示 Monit.app 已损坏,请参考 项目中README.md 中的 安装 部分

🚑 目前只支持 Windows 端自动检查更新

✨ 支持了各平台的开机自启,增加了消息通知功能

♿ 菜单栏增加了 开机自启 和 消息通知 的开关

功能介绍

github信息实时监测

1.webp.jpg

  1. 启动或点击右上角设置按钮会弹出信息模态框,输入你的github用户名即可(说起来还可以监测其他人的github信息)

1.webp.jpg

  1. 左上角第三个按钮的作用分别为是退出,隐藏,置顶/取消置顶
  2. 左侧依次为用户获得的follower、star、fork总数并可以显示实时动态
  3. 当数字变动时点击可查看变动详情
  4. 右侧为全部仓库及star数,点击可跳转到浏览器查看仓库详情,仓库列表可以滚动
  5. 网络异常时右上角红色图标会有一个断网指示

翻页时钟

1.webp.jpg

翻页时钟共分为三个功能,一个功能为时钟,另一个为计时,还有一个为番茄钟(未上线)其中时钟和计时功能是通过按钮控制的

下一步的想法

  1. 音乐播放器❌
  2. todo待办项❌
  3. bilibili创作监测❌
  4. 掘金创作信息监测❌
  5. 翻页时钟✅
  6. 计数器✅ 目前项目中初步搭建好了todo还有bilibili的文件,如果掘友感兴趣可以进行二次开发并提pr。

最后

关于electron,我这几天也在社区中看到一些好文章比如说

如果喜欢这款跨端监测github桌面应用软件,欢迎star与一键三连😍

小活动

如果掘友们有好的其他功能想法欢迎在评论区中进行留言并点赞,在6月十五号我会抽出一名幸运掘友分别送出克里克抱枕!!!

幸运掘友

1.webp.jpg1.webp.jpg

恭喜中奖掘友,请留下你的联系方式我会和你联系并将克里克抱枕邮寄给你!!!


相关文章
|
18天前
|
人工智能 移动开发 JavaScript
如何用uniapp打包桌面客户端exe包,vue或者uni项目如何打包桌面客户端之electron开发-优雅草央千澈以开源蜻蜓AI工具为例子演示完整教程-开源代码附上
如何用uniapp打包桌面客户端exe包,vue或者uni项目如何打包桌面客户端之electron开发-优雅草央千澈以开源蜻蜓AI工具为例子演示完整教程-开源代码附上
106 18
|
20天前
|
JavaScript
vue使用iconfont图标
vue使用iconfont图标
109 1
|
2月前
|
缓存 JavaScript UED
Vue3中v-model在处理自定义组件双向数据绑定时有哪些注意事项?
在使用`v-model`处理自定义组件双向数据绑定时,要仔细考虑各种因素,确保数据的准确传递和更新,同时提供良好的用户体验和代码可维护性。通过合理的设计和注意事项的遵循,能够更好地发挥`v-model`的优势,实现高效的双向数据绑定效果。
163 64
|
1月前
|
JavaScript 关系型数据库 MySQL
基于VUE的校园二手交易平台系统设计与实现毕业设计论文模板
基于Vue的校园二手交易平台是一款专为校园用户设计的在线交易系统,提供简洁高效、安全可靠的二手商品买卖环境。平台利用Vue框架的响应式数据绑定和组件化特性,实现用户友好的界面,方便商品浏览、发布与管理。该系统采用Node.js、MySQL及B/S架构,确保稳定性和多功能模块设计,涵盖管理员和用户功能模块,促进物品循环使用,降低开销,提升环保意识,助力绿色校园文化建设。
|
2月前
|
JavaScript API 开发者
Vue是如何进行组件化的
Vue是如何进行组件化的
|
2月前
|
JavaScript 前端开发 开发者
Vue是如何进行组件化的
Vue是如何进行组件化的
|
2月前
|
存储 JavaScript 前端开发
介绍一下Vue的核心功能
介绍一下Vue的核心功能
|
2月前
|
前端开发 JavaScript 测试技术
Vue3中v-model在处理自定义组件双向数据绑定时,如何避免循环引用?
Web 组件化是一种有效的开发方法,可以提高项目的质量、效率和可维护性。在实际项目中,要结合项目的具体情况,合理应用 Web 组件化的理念和技术,实现项目的成功实施和交付。通过不断地探索和实践,将 Web 组件化的优势充分发挥出来,为前端开发领域的发展做出贡献。
57 8
|
2月前
|
JavaScript
在 Vue 3 中,如何使用 v-model 来处理自定义组件的双向数据绑定?
需要注意的是,在实际开发中,根据具体的业务需求和组件设计,可能需要对上述步骤进行适当的调整和优化,以确保双向数据绑定的正确性和稳定性。同时,深入理解 Vue 3 的响应式机制和组件通信原理,将有助于更好地运用 `v-model` 实现自定义组件的双向数据绑定。
|
2月前
|
JavaScript 前端开发 开发者
vue学习第一章
欢迎来到我的博客!我是瑞雨溪,一名热爱前端的大一学生,专注于JavaScript与Vue,正向全栈进发。博客分享Vue学习心得、命令式与声明式编程对比、列表展示及计数器案例等。关注我,持续更新中!🎉🎉🎉
55 1
vue学习第一章

热门文章

最新文章