今天,继续深入学习react.js。
目录:
一、JSX介绍
二、React组件生命周期详解
三、属性、状态的含义和用法
四、React中事件的用法
五、组件的协同使用
六、React中的双向绑定
一、JSX介绍
①定义
JSX=JavaScript XML,是一种在React组件内部构建标签的类XML语法。React在不使用JSX的情况下一样可以工作,但是使用JSX可以提高组件的可读性,增强JS语义,结构清晰,抽象程度高,代码模块化。因此推荐在React中使用JSX。
②特点
1、元素名首字母大写
2、符合嵌套规则
3、可以写入求值表达式
4、驼峰式命名
5、不能使用javascript原生函数的一些关键词,如for和class。需要替换成htmlFor和className
③使用方法
1、使用动态值:JSX将两个花括号之间的内容{...}渲染为动态值,花括号指明了一个javascript上下文环境,花括号里面可以是一个变量,也可以是函数。 例如:
var name=“winty”;{name}
function date(d){ return [ d.getFullYear(), d.getMonth()+1, d.getDate() ].join('-); };{date(new Date()}
2.注释:首先,在子节点中注释要用大括号包裹起来,然后就可以单行注释/**/,也可以多行注释//。
var Hello=React.createClass({ render:function(){ return//set name Hello ,World /* 多行注释 多行注释 */
} });
3.使用CSS内联样式
var style={ color:#000;};React.render(....,document.body);
4.使用条件判断
//方法1,三目运算符var Hello=React.createClass({ render:function(){ returnHello,{this.props.name?this.props.name : "LuckyWinty"}
}});//方法2,if-else语句var Hello1=React.createClass({ getName:function(){ if(this.props.name) return this.props.name; else return "LuckyWinty"; render:function(){ returnHello,{this.getName}
}}); //方法3,使用逻辑||运算符var Hello3=React.createClass({ render:function(){ returnHello,{this.props.name||"LuckyWinty"}
}});
④非DOM属性介绍
JSX中有3个非DOM属性,分别是:dangerouslySetInnerHTML、ref、key。
dangerouslySetInnerHTML:在JSX中直接插入HTML代码,但是如果能避免使用这个属性则尽量避免使用。
innerHTML
可能会导致 攻击。 净化用户的输入来显示的时候,经常会出现错误,不合适的净化也是 的原因之一。 在彻底的理解安全问题后果并正确地净化数据之后,生成只包含唯一 key __html
的对象,并且对象的值是净化后的数据。例如:
function createMarkup() { return {__html: 'First · Second'}; };
ref:父组件引用子组件,你可以通过在属性中设置期望的引用名来定义一个引用。例如:
...render:function(){ return}... //然后你就可以在组件中的任何地方使用this.refs.myInput获取这个引用了
key:是一个可选的唯一标识符,通过给组件设置一个独一无二的键,并确保它在一个渲染周期中保持一致,使得React能够更只能地决定应该重用一个组件还是销毁并重建一个组件,进而提高渲染性能。例如:
var Hello3=React.createClass({ render:function(){ return
- 1
- 2
- 3
更多详细信息请参考:http://facebook.github.io/jsx/
二、React组件生命周期详解
运行结果:
三、属性、状态的含义和用法
字符串 大括号包裹的求值表达式 传入数组 变量
var props={ one:"123", two:"22"}
var instance=React.render(,document.body);instance.setProps({name:"winty"});
handleChange:function(event){ console.log(event.target.value);}
其他不同类型的事件有不同的属性,简单了解一下
知道了事件的一些属性,我们就可以很方便地在React中获取这些属性,进行一些逻辑的处理,实现一些复杂的业务功能、页面效果等。
例如:我们可以利用鼠标事件属性,实时显示鼠标在某个区域的坐标:
五、组件的协同使用
①组件嵌套使用:也就是说,用一个父组件把子组件包裹起来,本质就是父子关系。如下图描述:
实例代码:
var React = require('react');var CommentList=require('./CommentList.jsx');var CommentForm=require('./commentFrom.jsx');var CommentBox = React.createClass({ render: function() { return (); }});module.exports = CommentBox;Comments
//这是一个组件 //这是另一个组件
②Mixin:也就是可以把相同的代码抽象出来,封装成一个函数,然后再调用。
var Time=React.createClass({ mixins:[IntervalMixin(1000)], getInitialState:function(){ return {secondElapsed:0}; }, onTick:function(){ this.setState({secondElapsed:this.state.secondElapsed+1}); }, render:function(){ return (Seconds Elapsed:{this.state.secondsElapsed}); }});
mixin相当简单,它们就是混合进组件类中的对象而已。React在这方面实现得更加深入,它能防止静默函数覆盖,同时还支持多个mixin混合。但是这些功能在别的系统中可能引起冲突。例如:
React.createClass({ mixins:[{ getInitialState:function(){ return {a:1}} }], getInitialState:function(){ return {b:2}}});
这样在mixin和组件类中同时定义了getInitialState方法,得到的初始state是{a:1,b:2}.如果mixin中的方法和组件类中的方法返回的对象中存在重复的键,React会抛出一个错误来警示这个问题。
六、React中的双向绑定
React创立的理念跟angular那些框架就是不同的,React是单向数据绑定的。那么怎么实现像angular那样的双向绑定效果呢?看代码:
React中的双向数据绑定
效果图(没有CSS样式,有点不优雅,见谅):