React+webpack+es6的环境配置及demo改写
前言
git clone https://github.com/jrainlau/react-learning cd react-learning && npm install npm run dev 然后浏览器打开localhost:8080即可 最近在家闲得无聊,所以打算折腾一下react。在此之前,我是一个vue的重度使用用户,但是看到react确实非常火爆,所以也就趁此机会去了解一下react,增长一下见识。 学习react的参考资料,很大一部分来自 @阮一峰 的React入门实例教程。但是阮大神是用传统的 环境配置环境配置参照了@minooo 的文章:webpack-es6-react (为系统学习React布一个良好的开局)。这里引用一些关键包的说明:
另外,我增加了
使用es6改写demo首先可以参考这篇文章React on ES6+,里面提及了关于如何使用es6进行react开发的方法。
// The ES5 way var Photo = React.createClass({ handleDoubleTap: function(e) { … },render: function() { … },}); // The ES6+ way class Photo extends React.Component { handleDoubleTap(e) { … } render() { … } }
// The ES5 way var Video = React.createClass({ getDefaultProps: function() { return { autoPlay: false,maxLoops: 10,}; },getInitialState: function() { return { loopsRemaining: this.props.maxLoops,propTypes: { autoPlay: React.PropTypes.bool.isRequired,maxLoops: React.PropTypes.number.isRequired,posterFrameSrc: React.PropTypes.string.isRequired,videoSrc: React.PropTypes.string.isRequired,},}); // The ES6+ way class Video extends React.Component { static defaultProps = { autoPlay: false,} static propTypes = { autoPlay: React.PropTypes.bool.isRequired,} state = { loopsRemaining: this.props.maxLoops,} }
// The ES5 way var Video = React.createClass({ getInitialState: function() { return { loopsRemaining: ... }; } }); //The ES6 way class Video extends React.Component { constructor(props) { super(props) this.state = { loopsRemaining: ... } } } 组件化思路通过es6的模块功能,可以很方便地利用webpack实现页面组件化。 我们总共有7个小的demo,我把它们作为不同的组件,最终加载到根组件中: // app.js import React,{ Component } from 'react' import Component1 from './demo1.js' import Component2 from './demo2.js' import Component3 from './demo3.js' import Component4 from './demo4.js' import Component5 from './demo5.js' import Component6 from './demo6.js' import Component7 from './demo7.js' export default class Demo extends Component { render() { return ( <div> <Component1></Component1> <Component2></Component2> <Component3 title='Props example'></Component3> <Component4> <span>Hello</span> <span>React</span> </Component4> <Component5 content='This is the content'></Component5> <Component6></Component6> <Component7></Component7> </div> ) } } 具体请进入我的项目查看代码。 可以看到,通过es6的改写,在react中实现组件化是非常清晰简单的,只需要把需要的组件import进来即可。 另外,由于我非常讨厌行内样式,并且是不写less会死星人,所以并没有按照官方推荐的样子去定义一个 // demo7.js render() { let word = this.state.words require('../less/test.less') return ( <div> <h3 className='test-h1'>DEMO 7,state</h3> <p>{ word }</p> <input type="text" onChange={ this.stateFn }/> <hr/> </div> ) } 结语这个demo仅仅作为入门学习使用,react更多深层次的内容可能会在后续慢慢更新,比如加上react-router,redux什么的……如果这篇文章能够对你有所启发是最好不过,如果有任何错漏也欢迎拍砖指出,谢谢大家~ (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |