【前端笔记】Redux+Flux+webpack+Babel

AMD
Require.js
Node.js
CommonJS
browserify、webpack现代打包工具
ES6

//hello.js
function hello(){
}
export function foo(){
}
export const PI = 3.14;
export let person = {name: 'xiaoming'};
export hello;
//main.js
import { hello } from './hello.js';
import {PI, person} from './hello.js';
import * as util from './hello.js';

util.foo();
hello();
Babel

多用途的JS编译器,将最新版本的js编译成当下浏览器可以执行的版本。
Babel的核心是利用一系列的plugin来管理编译规则,通过不同的plugin,不仅可以编译ES6代码,还能编译React JSX语法等。

module模块和component组件

JS代码格式检测和压缩工具
jshint test.js
uglifyjs test.js -o output.js

Grunt、Gulp //组件打包工具

http://gruntjs.com/getting-started

RequireJS、browserify、webpack //模块打包工具
  • requirejs

npm install -g requirejs
r.js -o app.build.js

  • browserify

npm install -g browserify
browserify main.js -o bundle.js

  • webpack

npm install -g webpack
webpack main.js bundle.js
webpack.config.common.js
webpack.config.dev.js
webpack.config.dis.js

  • webpack-loader

npm install --save-dev style-loader css-loader
require('style-loader!css-loader!./index.css')

  • webpack-plugin

npm install --save-dev html-webpack-plugin webpack style-loader css-loader

React

Facebook推出的一个JS库
组件化、JSX语法、Virtual DOM

webpack、webpack-dev-server、babel-core、babel-loader、babel-preset-es2015、babel-preset-react、eslint【代码规范检查工具】、eslint-loader、eslint-plugin-import、eslint-plugin-react、eslint-plugin-jsx-a11y、eslint-config-airbnb

组件热加载 [Hot Module Replacement] babel-preset-react-hmre

props属性 { PropTypes }

state状态
可以在constructor中使用this.state直接定义它的值,使得渲染不同的UI,
也可以手动通过this.setState改变状态,从而重新调用render方法,渲染新的UI

ES6 class类型的component组件声明方式中,不会把一些自定义的callback方法绑定到实例上,所以需要手动在constructor中绑定:this.callback = this.callback.bind(this)

组件生命周期
getDefaultProps --> getInitialState -> componentWillMount -> render -> componentDidMount

组件props更新生命周期
componentWillReceiveProps -> shouldComponentUpdate -> componentWillUpdate -> render -> componentDidUpdate

组件卸载
componentWillUnmount

无状态函数式组件stateless functional component
没有state,只有props,则可以简化写成

function Component(props){
  return <div>{props.xxx}</div>
}

DOM操作
this.refs.name <- ref="xxx"属性

VirtualDOM
DOM结构的JS对象描述 = DOM + JS
https://github.com/Matt-Esch/virtual-dom

循环展示组件是,给每个子组件的key属性都赋值,目的是在重新渲染时,提高Diff算法的效率。

React测试

Mocha 很流行的前端测试框架,让异步测试变得简单。
http://mochajs.org

Chai 优秀的断言测试库。

React 官方测试库 react-addons-test-utils <-- Enzyme
Shallow Render 通过shallow()方法可以生成一个虚拟的DOM节点,然后可以通过find()方法测试属性值
https://github.com/airbnb/enzyme

安装:

npm i --save-dev ignore-styles mocha chai
npm i --save-dev react-addons-test-utils enzyme
mkdir test
touch Enzyme.test.js

package.json文件配置test脚本命令:
"test" : "NODE_ENV=production mocha --compliers js:babel-core/register --require ignore-styles"

使用:
test目录下创建文件Enzyme.test.js 然后运行npm test

import React from 'react';
import {expect} from 'chai';
import {shallow} from 'enzyme';
import List from '../app/components/List';
import ListItem from '../app/components/ListItem';

describe('Testing all the SFC using Enzyme', function(){
    const testData = [
    {
        "id": "dafksafksjfs23232",
        "title": "new item",
        "content": "hello item",
        "time": 1458030208359
    },
    {
        "id": "dsdsdsdad",
        "title": "new item2",
        "content": "# hello item2",
        "time": 1458030208359
    }
    ];

    it('test `List` component using Enzyme', ()=>{
        let list = shallow(<List items={testData} />);
        expect(list.find(ListItem).length).to.equal(testData.length);
    });

    it('test `ListItem` component using Enzyme', ()=>{
        let item = shallow(<ListItem item={testData[0]} />);
        expect(item.find('.item-title').text()).to.equal(testData[0].title);
        expect(item.find('.item-time').length).to.equal(1);
    })
});

Flux

Facebook官方推出的管理数据流、state、路由等的库,更像一种软件开发模式。
Action --> Dispatcher --> Store --> View

用户事件触发action--->到dispatcher--->数据存储中心store然后changed通过emit变换通知view改变状态从而达到刷新UI的流程。

Redux

提供了可预测的state管理,是跨平台的。
单一数据源、只读的state

action --> reducer --> store --- applyMiddleware

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 205,132评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,802评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,566评论 0 338
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,858评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,867评论 5 368
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,695评论 1 282
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,064评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,705评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 42,915评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,677评论 2 323
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,796评论 1 333
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,432评论 4 322
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,041评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,992评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,223评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,185评论 2 352
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,535评论 2 343

推荐阅读更多精彩内容

  • GitChat技术杂谈 前言 本文较长,为了节省你的阅读时间,在文前列写作思路如下: 什么是 webpack,它要...
    萧玄辞阅读 12,671评论 7 110
  • 无意中看到zhangwnag大佬分享的webpack教程感觉受益匪浅,特此分享以备自己日后查看,也希望更多的人看到...
    小小字符阅读 8,140评论 7 35
  • webpack 介绍 webpack 是什么 为什么引入新的打包工具 webpack 核心思想 webpack 安...
    yxsGert阅读 6,450评论 2 71
  • SPA(Single Page Application) 单页面应用,就是只有一张Web页面的应用。单页应用程序 ...
    sheepmiee阅读 1,428评论 0 5
  • 分别这件事,随着年龄的增大,在我们的生活中变得越来越不可避免。 去年夏天,我们在一起兼职结束那天,...
    Lemon莫莫阅读 210评论 0 0