写 React 的学了一下 Vue,真香
最近接手一个项目,由于以前是用 Vue 写的,只好临时学了一下,结果发现……
我艹,这玩意比 React 好用太多了。
很多 React 里处理起来比较麻烦的问题,在 Vue 里都解决了。向 children 传参再也不用 Clone 了,Vuex 也比 Redux 好使,连路由参数都能直接传入 props……
其实 React 的那些麻烦已经很多年了,只是老外似乎不太注重用户体验,不愿解决。还是中国同胞好啊!
最近接手一个项目,由于以前是用 Vue 写的,只好临时学了一下,结果发现……
我艹,这玩意比 React 好用太多了。
很多 React 里处理起来比较麻烦的问题,在 Vue 里都解决了。向 children 传参再也不用 Clone 了,Vuex 也比 Redux 好使,连路由参数都能直接传入 props……
其实 React 的那些麻烦已经很多年了,只是老外似乎不太注重用户体验,不愿解决。还是中国同胞好啊!
react 妙在一切都是 js,对于我来说都是可以预期的
框架还是不能单纯以方便分胜负, 个人认为生态更重要.
改造完寻思用 React 改造一版顺便也学一下,结果在 Redux 的地方坑住动不了
等 WebComponents 这套再成熟一点,Deno 的生态好一点,直接从 jQuery 跳 WebComponents 香爆
~关键是还能继续用 jQuery~~~~
什么老前辈 /思想顽固不化 /喜欢守旧 /害怕改变,说的就是我这样的只会 WordPress 的上古前端
这个就跟说 Clojure 是函数式语言一样,大部分人能认同,有一小部分 Haskell 党不能认同。
我想采访一下为什么讨厌函数式编程呢?我个人的体验是除去写底层 API,再除去 mutable 算法很好写的情况,普通的业务用函数式风格各方面都要好一点,好读 /好重构 /好扩展 /好测试 /好 reload 代码等等。
一进项目主目录,基本结构都有了呀,assets/ 放图片啥的,components/ 放组件,layouts/ 可以自定义布局,middleware/ 可以写中间件 判断登录啥的,pages/ 写页面,plugins/ 放第三方插件,static/ 还可以放静态资源 基本不会变动的那种,store/ 里面放 vuex
还要啥自行车,每个文件夹里还有一个 readme 告诉你这个文件夹是干啥的,服务端大佬都哭了呀,谁跟我说现在写前端配置就得学半天的,说着撸起了自己的博客
现在我配置个 next 搞了老半天,想用个按需加载 ant,直接就报错了 说什么 不能从 node_modules 里面 import css,没耐心找解决方法就全局引用了,尝试了 styled-jsx,又搞了半天 vscode 代码高亮和代码提示,搞半天还是不支持 postcss 的嵌套语法,气不过就不用了 直接用 sass 了
也就组件不用像 vue 那样手动注册一下,爽一点,其他的初学也没体验到啥
组件通讯是真的考验我的心智,原来没有 emit 是这么麻烦的吗
我已经忘了这项目是为了干啥了,我已经迷失在 react 优化里了,顺便问问各位 react 的大佬,我写了这么一个组件,里面有个输入框,输入特定字符就会在那个地方弹一个框出来,整个页面里面会添加有很多这样的组件,功能是可以,就是选一个组件输入,所有组件都会运行一下 render,这正常吗(还没学 redux,所以用的 hooks 模拟的 redux )
Scala 红皮书里面说过,如果函数式编程写得很笨很蹩脚,一般都是缺乏某种抽象。
函数式风格真正用起来是各种很流畅的函数组合,用函数高效流畅地地组装出绝大部分函数,大部分都是高阶函数各种传参生成一个需要的函数,而不是每次从头手写。
另外,不是很重要地,函数式 “编程” 有点强行造词的意味。我上面除了 #81 说讨厌外没有在 “函数式” 后面跟上 “编程”。
从我明白了 Excel 是真真正正的函数式之后就这样了。
React 虽然一直在改进 Type 支持,现在对 TS 支持也很好,但是它不够 OOP,Function 是一等公民。JS 印迹太深。
VUE 没正经使用过,看过比较各框架的 TODO 例子,第一眼觉得与早期 Polymer 1 相似(语法杂交了 AngularJS 1 概念),实在没好感,实在找不到什么理由用它。
期待 WebComponents 流行起来。
不过对比 Cycle,我觉得 React 只解决了 Model -> View 的 Reactive,没有实现像 Cycle 一样 View -> Model 的 Reactive 。
我理解大部分函数式其实都是指处理逻辑的核心是函数操作数据,操作以 transform ADT 为主就是非常函数式了。基本上也能获得函数式的核心好处-靠 referential transparency 和 local reasoning 让 business logic 更容易理解,测试和修改。
至于这个核心外面的 container 五花八门,Haskell 靠 ST,比如 Erlang 靠 process,Clojure 靠 Atom,ML 靠 ref,我理解都算函数式。但是这些和业务关系就变小了,是一些技术上的设计。只不过追求 Pure 的函数式是另外一回事。
Angular 问题很多,特别写库和写业务完全就是两套不同的代码,感觉 Angular 很多东西写出来都特别困难,难受得一批。API 很多,我们都是后端团队,学起来上手快,后面还是各种踩坑。
Mark for check 机制完全就是自动挡变手动挡,而且机制完全没 React 和 Vue 直接,一不小心就无限刷,或者 onPush 就不更新得手动调 Zone 。
Rx 本身也不够建模用,写多了极乱,最后还是需要 Ng*s 之类的东西。
而且实话说 OO 相比 FP 扩展性很差。
React vs Vue 感觉还有的比,Ng 用没 React 和 Vue 人多是有原因的。