求教下前端单页应用如何从 angularjs1.4 迁移至 vue 2.5,能否平滑迁移?

2018-07-26 15:37:18 +08:00
 countdown

最近刚接手了一个前端项目改造的活,领导要求从 angularjs1.4.7 迁移至 vue2.5,该项目时单页应用。

由于之前开发都是 java 后端,前端 js 只是了解基本的 jquery 操作。 这几天抽空学了下 angular 和 vue 的基本语法,发现这俩虽然很多地方差不多,但是真上手改起来却无从改起。一下子上手改这个项目难度还是挺高。

网上搜了下类似的迁移资料,也不是很多,发现比较好的参考资料也就是一篇国外的译文-> 我们为什么以及是如何从 Angular.js 迁移到 Vue.js ?

我捋了下现在应用的单页里面的引入的 css 和 js 库,主要如下, 请问下如果从 angularjs 迁移到 vuejs,是不是 angularjs 的 css 和 js 库都需要找替代的 vue 库,各位 v 友有没有什么迁移建议,能否平滑迁移还是重写,或者有好的实践文章推荐,感谢!

全局 css 样式

  1. Font-Awesome: 图标库
  2. simple-line-icons: 图标库
  3. bootstrap: 前端 ui 框架
  4. uniform: Jquery 的表单美化插件
  5. angular-xeditable: ng 对表格操作的插件
  6. angular-ui-select: ng 的下拉框插件
  7. bootstrap-toastr: 消息提示插件
  8. datatables: 表格插件
  9. components-rounded: Metronic 的一种样式
  10. Bootstrap Colorpicker: 颜色选择器

js

  1. bootstrap-hover-dropdown.js : 下拉菜单插件
  2. jquery-slimscroll: jquery 滚动条插件
  3. jquery.blockui.js: jquery 遮罩插件
  4. highstock: 图表插件
  5. bootstrap-toastr.js : 消息提示插件
  6. clipboard.js : 一个不需要 flash,将文本复制到剪贴板的插件
  7. codemirror.js: 代码高亮
  8. socket.io.js: 用于与后台消息通讯
  9. lodash.js : 一个模块化的 js 实用工具库

angularjs

  1. angular-sanitize.js: 防止跨站攻击
  2. angular-touch.js: 移动端的 touch 事件
  3. angular-ui-router: 可嵌套路由 --> 可实现页面局部刷新,同时导航栏地址变化
  4. ocLazyLoad.js : ui-router 局部刷新加载的页面不能加载其中的 script 标签,即无法执行其 js 代码。可通过 ocLazyLoad 来实现加载对应的 js 或者 css
  5. ui-bootstrap-tpls.js : angularjs 操作 bootstrap 组件
  6. angular-xeditable.js: ng 对表格操作的插件
  7. angular-ui-select.js : ng 的下拉框插件
2816 次点击
所在节点    问与答
13 条回复
sfree2005
2018-07-26 15:54:02 +08:00
你就当是重新用 vue 写这个 web app,angular 版本的就当是需求文档就好。你当然是需要认真读原项目代码的,部分可能也可以直接拷贝,但我想在实现同一个大功能的时候,你首先要去查下 vue 怎么实现,有没有类似的库给你直接用之类的。
wu67
2018-07-26 16:02:43 +08:00
去年我从 vue1.*升到 2.1 的时候, 实在忍不住了, 干脆立项重写...

clipboard 可以直接过渡, lodash 这货还有存在意义吗?直接 es6 大法呀, 其他没用过不作评论
countdown
2018-07-26 16:04:47 +08:00
@sfree2005 重写的话,只能完全迁移完才可以用了。
countdown
2018-07-26 16:05:53 +08:00
@wu67 vue1.*迁移都这么麻烦么,看来我还是低估了 angular1.x 迁移的难度
whypool
2018-07-26 16:11:47 +08:00
重构
countdown
2018-07-26 16:13:54 +08:00
@whypool 需求就是重构,现在的问题在于重构的形式,希望学习下类似的项目重构经验
yhxx
2018-07-26 16:15:51 +08:00
从 angular1.x 升级到 angular2 都基本等于重写
countdown
2018-07-26 16:18:39 +08:00
@yhxx 主要是看到我上面说的那篇迁移文章,看到他们项目实现了平滑迁移,想知道下平滑迁移和重写哪个更方便。
learnshare
2018-07-26 16:20:51 +08:00
大概是可以用一部分样式和第三方插件,其他的都要重写
countdown
2018-07-26 16:27:48 +08:00
@learnshare 想想确实是只有部分可复用,angularjs 的第三方插件替代下估计就得好好找找了
leafiy
2018-07-26 17:01:56 +08:00
刚好在做一个 ang to vue 和一个 react to vue,除了 css 真没啥过渡可说,还有一些 utils 可用,ui 方面的就别想了,要么重写要么重找
yhxx
2018-07-26 17:08:33 +08:00
@countdown 建议重写
有研究各种兼容 /替代方案的时间都够再写一遍了吧
countdown
2018-07-26 19:06:32 +08:00
@leafiy
@yhxx
看来还是重写好了

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/474374

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX