react学习笔记2--练习Demos
准备工作
# 0、react核心库
<script src="../build/react.js"></script>
# 将JSX 语法转为 JavaScript
<script src="../build/JSXTransformer.js"></script>
1、react基本语法
<script type="text/jsx">
React.render(
<h1>react渲染一条内容</h1>,
document.getElementById('example')
);
</script>
2、一个简单的组件
- React 允许将代码封装成组件(component),然后像插入普通 HTML 标签一样,在网页中插入这个组件;
- 【注意,组件类的第一个字母必须大写,否则会报错,比如HelloMessage不能写成helloMessage。】
<script type="text/jsx">
var HelloMessage = React.createClass({
render: function() {
return (
<p>我擦,这个是组件</p>
);
}
});
React.render(
<HelloMessage />,
document.getElementById('example')
);
</script>
3、组件的生命状态
- 组件的生命周期【挂载、更新、移除】
- getInitialState:是一个比较重要的方法,在组件挂载之前调用一次,可以用来定义初始化的数据,然后在后面调用
- getDefaultProps:
- 在组件类创建的时候调用一次,然后返回值被缓存下来。如果父组件没有指定 props 中的某个键,则此处返回的对象中的相应属性将会合并到 this.props (使用 in 检测属性)。
*【该方法在任何实例创建之前调用】,因此不能依赖于 this.props。另外,getDefaultProps() 返回的任何复杂对象将会在实例间共享,而不是每个实例拥有一份拷贝。
- 在组件类创建的时候调用一次,然后返回值被缓存下来。如果父组件没有指定 props 中的某个键,则此处返回的对象中的相应属性将会合并到 this.props (使用 in 检测属性)。
- componentWillMount【挂载】:
- 服务器端和客户端都只调用一次,在初始化渲染执行之前立刻调用。如果在这个方法内调用 setState,render() 将会感知到更新后的 state,将会执行仅一次,尽管 state 改变了。
- componentDidMount【挂载】:
- 在初始化渲染执行之后立刻调用一次,仅客户端有效(服务器端不会调用)。在生命周期中的这个时间点,组件拥有一个 DOM 展现,你可以通过 this.findDOMNode() 来获取相应 DOM 节点。
- 如果想和其它 JavaScript 框架集成,使用 setTimeout 或者 setInterval 来设置定时器,或者发送 AJAX 请求,可以在该方法中执行这些操作。
<script type="text/jsx">
var HelloMessage = React.createClass({
getInitialState:function(){
// this.state={};
console.log("在组件挂载之前调用一次。返回值将会作为 this.state 的初始值。");
return {data : "haha"};
},
getDefaultProps:function(){console.log("")},
componentWillMount:function(){console.log(1)},
componentDidMount:function(){console.log(2)},
// [更新的时候调用]
componentWillReceiveProps:function(){console.log(3)},
shouldComponentUpdate:function(){console.log(4)},
componentWillUpdate:function(){console.log(5)},
componentDidUpdate:function(){console.log(6)},
// 移除的时候调用
componentWillUnmount:function(){console.log(7)},
render: function() {
return (
<p>我擦,这个是组件{this.state.data}</p>
);
}
});
React.render(
<HelloMessage />,
document.getElementById('example')
);
</script>
4、事件处理
- react的事件支持有点像是传统的事件绑定方法,通过onClick等绑定事件;
数据的变化可以通过state的变量变【用this.setState方法】,也可以通过全局变量变
<script type="text/jsx">
var i=0;
var HelloMessage = React.createClass({
getInitialState:function(){
console.log("在组件挂载之前调用一次。返回值将会作为 this.state 的初始值。");
return {data : "haha"};
},
handClick:function(){
++i;
this.setState({data : "点击了"+i})
},
render: function() {
return (
<p onClick={this.handClick}>我擦,这个是组件,可点击-----{this.state.data}</p>
);
}
});
React.render(
<HelloMessage />,
document.getElementById('example')
);
</script>
5、DOM操作
- React.findDOMNode(component)获取到组件中真实的DOM;
- react可以允许我们通过 ref 来定位一个组件。具体的做法是:先给一个组件设置一个 ref=‘xxx’ 的属性,注意这个ref必须是全局唯一的。
<input ref='myTextInput' />然后就可以通过 this.refs.myTextInput 来访问这个组件。【不过,这里拿到的只是虚拟DOM,而不是真实的DOM。】 - 获取DOM主要是为了用第三方的插件来实现我们的功能,如jQuery。
<script type="text/jsx">
var MyComponent = React.createClass({
handleClick: function() {
// Explicitly focus the text input using the raw DOM API.
React.findDOMNode(this.refs.myTextInput).focus();
},
render: function() {
// The ref attribute adds a reference to the component to
// this.refs when the component is mounted.
return (
<div>
<input type="text" ref="myTextInput" />
<input
type="button"
value="Focus the text input"
onClick={this.handleClick}
/>
</div>
);
}
});
React.render(
<MyComponent />,
document.getElementById('example')
);
</script>
6、组件组合使用
- 复合组件必须有一个,而且只能有一个父节点;如Box组件
- 复合组件添加方法如
<script type="text/jsx">
var ComDemo1=React.createClass({
render: function() {
return (<p>哈哈哈,组件</p> );
}
});
var ComDemo2=React.createClass({
render: function() {
return (<p>哈哈哈,组件2</p> );
}
});
var Box=React.createClass({
render: function() {
return (
<div>
<ComDemo1 /><ComDemo2 />
</div>
);
}
});
React.render(
<Box />,
document.getElementById('example')
);
</script>
7、组件之间的数据传递
- 组件之间之间的组合使用的时候,this.state和this.props是很重要的一些东西
- 这个demo的数据的交换通过父亲Box组件来实现
- comment_txt,data都是用来绑定子节点的一些方法
- 类似input这种非成对标签,需要"/"结尾如
"<input type="text" ref="input_txt" />" - this.refs用来绑定获取真实的dom节点
- this.props.data.map遍历父元素传过来的数据
- this.setState({list:this.state.list})重新设计数据,会自动刷新
<script type="text/jsx">
var BoxInput=React.createClass({
btn_sub:function(){
var txts=this.refs.input_txt.getDOMNode().value.trim();
this.props.comment_txt(txts);
this.refs.input_txt.getDOMNode().value = '';
},
render: function() {
return (
<div className="inp">
<input type="text" ref="input_txt" />
<input type="button" value="添加" onClick={this.btn_sub} />
</div>
);
}
});
var BoxShow=React.createClass({
render: function() {
var com_lsit=this.props.data.map(function ( comment,index ){
return(<li>{index+1}、{comment}</li> )
});
return (
<ul> {com_lsit} </ul>
);
}
});
var Box=React.createClass({
getInitialState:function(){
return{
list:["第一","XD"]
}
},
surper_comment_txt:function(comment){
// console.log("传过来的东西:"+comment);
this.state.list.push(comment);
console.log(this.state.list);
this.setState({list:this.state.list})
},
render: function() {
// comment_txt,data都是用来绑定子节点的一些方法
return (
<div>
<BoxInput comment_txt={this.surper_comment_txt} />
<BoxShow data={this.state.list} />
</div>
);
}
});
React.render(
<Box />,
document.getElementById('example')
);
</script>
8、Mixins
- mixins是用来做方法复用的,
- 使用方法:mixins:[SetIntervalMixin],
- note:使用 ES6 class 定义的组件已经不支持 mixin 了,因为使用 mixin 的场景都可以用组合组件这种模式来做到
<script type="text/jsx">
var SetIntervalMixin = {
fn1:function(){console.log("我是方法1") },
fn2:function(){console.log("我是方法2") },
fn3:function(){console.log("我是方法3") }
};
var ComDemo1=React.createClass({
mixins:[SetIntervalMixin],
getInitialState:function(){
this.fn1();
return{};
},
render: function() {
return (<p>哈哈哈,组件</p> );
}
});
var ComDemo2=React.createClass({
mixins:[SetIntervalMixin],
getInitialState:function(){
this.fn2();
return{};
},
render: function() {
return (<p>哈哈哈,组件2</p> );
}
});
var ComDemo0=React.createClass({
render: function() {
return (
<div><ComDemo2 /><ComDemo1 /></div>
);
}
});
React.render(
<ComDemo0 />,
document.getElementById('example')
);
</script>
9、其他
- Flux等还需要了解,练习
- 服务端渲染需要了解
- 动画等也没有了解
参考文章
react学习笔记2--练习Demos的更多相关文章
- react学习笔记1--基础知识
什么是react A JAVASCRIPT LIBRARY FOR BUILDING USER INTERFACES[React是一个用于构建用户界面的JavaScript库.] React之所以快, ...
- React学习笔记--程序调试
React学习笔记 二 程序调试 前面我们搭建好了React的基本开发环境,可以编写基本的React js程序了.但完成的开发环境肯定包含调试器,怎么调试用React编写的JS程序呢?有浏览器,比 ...
- React学习笔记(一)- 入门笔记
React入门指南 作者:狐狸家的鱼 本文链接:React学习笔记 GitHub:sueRimn 1.组件内部状态state的修改 修改组件的每个状态,组件的render()方法都会再次运行.这样就可 ...
- React学习笔记(七)条件渲染
React学习笔记(七) 六.条件渲染 使用if或条件运算符来创建表示当前状态的元素. 可以使用变量来存储元素.比如: let button = null; if (isLoggedIn) { but ...
- React学习笔记(六)事件处理
React学习笔记(六) 五.事件处理 React事件绑定属性的命名采用驼峰写法,不同于传统DOM全部小写. 如果采用JSX的语法,事件函数需要用大括号{}包裹函数名,不同于传统DOM字符串小括号的方 ...
- React学习笔记(五)State&声明周期
React学习笔记(五) 四.State&声明周期 可以为组件添加"状态(state)".状态与属性相似,但是状态是私有的,完全受控于当前组件. 局部状态就是只能用于类(定 ...
- React学习笔记 - 组件&Props
React Learn Note 4 React学习笔记(四) 标签(空格分隔): React JavaScript 三.组件&Props 组件可以将UI切分成一些独立的.可复用的部件,这样你 ...
- React学习笔记 - 元素渲染
React Learn Note 3 React学习笔记(三) 标签(空格分隔): React JavaScript 二.元素渲染 元素是构成react应用的最小单位. 元素是普通的对象. 元素是构成 ...
- React学习笔记 - JSX简介
React Learn Note 2 React学习笔记(二) 标签(空格分隔): React JavaScript 一.JSX简介 像const element = <h1>Hello ...
随机推荐
- 程序员之---C语言细节22(函数返回指针注意事项<悬空指针>、查看进程能够分配的内存大小)
主要内容:函数返回指针注意事项<悬空指针>.查看进程能够分配的内存大小 #include <stdio.h> char * favorite_fruit() { static ...
- Razor button
比起Web Form開發,在後端(.cs)寫法上大同小異,可選擇C#或VB.NET來撰寫:而在前端(.cshtml..vbhtml)則有比較大的差別,自 MVC3版本後,就以Razor為前端檢視引擎, ...
- 关于VCL的编写 (一) 如何编写自己的VCL控件
如何编写自己的VCL控件 用过Delphi的朋友们,大概对Delphi的最喜欢Delphi的不是他的强类型的pascal语法,而是强大的VCL控件,本人就是一位VCL控件的爱好者. VCL控件的开源, ...
- c# 获取某个对象的[公有属性]的名称,类型,值
/// <summary> /// 获取某个对象的[公有属性]的名称,类型,值 /// </summary> /// <typeparam name="T&qu ...
- POJ 3422 Kaka's Matrix Travels(费用流)
POJ 3422 Kaka's Matrix Travels 题目链接 题意:一个矩阵.从左上角往右下角走k趟,每次走过数字就变成0,而且获得这个数字,要求走完之后,所获得数字之和最大 思路:有点类似 ...
- javascript有用小技巧—实现分栏显示
记得给师哥师姐測试考试系统的时候,看到他们的考试页面能够实现隐藏左边的考生信息部分,当时认为好高大上.好人性化. 如今学了javascript,我也能实现这个功能了,以下来显摆一下. 1.页面设计: ...
- 如何找到w3wp与w3svc的对应关系
在生产环境中,一般会有多个IIS进程在运行,这里面可能是有Web Garden的设置,也可能是有多个application pool在运行.而我们经常在c:\inetpub\logs目录下面,看到很多 ...
- phonegap+emberjs+python手机店发展,html5实现本地车类别~
商城开发项目,现在需要做出APP,无奈出场前android但不是很精通.最后选择phonegap实现app. 由于之前办理购物车分为登陆和登陆后两种情况,登录前必须充分利用本地存储.而基于phoneg ...
- 了解ASP.NET5 Web应用程序结构
本文参考ASP.NET5 官方文档 Understanding ASP.NET 5 Web Apps,加入了一些个人理解,理解不对的地方希望大家能指出,互相学习. ASP.NET 5 针对WEB编程引 ...
- C# WinForm dataGridView 技巧小结
1.不显示第一个空白列RowHeaderVisible属性设置为false 2.点击cell选取整行SelectinModel属性FullRowSelectRowSelectinModel属性设置或用 ...