React基础
简介学完这篇博文,你可以对React,这个著名的Facebook的库有一定程度的理解,并能开始实践。再完成后续的学习之后你可以掌握React。在正式开始以前,先了解一些相关的概念。 什么是React?React是一个Facebook开发的UI库。使用这个库可以很方便的开发交互式的、具有表达力的和可重用的UI组件。并且这个库已经在facebook和instagram.com的产品中使用。 这个库的另外一个独特的卖点是:他不仅可以使用在客户端,还可以用在Server端渲染。 这个库还使用了一种叫做虚拟DOM(Virtual DOM)的概念,这些DOM可以根据状态有选择的渲染。这样,页面就会尽量的减少DOM操作而达到保持页面状态的效果。 虚拟DOM是如何工作的想象一下你根据一个人造了一个模特,这个模特几乎有这个人的全部属性,并且有这个人的所有当前状态。这基本上就是React的虚拟DOM做的。 现在假设你对这个人形模特做了某些修改。比如,加了胡子、强壮的二头肌。在React的世界里,当我们做了这些修改,会发生两件事:第一、运行“对比”算法找出发生的改变。第二、调整,根据第一步找出的不同执行必要的DOM操作。 React工作的方式不是把真人拿来从头到尾的来一次“整形”,而是只修改脸(帖胡子)和胳膊(二头肌)。也就是如果你在input里加了文字,之后开始渲染操作里,如果input的父节点没有开始上文第二步的“调整”操作,那么input里的文字是不会动的。 因为React使用的是假的DOM不是真的,这也给了React一个新的可能。我们可以在Server端渲染这些假DOM。 现在开始开始React之旅非常简单,主要下载facebook提供的开始示例: React入门示例 你也可以用他们提供的JSFiddle: React JSFiddle 建立页面稍后使用的练习页面需要包括 <!DOCTYPE html>
<html> <head> </head> <body> <div id='mount-point'> </div> <script src="https://cdnjs.cloudflare.com/ajax/libs/react/15.1.0/react.js"></script> <script src="https://cdnjs.cloudflare.com/ajax/libs/react/15.1.0/react-dom.js"></script> <script src="https://cdnjs.cloudflare.com/ajax/libs/babel-core/5.8.24/browser.min.js"></script> <script type="text/babel"> </script> </body> </html>
在React里,一个组件就是一个元素,所以在本例中我们可以使用 本例只是作为入门时使用的,在实际的开发中最好是把创建的组件都放在一个单独的文件中。 基本内容React的基本创建单元叫做组件,例如: <script type="text/babel">
ReactDOM.render(
<h1>Hello,World!</h1>,document.getElementById('mount-point') ); </script>
如果你从没见过这样的写法,你会以为javascript/HTML又有什么新的魔法了。 JSX其实这是JSX,是一个javascript的XML变体。使用JSX可以在javascript里写出HTML式的标签。 在JSX里,HTML的 你也可以不使用JSX,这是一个不用JSX的例子: ReactDOM.render(
React.createElement('h1',null,'Hello!'),document.getElementById('content')
);
组件使用ReactDOM的 var MyComponent = React.createClass({
render: function(){
return (
<h1>Hello,world!</h1> ); } });
组件创建好之后就可以在文档里渲染出来了: ReactDOM.render(
<MyComponent />,document.getElementById('mount-point') );
很酷吧!? 进阶创建组件的时候,我们可以给组件添加一些属性。这些属性都存放在props。这些属性可以通过 var MyComponent = React.createClass({
render: function(){
return (
<h1>Hello,{this.props.name}!</h1> ); } }); ReactDOM.render( <MyComponent name="handsome" />,document.getElementById('mount-point') );
生命周期和状态
生命周期方法
状态(State)在开始State之前,需要了解一些相关基础: 更多相关的的内容可以看这里。 每一个组件都包含一个 var MyComponent = React.createClass({
getInitialState:function(){
return {
count: 5
};
},render: function(){
return (
<h1>Hello,{this.state.count}!</h1> ); } });
事件React包含一个跨浏览器的事件系统。这些事件作为属性包含在组件中。代码: var Counter = React.createClass({
incrementCount: function(){
this.setState({
count: this.state.count + 1
});
},getInitialState: function(){
return {
count: 0
}
},render: function(){
return (
<div class="my-component"> <h1>Count: {this.state.count}</h1> <button type="button" onClick={this.incrementCount}>Increment</button> </div> ); } }); ReactDOM.render( <Counter />,document.getElementById('mount-point') );
单向数据流在Rect里,数据通过 组件的状态应该用 var FilteredList = React.createClass({
filterList: function(event){
var updatedList = this.state.initialItems;
updatedList = updatedList.filter(function(item){
return item.toLowerCase().search(
event.target.value.toLowerCase()) !== -1;
});
this.setState({items: updatedList});
},getInitialState: function(){
return {
initialItems: [
"Apples","Broccoli","Chicken","Duck","Eggs","Fish","Granola","Hash Browns"
],items: []
}
},componentWillMount: function(){
this.setState({items: this.state.initialItems})
},render: function(){
return (
<div className="filter-list"> <input type="text" placeholder="Search" onChange={this.filterList}/> <List items={this.state.items}/> </div> ); } }); var List = React.createClass({ render: function(){ return ( <ul> { this.props.items.map(function(item) { return <li key={item}>{item}</li> }) } </ul> ) } }); ReactDOM.render(<FilteredList/>,document.getElementById('mount-point'));
结语现在我们已经把React的基础都学会了,花点时间看看React API和JSX。 原文地址:https://scotch.io/tutorials/learning-react-getting-started-and-concepts Stay tuned to my next episode(编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |