React|React antd 学习随笔
Table
控制是否展开,expandedRowKeys数组存放对应展开行的数据key
expandedRowKeys = {this.state.expandedRowKeys}
控制是否单独单元格放置展开图标
expandIconAsCell = {false}
number设置展开图标所在的单元格索引,取一个不存在的索引可达到去掉预设图标的效果
expandIconColumnIndex = {-1}
展开行内为Form表单,双向绑定导致input焦点丢失
【React|React antd 学习随笔】具体原因尚未清楚,表现疑似展开行内input双向绑定触发了父组件Table的重新渲染,进而触发展开行内重新渲染,导致焦点丢失,无法持续输入。
应急方案:父组件使用生命周期控制渲染
shouldComponentUpdate(nextProps, nextState) {
if (JSON.stringify(nextState) == JSON.stringify(this.state)){
return false;
}
return true;
}
缺点:部分props和state的复杂数据类型的变化无法被shouldComponentUpdate捕获,无法正确触发视图变化,因而必须保证清晰掌握父组件以及子组件所有更新可能。比如父组件中存在下面的上传组件,三元运算符结果显示失效
{
this.state.fileList[record.key] !== undefined ?
:
}
在该上传组件中,通过beforeUpload函数更新state的fileList(Object)并没有触发视图变化。通过在shouldComponentUpdate中输出控制台发现,nextState和this.state的fileList一致为更新后的值,原因未知。为了解决这个问题,我在state中引入了一个Boolean值,用于通过beforeUpload改变它来触发shouldComponentUpdate。
inputNumber 输入非数字时,在失去焦点后onChange获得的value会变成undefined,而不是空字符串或者0
Modal 个人常用例子
确定
,
]}
>{this.state.modalContent}
多个modal 显示时可能存在覆盖顺序错误 通过设置modal的zIndex值,将需要的modal层次提高
Form 个人常用例子
checkError = (id) => {
// Only show error after a field is touched.
return this.props.form.isFieldTouched(id) && this.props.form.getFieldError(id)
}...
{getFieldDecorator('title', {
rules: [{ required: true, message: '标题不能为空!', whitespace: true }],
})(
)}
推荐阅读
- 由浅入深理解AOP
- 继续努力,自主学习家庭Day135(20181015)
- python学习之|python学习之 实现QQ自动发送消息
- 基于|基于 antd 风格的 element-table + pagination 的二次封装
- 一起来学习C语言的字符串转换函数
- 定制一套英文学习方案
- 漫画初学者如何学习漫画背景的透视画法(这篇教程请收藏好了!)
- 《深度倾听》第5天──「RIA学习力」便签输出第16期
- 如何更好的去学习
- 【韩语学习】(韩语随堂笔记整理)