react遇到的各种坑
- 标签里用到
<label for>
的,for
要写成htmlFor
- 标签里的
class
要写成className
- 组件首字母一定要大写
- 单标签最后一定要闭合
- 如果html里要空格转义,
注意不要漏了分号; - style要写成
style={{clear: 'both',backgroundColor:'red',width:'200px'}}
- 组件里能用
<button>
的地方就不要用input type="button"
了,否则写个value
还要用{}
- 标签里的
ref
属性的属性名不要出现中横杠比如message-content
,如果有多个单词,直接写成驼峰形式 - 把要改变的数据写进父组件的
getInitialState
的属性里,然后通过this.props.listArr
传进去,表明初始状态是组件里listArr
里的属性。 - 如果将子组件改变的数据传递给父组件呢?可以在父组件里申明一个函数,里面传参
data
,然后在创建出子组件的对象的时候在属性上传入父组件的这个函数,然后在子组件里触发了某个事件的函数里,通过this.props.addItem()
这样的方式调用父组件的函数,这个addItem
就是父组件的函数,里面传参 - 如果组件之间的通信超过的一层,传参就非常麻烦,需要用到
react
的一个插件叫PubSub
订阅发布
(1) 先导入库
(2) 全局设置一个事件名称,子组件和父组件共用,比如var deleteItem = 'deleteItem';
(3) 子组件,触发事件之后,发布事件
//使用PubSub.publish(),第一个参数是公用的事件名称,第二个参数是你要传播的值
deleteItemHandler:function(){
PubSub.publish(deleteItem, this.props.item);
},
(4) 父组件,是等组件全部渲染之后,因为组件还在内存中,虚拟DOM还没有渲染出来,没有正式出现在页面上时,是获取不到真是DOM的,所以在componentDidMount
的函数里订阅一个从子组件发布出来的事件,在渲染完成后,会自动触发这个函数
//使用PubSub.subscribe(),第一个参数是公用的事件名称,第二个参数是一个回调函数,可以是用箭头函数方式使它内部this指向组件对象,evName是事件对象,data就是子组件发布过来,这里接受到的data
componentDidMount:function(){
PubSub.subscribe(deleteItem,(evName,data) =>{
var newArr = this.state.listArr.filter(function(item,index){
return item!= data;
});
this.setState({
listArr:newArr
});
});
},
- 这里顺便复习一下
Array
的filter()
方法,参数里是个函数,参数是项和下标,return
里写一个条件,所有符合条件的都会提取出来放到一个新的数组里,这里将数组里不等于传回来的这个data
里的值的每一项都放到了newArr
里,然后通过setState()
,更新state
里数组的值 利用
ReactCSSTransitionGroup
来添加一些简单的动画效果,比如列表内容增加或者删除时可以有渐进渐出的效果。但是这个标签默认是span
标签,使用在table
或者options
里提示警告,不能在table
和options
里嵌套span
,所以可以通过它本身的component
属性,比如component="div"
直接将这个标签渲染为我们需要的标签即可。另外css
里对应的动画时间要和这里标签里的时间对应var ListComponent = React.createClass({
render: function(){
return (
<ReactCSSTransitionGroup component="div" id="message-container" transitionName="messageContainer" transitionEnterTimeout={800} //这里定义渐进的时间
> { //这里放该组件的子级,也就意味写着这里面所有的内容的都会有动画效果,
this.props.mesArr.map(function(ele){
return <ItemComponent key={ele.time} {...ele} />
})
} </ReactCSSTransitionGroup>
)
}
});通过搜索框输入字符让显示区即时地筛选出搜索结果的效果。这里的难点是,如果直接通过
onChange
来获取打入的字符串来更新父组件的state
里的数据,会造成数据返回不到原来的状态。所以思路可以是这样的,在父组件state
里先创建一个空数组,每次当搜索框获取到焦点时,就把父组件当前的显示数据赋值给这个新建的数组,然后filter
的时候是通过这个新数组里的数据进行筛选,而不是原来的数据,另外,当搜索框内容为空或者失去焦点时,再把视图的数据恢复到得到焦点时的状态即可。下面是可以实现的父组件中的代码:
//在搜索框聚焦时,将当前state里的userList赋值给currentList,然后每次输入,筛选的对象都是currentList
focusHandler:function(){
this.state.currentList = this.state.userList;
},
//在失去焦点时立刻将刚才存储的currentList赋值给userList,让视图再恢复到点击搜索框之前
blurHandler:function(){
this.setState(function(){
return {
userList: this.state.currentList
}
});
},
//搜索功能
searchUser:function(text){
//这里要将text进行判断,如果为空,就要让视图呈现刚聚焦时的状态,否则就进行筛选
if(text!=''){
var newText = text.toLowerCase();
var newArr = this.state.currentList.filter(function(item){ //每次点击通过保存的currentList来过滤
return item.username.toLowerCase().indexOf(newText) != -1;
});
this.setState(function(){
return {
userList: newArr
}
});
}else{
this.setState(function(){
return {
userList: this.state.currentList
}
});
}
},
- React-Router和动画的结合使用
除了两种技术的结合之外,有个很重要的地方不要忘记,就是要让每个单独的组件设置样式为position:absolute,否则在动画切换时会出现短暂组件叠加的的情况,用户体验非常差,但是绝对定位后,每个组件都在同一个地方渐入渐出了。
//这里是react创建组件的ES6新写法,省略了function和内部的render,return。
const MenuComponent = ({ children, location }) => (
<div> //这里是将组件Menu下控制的路由写在这里,每个路径用Link标签包起来,通过属性to来控制对应不同的路径
<div className="col-md-3 list-group">
<Link to="/statistic" className="list-group-item active">Website Statistic
Data</Link>
<Link to="/topics" className="list-group-item">Hot Topics</Link>
<Link to="/visits" className="list-group-item">Today's Visits</Link>
<Link to="/status" className="list-group-item">Server Status</Link>
</div>
//这里把要对应的做成动画的区域用ReactCSSTransitionGroup包起来
<ReactCSSTransitionGroup className="col-md-9 pr clearfix"
component="div"
transitionName="content"
transitionEnterTimeout={500}
transitionLeaveTimeout={500}
>
{React.cloneElement(children, {key: location.pathname,className:"pa"})}
</ReactCSSTransitionGroup>
</div>
)
--------------------------------------------------------------
//这里是render方法里的写法
ReactDOM.render(
<Router> //根路由
// "/"代表根路由,IndexRoute表示索引页,如果没有索引页可以作为默认显示的内容
<Route path="/" component={MenuComponent}>
<IndexRoute component={StatisticComponent} />
<Route default path="statistic" component={StatisticComponent} />
<Route path="topics" component={TopicComponent} />
<Route path="visits" component={GuestComponent} />
<Route path="status" component={StateComponent} />
</Route>
</Router>
,document.getElementById('container')
);
- 用ES6的箭头函数写组件
const MenuComponent = ({ children, location }) => {
//定义组件里的函数直接在组件里申明即可
const changeLink = (ev) => {
var parent = ev.target.parentNode;
var children = parent.children;
for(var i=0; i<children.length; i++){
children[i].classList.remove('active');
}
ev.target.classList.add('active');
};
//这届写return (),里面写标签
return (
<div>
<div className="col-md-3 list-group" onClick={changeLink}> //这里不用再写this.changeLink了
<Link to="/statistic" className="list-group-item active">Website Statistic
Data
</Link>
<Link to="/topics" className="list-group-item">Hot Topics</Link>
<Link to="/visits" className="list-group-item">Today's Visits</Link>
<Link to="/status" className="list-group-item">Server Status</Link>
</div>
<ReactCSSTransitionGroup className="col-md-9 pr"
component="div" transitionName="content" transitionEnterTimeout={500} transitionLeaveTimeout={500}
>
{React.cloneElement(children, {key: location.pathname, className: "pa"})}
</ReactCSSTransitionGroup>
</div>
);
};
react遇到的各种坑的更多相关文章
- React设置宽度的坑
[React设置宽度的坑] 我们知道通过ref可以获取DOM元素,通过style属性可以给此DOM元素添加样式. 但下面两行的赋值是无效的: this.HomeRootDiv.style.width= ...
- React中innerHTML的坑
[React中innerHTML的坑] 通过React Ref机制返回的对象,是一个阉割的DOM对象,并非原始DOM对象.比如,这个阉割版的DOM对象没有innerHTML对象. <button ...
- 关于React Native的那些坑
好久没写博客了,特地把之前接触React Native时遇到的坑总结一下. 初始化一个React Native项目时,可能会遇到以下这些坑: 1.项目版本号与安卓模拟器中安装的 compileSdkV ...
- [Web 前端] React Router v4 入坑指南
cp from : https://www.jianshu.com/p/6a45e2dfc9d9 万恶的根源 距离React Router v4 正式发布也已经过去三个月了,这周把一个React的架子 ...
- 整理下react中常见的坑
其实有些也不能算是坑,有些是react的规定,或者是react的模式和平常的js处理的方式不同罢了 1.setState()是异步的this.setState()会调用render方法,但并不会立即改 ...
- React+Antd遇到的坑
第一次尝试React+antd,发现果然不愧是传说中的坑货,一个又一个坑.必须要记录. react + antd,都是最新版本,使用npm和yarn各种add,build,start 1. 资源文件, ...
- React Hooks使用避坑指南
函数组件比类组件更加方便实现业务逻辑代码的分离和组件的复用,函数组件也比类组件轻量,没有react hooks之前,函数组件是无法实现LocalState的,这导致有localstate状态的组件无法 ...
- 初识React Native,踩坑之旅....
开启Genymotion Android模拟器后 1.运行“react-native run-android”报端口冲突....解决方法: 2.运行“react-native run-android” ...
- react 之 reflux 填坑
注意:老铁些,在看这篇文章的之前,最好了解一下react 的全局状态管理库哦,不然可能会坐飞机. ^_^ React 之reflux (它是一个功能模块,需要安装引入): import Reflux ...
- react native遇到的坑
1.模拟器报错no bundle url present https://github.com/facebook/react-native/issues/12754 http://www.cnblog ...
随机推荐
- poj 1269 判断直线的位置关系
题目链接 题意 判断两条直线的位置关系,重合/平行/相交(求交点). 直线以其上两点的形式给出(点坐标为整点). 思路 写出直线的一般式方程(用\(gcd\)化为最简), 计算\(\begin{vma ...
- Remove Nth Node From End of List(链表,带测试代码)
Given a linked list, remove the nth node from the end of list and return its head. For example, Give ...
- spring mvc表单的展现、输入处理、校验的实现
之前已经实现了spring mvc的入门例子及如何处理带参数的请求Controller编写.本文主要记录: 1)重定向请求 2)处理路径中含有变量的请求 3)使用JSR-303进行校验 ① 首先,编写 ...
- 【APIO2016】Gap
题目描述 有 $N$ 个严格递增的非负整数 $a_1, a_2, \dots, a_N$($0 \leq a_1 < a_2 < \cdots < a_N \leq 10^{18}$ ...
- Oracle中PL/SQL 范例
1.写匿名块,输入三角形三个表的长度.在控制台打印三角形的面积 declare v_side_first ):=&第一条边; v_side_second ):=&第二条边; v_sid ...
- mysql function
mysql 自定义函数的使用 先查看函数功能是否开启:show variables like '%func%'; 若是未开启则:SET GLOBAL log_bin_trust_function_cr ...
- SG函数学习总结
有点散乱, 将就着看吧. 首先是博弈论的基础, 即 N 和 P 两种状态: N 为必胜状态, P 为必败状态. 对于N, P两种状态, 则有 1. 没有任何合法操作的状态, P; 2. 可以移动到P局 ...
- Linux内核源码分析--内核启动之zImage自解压过程
参考: http://blog.chinaunix.net/uid-20543672-id-3018233.html Linux内核编译流程分析 linux2.6内核启动分析--李枝果(不看是你的损失 ...
- 邁向IT專家成功之路的三十則鐵律 鐵律十五:IT人生活之道-赤子之心
人的年齡與身體可以因歲月的無情不斷老化,但我們的這一顆心可千萬不要跟著老化.身為IT工作者的我們,每天除了要面對那死板僵硬的電腦挑戰之外,可能還要面臨許多人事方面的紛擾.這時候如果在平日的生活之中,仍 ...
- asyncTask 的execute和executeOnExecutor 方法
asyncTask.execute Android.os.Build.VERSION_CODES.DONUT, this was changed to a pool of threads allowi ...