本系列将尽可能使用ES6(ES2015)语法。所以均在上节webpack的基础上做开发。
React是Facebook开发的一款JS库,因为基于Virtual DOM,所以响应速度快,以及支持跨平台。
(实际上,Virtual DOM在某些情况都会损耗一些性能在diff上,但相比其他MVVM框架比起来性能影响很少,同时大幅提升开发效率也是目前推荐的方式)
安装React: npm i -S react react-dom
安装Babel:npm i babel-loader babel-preset-react babel-plugin-import -S
import React from 'react';
import ReactDOM from 'react-dom';
ReactDOM.render(
<h1>Hello, world!</h1>,
document.getElementById('root')
);
JavaScript 的一种扩展语法。我们推荐在 React 中使用这种语法来描述 UI 信息。
const element = (
<h1 className="greeting">
Hello, world!
</h1>
);
const element = React.createElement(
'h1',
{ className: 'greeting' },
'Hello, world!'
);
// 注意: 以下示例是简化过的(不代表在 React 源码中是这样)
const element = {
type: 'h1',
props: {
className: 'greeting',
children: 'Hello, world'
}
};
React框架的一大特色就是它通过组件化的方式来构建和渲染前端页面。
定义组件有很多方式,最主流的为:函数 和 类(类允许我们在其中添加本地状态(state)和生命周期钩子。)
function Welcome(props) {
return <h1>Hello, {props.name}</h1>;
}
class Welcome extends React.Component {
render() {
return <h1>Hello, {this.props.name}</h1>;
}
}
React组件的生命周期事件很多,常用的有:
生命周期事件又分为3条流程:
React负责渲染表单的组件仍然控制用户后续输入时所发生的变化。相应的,其值由React控制的输入表单元素称为“受控组件”。
class ShowInput extends Component {
constructor(props) {
super(props);
this.state = {
val: 'hello'
}
}
onChange(e) {
this.setState({
val: e.target.value
})
}
render() {
return (
<div>
<input type="text" onChange={e => this.onChange(e)} />
<div>{this.state.val}</div>
</div>
)
}
}
DivInput组件中的input元素就是受控组件。value 和 onChnage都会由React控制。
render() {
return (
<div>
<input type="text" ref={e => this.input = e} />
<button onClick={() => console.log(this.input.value)}>Click</button>
</div>
);
}
挂到组件(这里组件指的是有状态组件)上的ref表示对组件实例的引用,而挂载到dom元素上时表示具体的dom元素节点。(stateless构造的组件是不会实例化,所以ref引用的为null)
ref属性可以设置为一个回调函数,这也是官方强烈推荐的用法;这个函数执行的时机为:
ReactDOM.findDOMNode(ref)来获取组件挂载后真正的dom节点。
组件之间通信的解决方案通常有2种:
原文:https://www.cnblogs.com/neverc/p/9057220.html