zoukankan      html  css  js  c++  java
  • ES6数组中删除指定元素

    知识点:

    ES6从数组中删除指定元素

    findIndex()方法返回数组中满足提供的测试函数的第一个元素的索引。否则返回-1。
     arr.splice(arr.findIndex(item => item.id === data.id), 1)

     http://louiszhai.github.io/2017/04/28/array/

    1:js中的splice方法

    splice(index,len,[item]) 注释:该方法会改变原始数组。

    splice有3个参数,它也可以用来替换/删除/添加数组内某一个或者几个值

    index:数组开始下标 len: 替换/删除的长度 item:替换的值,删除操作的话 item为空

    如:arr = ['a','b','c','d']

    删除 ---- item不设置

    arr.splice(1,1) //['a','c','d'] 删除起始下标为1,长度为1的一个值,len设置的1,如果为0,则数组不变

    arr.splice(1,2) //['a','d'] 删除起始下标为1,长度为2的一个值,len设置的2

    替换 ---- item为替换的值

    arr.splice(1,1,'ttt') //['a','ttt','c','d'] 替换起始下标为1,长度为1的一个值为‘ttt’,len设置的1

    arr.splice(1,2,'ttt') //['a','ttt','d'] 替换起始下标为1,长度为2的两个值为‘ttt’,len设置的1

    添加 ---- len设置为0,item为添加的值

    arr.splice(1,0,'ttt') //['a','ttt','b','c','d'] 表示在下标为1处添加一项‘ttt’

    想要的:定义一个数组ARR,保存已勾选上的数据ID,改变勾选框的状态时从数组中删除或添加数据ID,点击批量删除时,获取数组ARR

    操作:

    1.页面设置

    // 全选
             <th nz-th nzCheckbox>
                <label nz-checkbox [(ngModel)]="_allChecked" [nzIndeterminate]="_indeterminate" (ngModelChange)="_checkAll($event)">
                </label>
              </th>
    
    
    //单选
    
    <td nz-td nzCheckbox>
         <label nz-checkbox [(ngModel)]="data.checked" (ngModelChange)="_refreshStatus($event)" (click)="onSelect(data)">
         </label>
     </td>

    2.全选操作触发事件

    // 初始化全选和全部取消的状态
    _allChecked = false; _indeterminate = false;
       _bacthDelete = [];//定义一个数组,存放勾选的数据ID

    // 点击全选触发的事件 _checkAll(value) {
    if (value) { this._displayData.forEach(data => { data.checked = true; this._bacthDelete.push(data.id); }, console.log(this._bacthDelete) ); } else { this._displayData.forEach(data => { data.checked = false; }, this._bacthDelete=[] ); console.log(this._bacthDelete) } this._refreshStatus(); }

     3.点击单个数据状态

      onSelect(data: FormData): void {
        this.selectedTestId = data;
        console.log(data);
        if(!data.checked){
          let arr = this._bacthDelete;
          arr.splice(arr.findIndex(item => item.id === data.id), 1)
          console.log(arr)
        }else{
          this._bacthDelete.push(data.id);
           console.log( this._bacthDelete)
        }
    
      }

  • 相关阅读:
    preg_replace函数/e后门
    php7.0-7.3的bypass disable_function一把梭
    PHP反序列化逃逸
    day2filter_var函数漏洞
    基于 Elasticsearch 聚合搜索实现电商筛选查询功能
    基于SpringBoot + Redis + 轮询实现扫码登录
    教你理解Lambda表达式
    记录解决 Elasticseach 过滤与聚合问题
    基于 MyBatis-Plus 解决数据库逻辑删除与唯一索引问题
    Java8 Stream Lamdba sorted()排序遇到的小坑
  • 原文地址:https://www.cnblogs.com/linsx/p/8331623.html
Copyright © 2011-2022 走看看