使用React的技巧

0.避免无意义的父节点
import React from 'react';

const SecondsTop = ({title}) => [
    <div className="top">
        <i className="logo1"/>
    </div>,
    <div className="top">
        这是{title}
    </div>
];
export default SecondsTop;
1.优雅的渲染一个list

经常遇到的开发需求,从后台来到一个list数据,在前端展示出来
先手动造一个list数据

import React from 'react';

class Index extends React.Component{
  constructor(props){
      super(props);
        this.state = {
          list: [
            {id:1, title:'测试1'},
            {id:2, title:'测试2'},
            {id:3, title:'测试3'},
            {id:4, title:'测试4'},
            {id:5, title:'测试5'},
            {id:6, title:'测试6'},
          ]
        };
    }
  handleItemDel(id){
    //console.log(id)
    let list =  this.state.list;
      list.splice(list.findIndex(data => data.id === id ), 1);
      this.setState({list: list})
  }
  render(){
    let {list} = this.state;
    return(
        <div>
          {
             list.map(data => <li key={data.id}>{data.title} 
             <button onClick={()=>this.handleItemDel(data.id)}>删除</button></li>)   
          }
        </div>
    )
  }
}
2.如何处理List里面的Item(增删改查)

[见上面代码]
(1)删除:先增加一个删除按钮
(2)给按钮添加事件,绑定函数,并把id传参过去,点击删除按钮,看能否打印出当前id
(3)接下来写删除事件:(handleItemDel函数)
补充知识:

splice() 方法可删除从 index 处开始的零个或多个元素,并且用参数列表中声明的一个或多个值来替换那些被删除的元素。
语法:
arrayObject.splice(index,howmany,item1,.....,itemX)
【index:必需。整数,规定添加/删除项目的位置,使用负数可从数组结尾处规定位置。
howmany:必需。要删除的项目数量。如果设置为0,则不会删除项目。
itme1,...,itemX:可选。向数组添加的新项目。】
代码:http://www.w3school.com.cn/tiy/t.asp?f=jseg_splice
findIndex() 方法返回传入一个测试条件(函数)符合条件的数组第一个元素位置。
findIndex() 方法为数组中的每个元素都调用一次函数执行:
·当数组中的元素在测试条件时返回true时,findIndex() 返回符合条件的元素的索引位置,之后的值不会再调用执行函数。
·如果没有符合条件的元素返回-1
注意:findIndex() 对于空数组,函数是不会执行的。findIndex() 并没有改变数组的原始值。
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • ¥开启¥ 【iAPP实现进入界面执行逐一显】 〖2017-08-25 15:22:14〗 《//首先开一个线程,因...
    小菜c阅读 11,712评论 0 17
  • 冬天的情话 哪怕再暖 冷风一吹 也缩成一团 雨雪或冰霜 我从不相信 发生在此刻的誓言 落在冰冷的心上 怎能生根和发芽?
    晚风不晚阅读 838评论 0 1
  • 第四章母亲的叨叨絮絮 没站一会儿,嗡嗡嗡声音在耳边作响,穿了校服那几个倒是淡定得很,不过没被遮掩的时候照样逃不过蚊...
    東夜十二阅读 1,248评论 0 0
  • 《目标感》这本书看着很无感。因为我自己对目标就没什么感觉。 书中花了很大篇幅给我们介绍各种各样的方法,训练目标感。...
    邓男神Sweety阅读 1,352评论 0 0
  • 记得高中的时候,在县里的出租屋里热的睡不着,我都忍了,觉得那是该吃的苦,可是很努力。去年暑假的时候,由于学车也是热...
    Kristin_acd8阅读 1,196评论 0 0