使用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() 并没有改变数组的原始值。
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 217,734评论 6 505
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,931评论 3 394
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 164,133评论 0 354
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,532评论 1 293
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,585评论 6 392
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,462评论 1 302
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,262评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,153评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,587评论 1 314
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,792评论 3 336
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,919评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,635评论 5 345
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,237评论 3 329
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,855评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,983评论 1 269
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,048评论 3 370
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,864评论 2 354

推荐阅读更多精彩内容

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