React(一)基础点
prop实例
<div id="app"></div> <script src="bower_components/react/react.min.js"></script> <script src="bower_components/react/react-dom.min.js"></script> <script src="lib/babel-core/browser.min.js"></script> <script type="text/babel"> var MessageBox = React.createClass({ getInitialState: function () { return { isVisible: true, titleMessage: '你好世界(来自state哦)', subMessages: [ '我会代码搬砖', '以及花式搬砖', '不说了,工头叫我回去搬砖了。。。。。' ] } }, render: function () { return ( <div> <h1>{this.state.titleMessage}</h1> <SubMessage messages={this.state.subMessages} /> </div> ) } }); var SubMessage = React.createClass({ propTypes: { messages: React.PropTypes.array.isRequired }, getDefaultProps: function () { return { messages: ['默认的子消息'] // 防止this.props.messages不存在 } }, render: function () { var msgs = []; this.props.messages.forEach(function (msg, index) { msgs.push( <p>码农说:{msg}</p> ); }); return ( <div>{msgs}</div> ) } }); var messageBox = ReactDOM.render( <MessageBox/>, document.getElementById('app') ); </script>
表单监听事件(非常麻烦,下一段代码有替代的)
<div id="app"></div> <script src="bower_components/react/react.min.js"></script> <script src="bower_components/react/react-dom.min.js"></script> <script src="lib/babel-core/browser.min.js"></script> <script type="text/babel"> var FormApp = React.createClass({ getInitialState: function () { return { inputValue: 'input value', selectValue: 'A', radioValue: 'B', textareaValue: 'some text here' } }, // 监听表单值的改变 handleInput: function (e) { this.setState({ inputValue: e.target.value }); }, handleSelect: function (e) { this.setState({ selectValue: e.target.value }); }, handleSubmit: function (e) { e.preventDefault(); console.log('form submit'); console.log(e); }, render: function () { return ( <div> <form action="" onSubmit={this.handleSubmit}> <input type="text" value={this.state.inputValue} onChange={this.handleInput}/> <select name="" id="" value={this.state.selectValue} onChange={this.handleSelect}> <option value="A">A</option> <option value="B">B</option> <option value="C">C</option> <option value="D">D</option> <option value="E">E</option> </select> <br/> <p>radio button!</p> <input type="radio" name="goodRadio" value="A"/> <input type="radio" name="goodRadio" defaultChecked value="B"/> <input type="radio" name="goodRadio" value="C"/> <br/> <input type="checkbox" name="goodRadio" value="A"/> <input type="checkbox" name="goodRadio" value="B"/> <input type="checkbox" name="goodRadio" defaultChecked value="C"/> <br/> <textarea name="" id="" cols="30" rows="10" value={this.state.textareaValue}> </textarea> <button type="submit">提交</button> </form> </div> ) } }); var messageBox = ReactDOM.render( <FormApp/>, document.getElementById('app') ); </script>
指向ref
var FormApp = React.createClass({ getInitialState: function () { return { inputValue: 'input value', selectValue: 'A', radioValue: 'B', checkboxValues: ['C'], textareaValue: 'some text here' } }, handleSubmit: function (e) { e.preventDefault(); console.log('form submit'); var formData = { input: this.refs.myInput.value, select: this.refs.mySelect.value, textarea: this.refs.myTextarea.value, radio: this.state.radioValue, check: this.state.checkboxValues }; console.log('the form result is: '); console.log(formData); }, handleRadio: function (e) { this.setState({ radioValue: e.target.value }); }, handleCheck: function (e) { var checkboxValues = this.state.checkboxValues.slice(); var newVal = e.target.value; var index = checkboxValues.indexOf(newVal); if(index == -1) { checkboxValues.push(newVal); } else { // 存在了删除掉 checkboxValues.splice(index, 1); } this.setState({ checkboxValues: checkboxValues }); }, render: function () { return ( <div> <form action="" onSubmit={this.handleSubmit}> <input ref="myInput" type="text" defaultValue={this.state.inputValue}/> 选项: <select name="" id="" defaultValue={this.state.selectValue} ref="mySelect"> <option value="A">A</option> <option value="B">B</option> <option value="C">C</option> <option value="D">D</option> <option value="E">E</option> </select> <br/> <p>radio button!</p> <RadioButtons handleRadio={this.handleRadio} /> <br/> <CheckboxButtons handleCheck={this.handleCheck} /> <br/> <textarea name="" id="" cols="30" rows="10" defaultValue={this.state.textareaValue} ref="myTextarea"> </textarea> <button type="submit">提交</button> </form> </div> ) } }); var RadioButtons = React.createClass({ render: function () { return ( <div> A <input onChange={this.props.handleRadio} type="radio" name="goodRadio" value="A"/> B <input onChange={this.props.handleRadio} type="radio" name="goodRadio" defaultChecked value="B"/> C <input onChange={this.props.handleRadio} type="radio" name="goodRadio" value="C"/> </div> ); } }); var CheckboxButtons = React.createClass({ render: function () { return ( <div> A <input onChange={this.props.handleCheck} type="checkbox" name="A" value="A"/> B <input onChange={this.props.handleCheck} type="checkbox" name="B" value="B"/> C <input onChange={this.props.handleCheck} type="checkbox" name="C" defaultChecked value="C"/> </div> ) } }); var messageBox = ReactDOM.render( <FormApp/>, document.getElementById('app') );
React(一)基础点的更多相关文章
- react组件的生命周期
写在前面: 阅读了多遍文章之后,自己总结了一个.一遍加强记忆,和日后回顾. 一.实例化(初始化) var Button = React.createClass({ getInitialState: f ...
- 十分钟介绍mobx与react
原文地址:https://mobxjs.github.io/mobx/getting-started.html 写在前面:本人英语水平有限,主要是写给自己看的,若有哪位同学看到了有问题的地方,请为我指 ...
- RxJS + Redux + React = Amazing!(译一)
今天,我将Youtube上的<RxJS + Redux + React = Amazing!>翻译(+机译)了下来,以供国内的同学学习,英文听力好的同学可以直接看原版视频: https:/ ...
- React 入门教程
React 起源于Facebook内部项目,是一个用来构建用户界面的 javascript 库,相当于MVC架构中的V层框架,与市面上其他框架不同的是,React 把每一个组件当成了一个状态机,组件内 ...
- 通往全栈工程师的捷径 —— react
腾讯Bugly特约作者: 左明 首先,我们来看看 React 在世界范围的热度趋势,下图是关键词“房价”和 “React” 在 Google Trends 上的搜索量对比,蓝色的是 React,红色的 ...
- 2017-1-5 天气雨 React 学习笔记
官方example 中basic-click-counter <script type="text/babel"> var Counter = React.create ...
- RxJS + Redux + React = Amazing!(译二)
今天,我将Youtube上的<RxJS + Redux + React = Amazing!>的后半部分翻译(+机译)了下来,以供国内的同学学习,英文听力好的同学可以直接看原版视频: ht ...
- React在开发中的常用结构以及功能详解
一.React什么算法,什么虚拟DOM,什么核心内容网上一大堆,请自行google. 但是能把算法说清楚,虚拟DOM说清楚的聊聊无几.对开发又没卵用,还不如来点干货看看咋用. 二.结构如下: impo ...
- React的使用与JSX的转换
前置技能:Chrome浏览器 一.拿糖:React的使用 React v0.14 RC 发布,主要更新项目: 两个包: React 和 React DOM DOM node refs 无状态的功能 ...
随机推荐
- 为什么一个类的全局变量默认以m开头?
某天闲着无聊,突然想起来为什么大家都习惯将全局变量使用m开头,于是追根求源,查了一些资料,虽然并不是我想要的,但是也总结一下. 在stackoverflow上就有人问: Why do most var ...
- 我的github代码库
我的github代码库地址:https://github.com/gooree.Enjoy coding,enjoy sharing.
- rabbitmq集群安装
在配置文件中配置集群没有成功,但是使用命令行成功了,以下是过程请参考. 场景:两台机器,一台是10.1.3.95 hostname为mq1,一台是10.1.3.96 hostname为 ...
- iOS 7 UI Transition – Porting View Controller Layouts from iOS 6
http://www.mobinett.com/2013/08/19/ios7-ui-transition-porting-view-controller-layouts-ios6/
- StrongSwan 5.1.1 发布,Linux 的 IPsec 项目
StrongSwan是一个完整的2.4和2.6的Linux内核下的IPsec和IKEv1 的实现.它也完全支持新的IKEv2协议的Linux 2.6内核.结合IKEv1和IKEv2模式与大多数其他基于 ...
- SQL入门经典(九) 之自定义函数
UDF和存储过程很类似,用户自定义函数是一组有序的T-SQL语句,这些语句被预先优化和编译,并且可以作为一个单元来测试调用.UDF和存储过程的主要区别在于结果返回方式,为了能支持更多返回值,UDF比存 ...
- sql server 写性能优化
潜在的方案是: (1)2014版本的内存表 (2)表分区,将表数据存放在多个硬盘上. (3)采用SSD磁盘阵列. (4)不重要的表关闭事务日志.??
- mvvm的优势
之前在项目中有个功能,是根据数据模型生成页面,然后页面变动之后,再同步到数据模型之中. 当时用的jquery写的,一点一点的控制,整个功能写下来.测试,花了很长时间,而且还担心出bug. 现在用mvv ...
- angular中的MVVM模式
在开始介绍angular原理之前,我们有必要先了解下mvvm模式在angular中运用.虽然在angular社区一直将angular统称为前端MVC框架,同时angular团队也称它为MVW(What ...
- [.net 面向对象编程基础] (12) 面向对象三大特性——继承
[.net 面向对象编程基础] (12) 面向对象三大特性——继承 上节我们说了面向对象的三大特性之一的封装,解决了将对同一对象所能操作的所有信息放在一起,实现统一对外调用,实现了同一对象的复用,降低 ...