angular开发者吐槽react+redux的复杂:“一个demo证明你的开发效率低下”

曾经看到一篇文章,写的是jquery开发者吐槽angular的复杂。作为一个angular开发者,我来吐槽一下react+redux的复杂。

例子

为了让大家看得舒服,我用最简单的一个demo来展示react+redux的“弯弯绕”,下面这个程序就是我用react和redux写的。然而这个程序在angular中一行js都不用写!!!

展示组件

App.js

import React, { findDOMNode, Component } from ‘react‘;
import ReactDOM from ‘react-dom‘;
import { connect } from ‘react-redux‘;
import * as action from ‘./actions‘

class App extends Component {
  render() {
    return (
      <div>
        <input type=‘text‘ value={this.props.propsValue} onChange={this.changeHandle.bind(this)} ref="input"/>
        {this.props.propsValue}
      </div>
    );
  }
  changeHandle(){
    const node = ReactDOM.findDOMNode(this.refs.input);
    const value = node.value.trim();
    this.props.change(value);
  }
}

function mapStateToProps(state) {
  return {
    propsValue: state.value
  }
}

//将state的指定值映射在props上,将action的所有方法映射在props上
export default connect(mapStateToProps,action)(App);

没有玩过redux的同学们可能已经看得有点晕了,redux的设计是这样的:

state就是数据,组件就是数据的呈现形式,action是动作,action是通过reducer来更新state的。

上述代码,我们干了三件事:

  1. 编写一个可视化组件(其实就是个input);
  2. 将state的value属性绑定在组件的props上;
  3. 将action的所有方法绑定在组件的props上。

action和reducer两个好基友负责更新state

actions.js

//定义一个change方法,将来把它绑定到props上
export function change(value){
    return{
        type:"change",
        value:value
    }
}

reducers.js

//reducer就是个function,名字随便你起,功能就是在action触发后,返回一个新的state(就是个对象)
export default function change(state,action){
  if(action.type=="change")return{value:action.value};
  return {value:‘default‘};
}

上述代码我们就干了一件事:用户触发action后,更新状态。

因为状态和组件的props是绑定的,所以,组件也跟着变化了!

store出场,将reducer注入组件

index.js

import React from ‘react‘
import { render } from ‘react-dom‘
import { createStore } from ‘redux‘
import { Provider } from ‘react-redux‘
import App from ‘./App‘
import inputApp from ‘./reducers‘

let store = createStore(inputApp);

render(
  <Provider store={store}>
    <App />
  </Provider>,
  document.querySelector("#app")
);

provider是组件顶层,用来乘放store。

上述代码,我们干了三件事:

  1. 将reducer放进store
  2. 将store放进provider
  3. 将provider放在组件顶层,并渲染

最后用webpack编译运行

webpack.config.js

var path = require(‘path‘);
var webpack = require(‘webpack‘);

module.exports = {
    entry: {
        app:path.join(__dirname, ‘src‘),
        vendors: [‘react‘,‘redux‘]
    },
    output: {
        path: path.join(__dirname, ‘dist‘),
        filename: ‘[name].js‘
    },
    module: {
        loaders: [
            {
                test:/\.js?$/,
                exclude:/node_modules/,
                loader:‘babel‘,
                query:{
                    presets:[‘react‘,‘es2015‘]
                }
            }
        ]
    },
    plugins: [
        new webpack.optimize.CommonsChunkPlugin(‘vendors‘, ‘vendors.js‘)
    ]
};

好了,开始吐槽

槽点如下:

  1. 概念太多,props,state,action,reducer,store,provider,就这还没引入router呢,对新手而言,无法在脑海中立马形成一个清晰的流程
  2. 很多概念冗余,比如reducer和store
  3. 很简单一个功能,写了这么多代码,如果用angular一行代码都不用写
  4. 看看我们为了虚拟dom的高性能以及服务器渲染,牺牲了多少,虚拟dom的设计如果被angular引入,那么react的优点何在?
  5. 看看react所谓的简单,平滑的学习曲线,在引入某种框架后,还不是照样复杂。react本身非常简单,可是又有什么用呢?我们绝大多数人,还不是得结合backbone或者angular或者flux,reflux,redux来用。这样看来还简单吗?
  6. 更新太快,如果我不列出package.json清单,几个月后你能运行这个程序吗?
  7. 一个页面的HTML模板被完全碎片化了,angular的指令虽说也有此嫌疑,但是angular旨在”拓展html的能力“,并没有完全碎片化模板。
  8. ……

这些想法,我想对于angular开发者来说,都是有共鸣的。

没有用过angular的react开发者觉得react好,可能是因为他们没有用过angular,拿react和jquery对比得出的结论。

用过angular的react开发者觉得react好,无非就是因为

  1. react牛逼的服务器渲染
  2. diff算法带来的高性能。

但是,不考虑性能和seo,单从开发效率上来讲,angular以及mvvm的其他框架相对优秀一点!

当然这里还有适用场景的问题,因为我们研究所目前在做的是大数据平台,全是crud和表单,使用angular开发会非常合适。

一定要看

最后,我想说这篇文章娱乐为主,并不具有实际参考价值。因为redux是用来管理状态的框架,通常在大型复杂的项目中会发挥优势,而我用这样一个简单的demo来说明问题,本来就是哗众取宠,为了吸人眼球(来咬我呀)。前端圈太浮躁,就爱看这种文章。当然初学者也可以通过这篇文章来学习react+redux。

