最近接手一个项目,由于以前是用 Vue 写的,只好临时学了一下,结果发现……
我艹,这玩意比 React 好用太多了。
很多 React 里处理起来比较麻烦的问题,在 Vue 里都解决了。向 children 传参再也不用 Clone 了,Vuex 也比 Redux 好使,连路由参数都能直接传入 props……
其实 React 的那些麻烦已经很多年了,只是老外似乎不太注重用户体验,不愿解决。还是中国同胞好啊!
1
Hanggi 2020-05-12 07:09:36 +08:00 4
你试试 Angular 更爽。还有 Ember.js, youtube 用的 polymer.js, 以及 Meteor 都可以试试。
|
2
lambdaxs 2020-05-12 07:36:25 +08:00 6
react 的强大在于它是基于函数式思想的,所以让我说 react 更简洁统一。但现实世界又是复杂繁琐的,这时候 vue 就好使,就是那个锤子,见啥钉子都能锤爆
|
3
Perry 2020-05-12 07:38:38 +08:00
停火可以不?每个人偏好都不一样,你觉得处理起来麻烦的问题可能在别人看来不是问题,瑞斯拜。
|
4
Perry 2020-05-12 07:39:18 +08:00
向 children 传参再也不用 Clone 了?啥意思?
|
5
hoyixi 2020-05-12 07:40:22 +08:00 3
你写的还不够多
|
6
murmur 2020-05-12 08:13:37 +08:00
写多才知道 vue 得好,react 适合复杂得东西,但多不等于复杂,iframe+复制粘贴能搞定的都不叫复杂
|
8
xstmjh 2020-05-12 08:27:02 +08:00
感觉楼主一个都没说到点子上
|
9
pkaq 2020-05-12 08:29:21 +08:00
向 children 传参再也不用 Clone 了?迷惑行为?
|
10
fxxwor99LVHTing 2020-05-12 08:30:20 +08:00
是个新手吧,说这种话
|
11
zachlhb 2020-05-12 08:34:43 +08:00 via Android 10
不喜欢 react 原因是很讨厌 js 和 html dom 混写,看着好蛋疼
|
12
zhuangzhuang1988 2020-05-12 08:41:28 +08:00 via Android
@lambdaxs fp 就是放屁
|
13
rioshikelong121 2020-05-12 08:41:34 +08:00
迷惑行为大赏
|
14
ccraohng 2020-05-12 08:50:26 +08:00 via Android
emmmm
clone 可以对 child 进行重写或者加强,传参,比如 rc-trigger react 妙在一切都是 js,对于我来说都是可以预期的 |
15
Yumwey 2020-05-12 08:53:58 +08:00 via Android
你这说的充分体现了你是个新手。
|
16
BarZu 2020-05-12 08:57:17 +08:00
React 太费心智,还是 Vue 傻瓜好用,另外,我竟然喜欢上了小程序的原生语法
|
17
zj1926 2020-05-12 09:10:47 +08:00
向 children 传参再也不用 Clone 了? 这句话疑问不少
|
18
fumichael 2020-05-12 09:12:28 +08:00 18
管你新手老手,能准时下班就是能手
|
19
toacnme 2020-05-12 09:25:32 +08:00 1
对于优秀的前端,这两个没有谁好用的问题, 起码你得都会, 然后就看你们具体的业务需求和技术选型了.
写了一年多的 Vue, 最近在写 React,发现 React 对于新手入门还是比较困难的 会 React 的人去学 Vue 相对就比从 Vue 学 React 轻松了很多 框架还是不能单纯以方便分胜负, 个人认为生态更重要. |
20
nanau2016 2020-05-12 09:29:23 +08:00 via iPhone
redux 不要用也成了 react 的锅了吗
|
21
SSW 2020-05-12 09:33:40 +08:00
最近开始写 react,个人觉得,对我的原生和函数思维简是一次很大的提升。两种各有各的好处叭。具体的还得根据业务来
|
22
murmur 2020-05-12 09:37:54 +08:00
@toacnme 生态就一套 ui 而已,谁比谁差,真正拼好看还是设计师出力,通用 ui 不丑但是太俗了,你说 rn,flutter 吹又不愿意了
|
23
joesonw 2020-05-12 09:42:32 +08:00
不知道组件属性,绑定的方法这些有智能提示吗? 能一键重构(改名)吗?
|
24
IsaacYoung 2020-05-12 09:44:17 +08:00 via iPhone 1
又开始了🐶
|
26
ke1vin 2020-05-12 09:45:30 +08:00
写 React 的心智负担高一点
|
27
stabc 2020-05-12 09:45:40 +08:00
可惜没有"Vue native"
|
28
ccyu220 2020-05-12 09:57:53 +08:00
两个都会就不会撕逼,想用哪个用哪个。而且有 antd 这么优秀的 UI 框架。所以,这都能撕逼的都是菜鸡。
|
30
murmur 2020-05-12 10:00:51 +08:00
@Torpedo ts 本身也可以写 js,js 就太活了,尤其是带点框架性质的,传个字符串执行某个方法,那种肯定不能简单就重构
java 也一样,可以 xml 、可以反射 |
31
toacnme 2020-05-12 10:01:51 +08:00 1
@murmur 所以这两个框架,作为前端的话还是都要掌握, 各有优点.
真要让我二选一的话 , 我还是选择 React , 现在很多小公司用的都是 Vue, 公司为了省钱 一般都是几个后端配一个前端, 因为 Vue 入门简单, 让后端也去写 Vue, 但是大部分这些后端都是处于 MVC+Jquery 的阶段, 对前端工程化 ES6 等语法都不了解,他们写的 JS 就跟膏药一样,o(︶︿︶)o 唉,亲身经历. 如果选择用 React 的 ,我觉得起码能最大程度避开这些坑. |
33
murmur 2020-05-12 10:08:35 +08:00
@toacnme 这就是实际开发和理论的区别了,只要能过了测试的,做的再烂也不重构,宁可推倒重来
放到互联网公司就更现实了,半年可能项目甚至公司都没了,根本不需要考虑后期维护 |
34
bnm965321 2020-05-12 10:26:35 +08:00
心智负担最低的是 react 吧,框架带来的东西很少,需要记忆的东西很少。就是 hooks 之后又一点坑
|
36
murmur 2020-05-12 10:29:04 +08:00
@bnm965321 如果你从后端兼职的角度来看,es6 和 ts 都是要学习的,而 vue 的模板对于后端来说是家常便饭,别人 freemarker 、velocity 、jsp 都用过,什么样的模板没见过
|
38
minglanyu 2020-05-12 10:31:14 +08:00
刚毕业的时候用 Vue 改造一个公司用的 Oracle 的管理页面。
改造完寻思用 React 改造一版顺便也学一下,结果在 Redux 的地方坑住动不了 |
41
nnnToTnnn 2020-05-12 10:33:14 +08:00
React Hook: "你在说什么? "
antd: "我官方支持 React" umi: "未来我会考虑支持 Vue 。" |
42
murmur 2020-05-12 10:36:12 +08:00 3
拿 ui 框架说事的,简单的 ui 你自己都可以封装,而且 ui 的好坏取决于设计师
真正难开发几个东西: 1 、企业级要求的 table (功能对标 excel ),行列拆分、合并、冻结、原地编辑,这是必修课 2 、企业级要求的图表(线图、横竖柱状图、饼图都不用说,至少得支持线柱混合) 3 、富文本编辑器,要求不高,word 可以直接复制 这些都是跟框架无关的 |
43
dany813 2020-05-12 10:39:18 +08:00
react 香的一笔,会 JS 就能写
|
44
auroraccc 2020-05-12 10:47:25 +08:00
除了 redux 还有 mobx 呀,体验跟 vuex 感觉差不太多
|
45
lupkcd 2020-05-12 10:47:38 +08:00
在我看来 Vue 比 React 差就差在 RN,其他各方面都更好,Vue 3.0 出来,说 ts 支持的问题也不存在了。
|
46
Pyrex23 2020-05-12 10:48:38 +08:00 via iPhone
龟龟 又开始了?
|
47
Midnight 2020-05-12 10:50:44 +08:00 4
所以说,angular 在 3 年后等你们一点毛病都没有
|
48
Orenoid 2020-05-12 10:55:38 +08:00
你们先等下,我去拿瓜子和板凳
|
49
endlessJ219 2020-05-12 11:05:26 +08:00
《如何让程序员吵起来》
|
50
Smilencer 2020-05-12 11:08:25 +08:00
前端娱乐圈日常
|
51
jimrok 2020-05-12 11:09:14 +08:00
更适应 React,Vue 的指令看起来像一个问题搞出一个办法
|
52
sam014 2020-05-12 11:24:55 +08:00 1
vue 写久了不会烦吗?我是一直想换 react 换换脑子
|
53
lancelock 2020-05-12 11:26:58 +08:00
我写 react 从来没用过 redux,莫名其妙搞得那么复杂
|
54
namelosw 2020-05-12 11:32:05 +08:00 via iPad
说 React 麻烦的可以把 Ramda 这种库练一练,做到 60%的函数没函数体,80%函数没花括号之后你会对 React 有新的理解。
|
55
betulac 2020-05-12 11:32:19 +08:00
推荐一种 React 的使用,https://github.com/BetulaZbot/EDV
|
56
no1xsyzy 2020-05-12 11:41:42 +08:00
|
57
zhw2590582 2020-05-12 11:42:49 +08:00 1
过来人可以说一句:redux 真是浪费我好多青春
|
58
qbhy 2020-05-12 11:47:35 +08:00
还是用的不多
|
59
qbhy 2020-05-12 11:48:21 +08:00
说 redux 的,可以去 github 搜一下 dva,封装后还是很香的
|
60
ciqulover 2020-05-12 11:55:35 +08:00 via iPhone
大概上班太闲了不如去刷知乎。楼主是个新手就别尝试管中窥豹了。
|
62
crella 2020-05-12 12:05:52 +08:00 via Android
php 仍然是最好的语言(
|
63
hikaruchang 2020-05-12 12:35:05 +08:00 via iPhone
看你项目,合适的项目对应合适的工具
|
64
stantbyme 2020-05-12 12:54:45 +08:00
开始了 开始了
|
65
find456789 2020-05-12 13:02:54 +08:00 1
redux 、阿里的 dva 太难用了, 为啥不用 mobx
|
67
mywaiting 2020-05-12 13:07:21 +08:00
什么鬼 React/VUE,好好用 jQuery 不好么?
等 WebComponents 这套再成熟一点,Deno 的生态好一点,直接从 jQuery 跳 WebComponents 香爆 ~关键是还能继续用 jQuery~~~~ 什么老前辈 /思想顽固不化 /喜欢守旧 /害怕改变,说的就是我这样的只会 WordPress 的上古前端 |
68
wangyzj 2020-05-12 13:27:54 +08:00
fp 吹好多
|
69
jziwenchen 2020-05-12 13:35:48 +08:00 1
来 angualr8 啊 很香
|
70
noobma 2020-05-12 13:57:33 +08:00 1
@jziwenchen angular 9 了啊😂
|
71
Junh 2020-05-12 13:59:18 +08:00 via iPhone
还是 angular 香
|
72
noobcoder1 2020-05-12 14:09:43 +08:00
dva umi 了解一下
|
73
shabbyin 2020-05-12 14:15:30 +08:00
为什么向 children 传递 props 要 clone 一下 是因为 children 修改 props ?为什么会有这么迷惑的行为
|
75
Bigglesworth 2020-05-12 14:29:36 +08:00
@fumichael #18 哈哈哈哈哈
|
76
namelosw 2020-05-12 14:34:11 +08:00
@no1xsyzy 为啥说 React 是函数式就要锤爆?写过 OCaml 没有? Hooks 是 Algebraic effects 的实现。跟 Monad 作用类似。
|
77
dtysky 2020-05-12 14:48:42 +08:00
2020 年了,别吵三年前的话题了。
|
78
no1xsyzy 2020-05-12 15:08:37 +08:00
@namelosw #76 Don’t call Hooks inside loops, conditions, or nested functions.
https://reactjs.org/docs/hooks-rules.html 如果说不完整的实现 —— 甚至说只有幻想上的模拟(可以让函数式语言用户以函数式方式思考写出正常运作的代码,但注意你的脑子不能被非函数式污染),也能说是的话,那就是吧。 C 语言是一个(非常不完整地实现的) Lisp ! |
79
loveToMy1 2020-05-12 15:10:41 +08:00
你们不要吵了 要吵去练舞室去吵 (滑稽)
|
80
namelosw 2020-05-12 15:16:19 +08:00
@no1xsyzy 这两条已经很 trivial 了吧。基本上类似 Redux 不能 mutate 这种一下就能记住的简单规则。这里面 leverage 的是函数式风格,而不是追求纯函数式编程。毕竟 React team 也 evaluate 过 Monadic React……
这个就跟说 Clojure 是函数式语言一样,大部分人能认同,有一小部分 Haskell 党不能认同。 |
81
no1xsyzy 2020-05-12 15:59:16 +08:00
@namelosw #80 单这一条就够诡异的了。
我倒是非常讨厌函数式编程 /风格,但 hooks 就还好,只感觉非常脏。 看上去 Algebraic effects 实质上是向环境暴露续延,相当于 call/cc 和 parameter 的结合体。但 JavsScript 没有 First-class Continuation 的话连风格都是做不到的。 哪怕一个很简单的要求,就 https://reactjs.org/docs/hooks-rules.html 里面,只改 surname 的话是不应该运行 persistForm 的,但测试了一下并不能。 |
82
l1nyanm1ng 2020-05-12 16:02:35 +08:00 1
对象是穷人的闭包,闭包是穷人的对象,react 不用 class 组件了,结果在函数组件里面写了一大堆的 function,这么一看好像和对象方法没什么区别了,哎,终究逃不过这个定律,但是 hooks 肯定是好的,虽然有很多问题,但是 hooks 的 ts 类型约束比 hoc 简单太多了
|
83
devwolf 2020-05-12 16:13:19 +08:00
比什么,反正最后全都要学
|
84
pecopeco 2020-05-12 16:18:00 +08:00
至少,在 rn 面前,vue 的生态暂时一个能打的都没有
|
85
ljpCN 2020-05-12 16:18:25 +08:00 via Android
我也 react 转 vue,喜欢 react 。你说的这些应该是说明了 vue 开箱即用的程度更高。至于谁更好用,见仁见智。
|
86
namelosw 2020-05-12 16:22:43 +08:00
@no1xsyzy 毕竟当 Library 实现,而不是语言实现,没办法。感觉如果要走 Svelte 那种编译器路线理论上还可能实现完整的版本,但是感觉更不透明。
我想采访一下为什么讨厌函数式编程呢?我个人的体验是除去写底层 API,再除去 mutable 算法很好写的情况,普通的业务用函数式风格各方面都要好一点,好读 /好重构 /好扩展 /好测试 /好 reload 代码等等。 |
87
rain0002009 2020-05-12 16:34:24 +08:00
玩了 3 年 vue 最近开始学习 react (因为大家都在说这东西贼香),因为对 vue 的 nuxt 有好感(我都把它当 cli 用)所以用 next 搭建项目,我以为会像 nuxt 一样 一装就啥都有了呢,还会问你用 ts 还是用 js,以下 ui 框架都很好要不要装一个(好 那就装个 ant ),还可以使用其他服务框架,express koa hapi 啥的(不懂,默认吧),我们还集成了 axios 和 pwa 要不要用(那就装个 axios 吧),eslint,prettier 啥的要用不(虽然就我一个人玩,还是用一下吧),测试框架要不要装一个有 jest 和 ava (玩不来,算了),要使用 ssr 不(要吧,不然就真当 cli 了)
一进项目主目录,基本结构都有了呀,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 ) |
89
namelosw 2020-05-12 17:33:44 +08:00
@yazoox Ramda 只是一个比较贴合函数式风格的函数库而已。只是说大部分人写所谓函数式 React 都是很入门的内容,所以写起来很尴尬很麻烦。写过 Haskell 的人一般都能写出来很漂亮的 React 代码。
Scala 红皮书里面说过,如果函数式编程写得很笨很蹩脚,一般都是缺乏某种抽象。 函数式风格真正用起来是各种很流畅的函数组合,用函数高效流畅地地组装出绝大部分函数,大部分都是高阶函数各种传参生成一个需要的函数,而不是每次从头手写。 |
91
no1xsyzy 2020-05-12 18:20:54 +08:00
@namelosw #86 一方面是和我的理想形态(纯响应化)有点远,我非常希望写出一个函数之后,传入 atom 传出 atom,传入 source 传出 source,传入 sink 传出 sink 。打个比方,JavaScript 有 element.addEventListener('event', handler) 这样处理的,我觉得就应该变成
handler(element.eventSource('event')) |> sink 或者 element.eventSource('event') |> handler(sink) 或者更平衡的写法 element.eventSource('event') |> handler |> sink 也就是说,handler(source) 相当于每当 source 产生数据即丢给 handler,而该表达式的值是 handler 的结果作为新的 source,而 sink 会反过来,构造一个新的 sink,这个新的 sink 传入的任何数据都会经过 handler 然后将结果再传入原 sink 。 或者就是 Qt 信号槽。 但这种一条语句永久运行的模式,现在称为函数式的那些都反对这么做。 (话说 REPL 也有点难搞) 另外,不是很重要地,函数式 “编程” 有点强行造词的意味。我上面除了 #81 说讨厌外没有在 “函数式” 后面跟上 “编程”。 从我明白了 Excel 是真真正正的函数式之后就这样了。 |
92
menyakun 2020-05-12 18:38:43 +08:00
日常又开始了,狗头
|
93
hantsy 2020-05-12 18:56:18 +08:00 1
唯一爽的只有 Angular,从 Spring Boot 切换过去一天上手,DI,Module 概念太相似了。Angular 内置使用 Rxjs, 天生就是异步,Reactive 编程(对于使用过 ReactiveX 下的组件的后端开发人员,太亲切了)。
React 虽然一直在改进 Type 支持,现在对 TS 支持也很好,但是它不够 OOP,Function 是一等公民。JS 印迹太深。 VUE 没正经使用过,看过比较各框架的 TODO 例子,第一眼觉得与早期 Polymer 1 相似(语法杂交了 AngularJS 1 概念),实在没好感,实在找不到什么理由用它。 期待 WebComponents 流行起来。 |
94
hantsy 2020-05-12 19:00:44 +08:00
工具方面,Angular 生态圈很强大,很 Angular 扩展都支持 Angular Semantics,用 NG ADD 完成自动配置,用 NG UPdate 来自动升级。希望 React 下面能有一样工具加入 CRA 。
|
95
duan602728596 2020-05-12 19:13:39 +08:00
@rain0002009 https://github.com/ant-design/ant-design/issues/22802#issuecomment-621622699
next 里面使用 antd 按需加载的方法。因为 node_modules 里面的组件是使用 node 的 commonjs 的方式加载,而不是用 webpack 编译打包的,所以会报错 |
96
louieliu 2020-05-12 19:28:32 +08:00 via iPhone
是 React 太灵活 不好掌握到精髓 使用起来心智负担比 Vue 大
|
97
mandex 2020-05-12 19:43:34 +08:00
我用 React,因为 JSX 表现力远远强于 VUE 的模板语法,而且不需要重新学习各种指令,会 JS 就可以了,充分利用了 JS 的一切优点。
|
98
namelosw 2020-05-12 19:49:14 +08:00
@no1xsyzy 感觉这个形式和函数式也不矛盾啊,只是有个 sink 而已。比如 CycleJS 基本就是这样无限 sink,而且还有回绕,但我理解它还是非常函数式的,main 函数里面全都是 pure 的。
不过对比 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 的函数式是另外一回事。 |
99
ragnaroks 2020-05-12 19:52:34 +08:00
csharp => vue
java => react |
100
namelosw 2020-05-12 19:58:10 +08:00
@hantsy React,AngularJS 和 Angular 我都写了很多年,RxJS 我也用了很多年。
Angular 问题很多,特别写库和写业务完全就是两套不同的代码,感觉 Angular 很多东西写出来都特别困难,难受得一批。API 很多,我们都是后端团队,学起来上手快,后面还是各种踩坑。 Mark for check 机制完全就是自动挡变手动挡,而且机制完全没 React 和 Vue 直接,一不小心就无限刷,或者 onPush 就不更新得手动调 Zone 。 Rx 本身也不够建模用,写多了极乱,最后还是需要 Ng*s 之类的东西。 而且实话说 OO 相比 FP 扩展性很差。 React vs Vue 感觉还有的比,Ng 用没 React 和 Vue 人多是有原因的。 |