React问题总结与归纳
欢迎大家指导与讨论 : )
【持续更新】本文主要记录笔者在学习中遇到的问题,并作出相应总结。有错误的地方希望各位能够指出。
一、在es6中getInitialState( 摘要: constructor(props)和this.state )
/*es6*/
class TodoList extends Component{
constructor(props){
super(props);
this.state = {
items: ['hello', 'world', 'click', 'me']
}
}
render(){
//..
}
}
/*es5*/
var TodoList = React.createClass({
getInitialState: function() {
return {items: ['hello', 'world', 'click', 'me']};
},
render(){
//...
}
})
二、在es6中setState( 摘要: fun.bind(this)和this.setState )
/*es6*/
class TodoList extends Component{
render(){
return (
<div>
<button onClick={ this.handleAdd.bind(this) } >Add item</button>
</div>
)
}
handleAdd(){
var newItem = prompt('enter a new')
var newItems = [ ...this.state.items, newItem ];
this.setState({items: newItems})
}
}
三、PureRenderMixn在深比较会失效(摘要: Immutable提升性能)
/ assume this.props.value is { foo: 'bar' }
// assume nextProps.value is { foo: 'bar' },
// but this reference is different to this.props.value
this.props.value !== nextProps.value; //true
//错误:浅比较/引用对象的比较/this.props和nextProp实际上是两个不同的对象引用
/*正确做法1-------对象比较应该进行深比较*/
shouldComponentUpdate: function(nextProps, nextState) {
return this.props.value.foo !== nextProps.value.foo;
}
/*正确做法2-------使用Immutable提升对象深比较的性能*/
export default class TabHeader extends Component {
shouldComponentUpdate(nextProps){
return !Immutable.is(Immutable.fromJS(nextProps), Immutable.fromJS(this.props));
}
//..........
}
四、Map结构的state由reducer传到组件时需要先提取this.props中的某个属性(摘要: this.props为多对象集合体)
export default class TabHeader extends Component {
shouldComponentUpdate(nextProps){
return !Immutable.is(Immutable.fromJS(nextProps), Immutable.fromJS(this.props));
}
render (){
const active = this.props.tabIndex
return (
//....
)
}
//....
}
五、reducer state中覆盖原object类型的state简洁写法(摘要: Object.assign())
Object.assign(...state, {
third: {
value: '',
show: true
}
})
//原state结构为
const initState = {
first: {
value: '',
show: true
},
second: {
value: '',
show: false
},
third: {
value: '',
show: false
}
}
六、获取动态render组件的真实DOM节点及其value值(摘要: fun.bind(this) / ReactDOM.findDom())
export default class CascadeBar extends Component{
render(){
return (
<div>
{this.renderFirst()}
</div>
)
}
renderFirst(){
//if...render...
return(
<select onChange={this.countryChange.bind(this)} ref="countryInput">
//.....
</select>
)
}
countryChange(){
ReactDOM.findDOMNode(this.refs.countryInput).value
}
}
七、父组件向子组件传递方法(摘要: React.cloneElement)
<div className="Detail">
{this.props.children && React.cloneElement(this.props.children, {
helloWorld: this.helloWorld
})}
</div>
八、不同浏览器对对象更新/对象深比较的兼容性问题(underscore的extend、omit)
// 无效手机UC不支持
return Object.assign(state, {left: {show: action.value}}
// 有效->克隆了一个新对象
var e = _.omit(state)
return _.extend(state , {left: {show: action.value}})
十一、在.js文件中使用async( 摘要: 配置webpack )
loaders: [
{
test: /\.js|jsx$/,
loader: 'babel',
query: {
presets: ['es2015', 'stage-3'],
plugins: ['transform-runtime']
},
exclude: /node_modules/
}
]
十、ant design的webpack配置
//package.json
{
"name": "processBar",
"version": "1.0.0",
"description": "",
"main": "index.js",
"scripts": {
"test": "echo \"Error: no test specified\" && exit 1"
},
"author": "",
"license": "ISC",
"dependencies": {
"antd": "^0.12.14",
"atool-build": "^0.6.6",
"babel-loader": "^6.2.4",
"babel-plugin-antd": "^0.3.2",
"babel-preset-es2015": "^6.6.0",
"babel-preset-react": "^6.5.0",
"css-loader": "^0.23.1",
"es3ify-loader": "^0.2.0",
"react": "^0.14.7",
"react-dom": "^0.14.7",
"style-loader": "^0.13.1",
"webpack": "^1.12.14"
}
} //webpack.config.js
var path = require('path')
var webpack = require('webpack') module.exports = {
entry: [
path.resolve(__dirname, 'index.js')
],
output: {
path: 'dist/',
filename: '[name].js'
},
resolve: {
extensions: ['', '.js', '.jsx']
},
module: {
loaders: [
{
test: /\.js|jsx/,
loader: 'es3ify-loader'
},
{
test: /\.js|jsx$/,
loader: 'babel',
query: {
presets: ['es2015', 'react'],
cacheDirectory: true,
plugins: [
'babel-plugin-antd'
]
}
},
{
test: /\.css$/,
loader: 'style-loader!css-loader'
}
]
}
}
React问题总结与归纳的更多相关文章
- [RN] React Native 常见基本问题归纳总结
[RN] React Native 常见基本问题归纳总结 本问题总结涉及到版本为: "react": "16.8.3","react-native& ...
- React Native汇错归纳(持续更新中……)
1.2017-10-25: 报错信息:“Cannot find entry file index.android.js in any of roots…..” 解决方法: 1.首先从虚拟机中找问题:看 ...
- React核心内容归纳总结
状态.属性.组件API.组件的生命周期 当react的状态改变时,自动执行this.render()方法更新组件ES6写React的时候,事件里不会自动绑定this,需要自己绑定,或者直接在const ...
- react 开发过程中的总结/归纳
1.点击元素,获取绑定该事件的父级元素,使用 e.currentTarget.e.target 获取的是,出发该事件的元素,该元素有可能是所绑定事件的元素的子元素. 2.使用 react router ...
- Webpack+React+ES6开发模式入门指南
React无疑是今年最火的前端框架,github上的star直逼30,000,基于React的React Native的star也直逼20,000.有了React,组件化似乎不再步履蹒跚,有了Reac ...
- [React] 多组件生命周期转换关系
前段时间一直在基于React做开发,最近得空做一些总结,防止以后踩坑. 言归正传,React生命周期是React组件运行的基础,本文主要是归纳多组件平行.嵌套时,生命周期转换关系. 生命周期 Reac ...
- 【腾讯Bugly干货分享】React移动web极致优化
本文来自于腾讯bugly开发者社区,非经作者同意,请勿转载,原文地址:http://dev.qq.com/topic/579083d1c9da73584b02587d 最近一个季度,我们都在为手Q家校 ...
- Webpack+React+ES6入门指南[转]
React无疑是今年最火的前端框架,github上的star直逼30,000,基于React的React Native的star也直逼20,000.有了React,组件化似乎不再步履蹒跚,有了Reac ...
- 正式学习React( 三)
最基本的jsx语法什么的,我就不介绍了,唯一觉得有用点的,就是声明周期了. 下面的内容是转来的,自己也可以网上去搜,我觉得别人归纳的挺不错的,不过写法可能不是es6的,不影响学习. 在组件的整个生命周 ...
随机推荐
- TextView 字数限制
给大家推荐一个 无bug的 字数限制 http://blog.csdn.net/u012460084/article/details/50377928
- Android 自定义控件(一)
本文用一个简单的例子来说明一下自定义控件的步骤实现,自定义控件有几种实现类型,分别为继承自view完全自定义,继承现有的 控件实现特定效果,继承viewgroup实现布局类等: 本文研究的是继承自vi ...
- XML解析方案
在iOS中,解析XML的手段有很多 苹果原生 NSXMLParser:SAX方式解析,使用简单 第三方框架 libxml2:纯C语言,默认包含在iOS SDK中,同时支持DOM和SAX方式解析 GDa ...
- AndroidStudio添加依赖库
以Gson为例 Step1:点击下图中的入口,进入ProjectStructure Step2: 在app项中选择Dependencies窗口,点击右侧的加号 Step3:在搜索框中输入gson,点击 ...
- vi, vim 基本使用(2)
进入vi的命令vi filename :打开或新建文件,并将光标置于第一行首vi +n filename :打开文件,并将光标置于第n行首vi + filename :打开文件,并将光标置于最后一行首 ...
- Solr页面查询各个字段参数解释
q:查询的关键字,此参数最为重要,例如,q=id:1,默认为q=*:*,类似于sql中的where 1=1. fq(filter query):过滤查询,提供一个可选的筛选器查询.返回在q查询符合结果 ...
- Nginx问题定位之监控进程异常退出
nginx在运行过程中是否稳定,是否有异常退出过?这里总结几项平时会用到的小技巧. 1. 在error.log中查看是否有signal项,如果有,看看signal是多少. 比如,这是一个异常退出的情况 ...
- SQL Server中字符串转化为GUID的标量函数实现
还是工作中遇到的需求,有时候和外部的系统对接,进行数据的核对功能,外部的系统有时候主键字段列数据类是UNIQUEIDENTIFER(GUID)类型的字符串格式,去除了GUID格式中的分隔符“- ...
- android开发环境搭建日记和嵌入式Android开发环境初探
非常感谢博客园的各位,按照你们的博文,还有利用百度和谷歌逐渐建立了android的开发环境,只是给自己备份参考查看,看过的人可以忽略这篇文章. 本文章大部分参考了:http://www.cnblogs ...
- linux线程同步(1)-互斥量
一.概述 互斥量是线程同步的一种机制,用来保护多线程的共享资源.同一时刻,只允许一个线程对临界区进行 ...