道招

2021年的一点工作总结(一)迁移React技术栈

如果您发现本文排版有问题,可以先点击下面的链接切换至老版进行查看!!!

2021年的一点工作总结(一)迁移React技术栈

2021年全年的工作总结起来很简单,算是做苦力的一年吧。。。

2021年春节后就开始邮件项目从Vue迁移到React的工作以及富文本编辑器由wangEditor替换成CKEditor。 其实自己对这项工作内心是排斥的,这绝对不是自己从Vue因为切换到不熟悉的React技术栈。

我对此工作安排的分析如下:

  • 这是一项时间跨度很长的工作,迁移期间是需要同事兼容两套系统的。
  • 长期性工作很容易存在延期,虽然大家并不是不容忍你延期,但是这会额外增加自己在这项工作中所花费的时间。
  • 自己在时间投入和收益方面不成正比,主要时间都花在原来功能的迁移
    1. 业务方面:没有太多时间开发新需求和解决业务痛点上。用户较难发现你到底做了什么新的工作,反而容易问你“以前这个都支持的,现在怎么不支持了”这样的问题。
    2. 技术方面:没有太多精力进行技术深度的研究和新型技术的探索
  • 对年底晋升没有任何助力,难有亮点,大家都会认为迁移技术栈没什么不算什么贡献。

所以说这是项对公司有利,但是对我个人而言性价比极低的一件事,唯一的好处也只能是熟悉了React技术栈而已,深度还有限。

如果只是想在公司养老混日子,一直有事做的话,上面的话当我没说。

现状

目前邮件项目主要分查看和编辑两个页面,剩下的主要是websocket消息、编辑切换二次确认之类的业务逻辑控制,其中编辑页使用到了富文本编辑器,相对复杂些。

dom结构

file

  • 蓝框内:O端控制部分
  • 绿框内:邮件控制部分(iframe内)
  • 黄框内:邮件详情查看(iframe内)
iframe无感

file

右键唤出的功能框(比如翻译框)需要支持自由拖拽,让用户感知不到iframe隔离效果

迁移方案

方案一:开发完所有组件再拼装相应模块
  • 完成组件开发
  • 拼装组件整体上线

优点

整体迁移,无额外兼容成本

缺点

开发、测试进度不好量化。项目整体积压在一起上线,项目整体风险不好控制

方案二:按模块维度开发所需组件后拼装成型

拆分成各个大模块逐步上线、测试

根据业务功能和方便布局考虑,将项目简单分成以下模块

  • 编辑模块
  • 列表模块
  • 主模块(查看模块/编辑模块 + 右侧模块)

file

file

优点

可以将整个项目分模块开发、测试,项目风险更容易把控

缺点

增加额外通信成本成本(状态一致、页面跳转) 状态同步成本(邮箱、权限信息等) 过渡阶段的部分开发量后期用不上

出于对项目尽快落地见效等考虑,决定采用方案二——按模块维度开发所需组件拼装成型。

后面就是悲催的搬砖过程,当时较为激进的选择了使用React hooks,同时自己为了加快项目进度,避免更多的占用自己时间,采用的进行进行Vue方法和React方法的一对一“翻译”,迁移过程中发现很多场景并不能这样做,再加上之前Vue版本中是使用事件驱动的,这样的话页面mounted后需要大量的事件回调,回调方法及其嵌套方法会用到state,所以出现了很多因为闭包陷阱而引发的问题。。。

更新时间:
上一篇:CKEditor富文本编辑器职责分离下一篇:2021年的一点工作总结(二)富文本编辑器

相关文章

vue多语言的解决方案不只是 vue-i18n,前端+后端完整解决方案

网上搜很多vue多语言的,一般都是介绍vue-i18n怎么使用,当然这是不错的,但是我们如果只是讲这个的话,只是解决了静态文字的多语言化。 这一部分我们也简单讲一下 npm install 阅读更多…

Did you mean to use React.forwardRef()?搞懂react的createRef和forwardRef

最近在使用react过程中发现在使用ref时的一些场景,自己初步感觉react的ref没有vue那么强大。 现在我就简单看下怎么使用ref? createRef 我们直接看源码 / 阅读更多…

element-ui表单源码解析之el-input

关于表单校验el-input做的主要工作就是跟el-form-item交互,把input的相关事件发送给el-form-item,上一篇已经讲到在el-form-item的mounted的生命周期里 阅读更多…

WordPress博客项目改用react前端展示

之前自己的主打技术栈是vue全家桶,所以将自己的wordpress博客改成了vue版本服务端渲染,现在因为公司需要将我的项目从vue转到react,本人后面可能也就要主打eact技术栈了。 我记 阅读更多…

react router页面跳转二次确认弹框及样式、业务逻辑自定义

我们在编辑页面时如果需要跳走通常会需要给用户提示,react router本身已经给了我们这样的功能,我们先看看怎么使用。 初见二次确认弹框 // App.jsx const App = 阅读更多…

改造富文本编辑器wangEditor成react组件

我们知道wangEditor常用的功能是editor实例的 txt.html() 和 txt.text() 方法,尤其是 txt.html() 方法,这是一个类似与jQuery常用的那种get和se 阅读更多…

关注道招网公众帐号
友情链接
消息推送
道招网关注互联网,分享IT资讯,前沿科技、编程技术,是否允许文章更新后推送通知消息。
允许
不用了