示例代码:

https://github.com/lewis617/myReact/tree/master/input-redux

运行方法:

npm install

npm run build

手动打开index.html

时间: 2024-07-28 20:42:48

angular开发者吐槽react+redux的复杂:“一个demo证明你的开发效率低下”的相关文章

用react + redux + router写一个todo

概述 最近学习redux,打算用redux + router写了一个todo.记录下来,供以后开发时参考,相信对其他人也有用. 注意: 我只实现了Footer组件的router,其它组件的实现方法是类似的. 由于react-router升级到V4,所以redux官网的demo有些地方不再适用. 代码 代码请见我的github 组织架构如下图: 原文地址:https://www.cnblogs.com/yangzhou33/p/9094545.html

我的第一个phonegap开发WebApp的demo 怎么搭建安卓开发环境以及安装phonegap

一.先来张图,赏心悦目观赏一下,哈 . 这个就是使用phonegap框架搭建起来的,运行在安卓环境上的第一个demo. 安卓的开发环境,大家都会搭建了,所以不赘述.讲一下,安装phonegap的步骤. 二.phonegap的安装   1. 设置系统变量系统变量 Path后面添加:(以下变量都是必须的,路径根据自己的设置)E:\android_sdk\sdk\tools;E:\android_sdk\sdk\platform-tools;E:\android_sdk\eclipse\plugins

一个资深iOS开发者对于React Native的看法

一个资深iOS开发者对于React Native的看法 当我第一次尝试ReactNative的时候,我觉得这只是网页开发者涉足原生移动应用领域的歪门邪道. 我认为一个js开发者可以使用javascript来构建iPhone应用确实是一件很酷的事情,但是我很快放弃了自己去使用它的念头.毕竟我因为爱好而从事ios原生开发多年,并且目前为止已经很熟悉这一套开发专业工具. 我已经创造了一些我引以为傲的iOS应用——一些使用Object-C和Xcode构建的应用,通常人们都是这么做的.这两样工具是苹果公司

成为优秀Angular开发者所需要学习的19件事

一款to-do app基本等同于前端开发的"Hello world".虽然涵盖了创建应用程序的CRUD方面,但它通常只涉及那些框架或库也能做到的皮毛而已. Angular看起来似乎总是在改变和更新 - 但实际上,还是有一些事情仍然保持不变.以下是关于Angular所需要学习的核心概念的概述,以便大家可以正确地利用JavaScript框架. 说到Angular,我们需要学习很多东西,很多人被困在初学者的圈子里,仅仅是因为不知道去哪里搜索或者应该搜索什么关键词.下面我们会说到的这个指南(也

ReactJS React+Redux+Router+antDesign通用高效率开发模板,夜间模式为例

工作比较忙,一直没有时间总结下最近学习的一些东西,为了方便前端开发,我使用React+Redux+Router+antDesign总结了一个通用的模板,这个技术栈在前端开发者中是非常常见的. 总的来说,我这个工程十分便捷,对于初学者来说,可能包含到以下的一些知识点: 一.React-Router的使用 Router是为了方便管理组件的路径,它使用比较简单,一般定义如下就行,需要注意的是,react-router的版本有1.0-3.0,各个版本对应的API大致相似,但也有不同,我使用的是2.X的,

6周学习计划,攻克JavaScript难关(React/Redux/ES6 etc.)

6周学习计划,攻克JavaScript难关(React/Redux/ES6 etc.) 余博伦· 2 个月前 原文链接:A Study Plan To Cure JavaScript Fatigue 作者:Sacha Greif 和大家一样,最近我也看了Jose Aguinaga写的How it feels to learn JavaScript in 2016. 显然这篇文章击中了人们的痛处.它在Hacker News上排了不止一次第一.同样也是/r/javascript上最火的一篇,在Med

react + redux 完整的项目,同时写一下个人感悟

先附上项目源码地址和原文章地址:https://github.com/bailicangd... 做React需要会什么? react的功能其实很单一,主要负责渲染的功能,现有的框架,比如angular是一个大而全的框架,用了angular几乎就不需要用其他工具辅助配合,但是react不一样,他只负责ui渲染,想要做好一个项目,往往需要其他库和工具的配合,比如用redux来管理数据,react-router管理路由,react已经全面拥抱es6,所以es6也得掌握,webpack就算是不会配置也

react+redux教程(六)redux服务端渲染流程

教程目录 react+redux教程(一)connect.applyMiddleware.thunk.webpackHotMiddleware react+redux教程(二)redux的单一状态树完全替代了react的状态机? react+redux教程(三)reduce().filter().map().some().every()....展开属性 react+redux教程(四)undo.devtools.router react+redux教程(五)异步.单一state树结构.compo

react案例-&gt;新闻移动客户端--(react+redux+es6+webpack+es6的spa应用)

今天分享一个react应用,应在第一篇作品中说要做一个react+redux+xxx的应用.已经做完一部分,拿出来分享.github地址为:点我就可以咯~ 这里实现了一个新闻移动站的spa.本来想写pc端的,但是比较懒,而且因为主要是react的项目,关于css和布局的细节就是糊弄人的了.T.T,这里只说关于这个项目的js部分. 这里的功能很简单,有一下几点: 1,按”心“排序 当比上一个多了,就会排到前面. 2.评论部分 新闻的评论部分类似qq空间的评论 当然,也可以点击新闻回复的哦. ===