zoukankan      html  css  js  c++  java
  • 聊聊 electron-vue-serialport 的添加数据持久化分析以及解决方案,关联 pouchdb 、nedb 、vuex-persistedstate

    什么是 数据持久化?

    数据持久化其实就是指期望把数据长期存储下来,而这个问题被拆分成很多场合,用这篇记录一下一些细节和过程。

    起因

    起因 electron-vue-serialport 使用的 electron-vue 基础 vue-admin-template 在 yarn run dev 下 js-cookie 正常使用,但 build 后无法获取存放在 Cookie 中的 token 数据,经过写入后读取的测试返回仍然是 undefined 。

    这也就说明它可能并非真正的同步模式,考虑到有太多组件的融合,最初判断是 electron 的 Cookies 炸了,例如需要时间连接本地数据,但可能加载过程过快,无法在获取 token 前完成数据的载入,也有可能是本来就存在的版本 bug 之类的。

    准备解决方案

    既然存在 bug ,然后也没法通过更新环境解决的情况下,就直接改写之。

    • 既然是要 cookie 数据,那就用其他数据模拟一个接口送回即可。
    • 既然要持久化数据,考虑到之后也有小型数据库需求,不妨一起考虑。

    于是选取了 pouchdb 和 nedb 做长期存储,不过此时将失去 Cookies 的过期功能,但好像也并非所要的功能。

    实践结论

    为什么我在做仪器类客户端还需要这个登录的功能是因为,设备机型的登录表示你所使用的配置版本,这样的好处就是统一入口,然后分发不同的功能接口,对于一个公司来说相对规范化整体框架。

    最早怀疑是 mock 在 electron 无法工作的原因,后来经过检查是 build 后的 electron 的 js-cookie 无法工作,然后观察 js-cookie 的设计模式是同步的,这与上述的数据库的使用相违背,不得已修正为异步调用。

    其中 pouchdb 存在的问题是 electron 的 Windows 32 bit 无法编译通过,而 pouchdb-browser 存在于 浏览器 的 local storage 中无法满足我需要的本地化文件,就换了 nedb ,辛苦写了模型对上去后,一切正常工作后。

    又产生新的问题,就是 Cookies 数据没有先于 login 验证前加载完成,导致需要重新登录,这是因为 electron 关闭后,要加载数据回来需要的一些异步时间,而页面启动后,不可能会允许写一段毫无意义的延时同步数据(下下策),那么如何解决呢?

    回到原点

    最后放弃写垃圾代码注入其中,改用 vuex 的 vuex-persistedstate 插件,自动在框架内部同步数据,强组件绑定关系。

    很意外的是,如果一开始我就想清楚我想要的效果,可能就会少走这些弯路,但实际上也是由于,我并不了解 electron vue nodejs 等数据持久化组件的选取,所以要预先了解和学习一波才能应用到其中。

    最后代码反而删减了,基本没有做任何改动,也没有添加多余的模拟接口注入。

    更新在 remove auth Cookies and use vuex-persistedstate

    个人感悟

    在现代 Javascript 的设计模式上可能要缓存+同步数据,但实际上深度绑定组件的话,可以避开不必要的异步数据同步的问题。

    最后,关联上一篇博文,因为在实践过程中分析了一下 js 的 import 机制,如果有 python 经验的可能会有些疑惑是否一致,当然答案是基本一致,可以放心的到处 import 。

  • 相关阅读:
    RabbitMQ 工作图解
    RabbitMQ常用命令
    搭建 .Net RabbitMQ 开发环境
    不使用第三个变量交换两个变量的值
    WEB编程 入门简单 进阶难
    C# 字符串的长度问题
    C# 反射
    C# 拼接字符串的几种方式和性能
    ASP.NET MVC 教程汇总
    SSIS中循环遍历组件[Foreach Loop Container]
  • 原文地址:https://www.cnblogs.com/juwan/p/12312612.html
Copyright © 2011-2022 走看看