web前端day2——crud&过滤器&生命周期函数

vue 的crud

增加

add(){ //添加的方法
// 分析
// 1.获取到id和name,直接从 data 上获取
// 2,组织一个对象
// 3.把这个对象,调用 数组的 相关方法,添加到 当前 data的list里面
// 4.在Vue中已经实现了数据的双向绑定了,改动都会自动更新

    var car = { id: this.id, name: this.name, cTime: new Date() }
    this.list.push(car)
    this.id = this.name = ''
}

删除

del(id){ //根据Id删除数据
    //分析
    // 1.如何根据Id,找到要删除这条的索引
    // 2.有索引,直接调用 数组的 solice 方法
    // 3.item 是回调函数

    // this.list.some((item, i)=>{
    //  if(item.id == id){
    //      this.list.splice(i, 1)
    //      // 在数组的 some方法中,如果return true,就会立即终止后续循环
    //      return true;
    //  }
    // })

    var index = this.list.findIndex(item => {
        if(item.id == id) {
            return true;
        }
    })

    this.list.splice(index, 1)

}

这里删除提供了两种方法

①some()
some()方法用于检测数组中的元素是否满足指定条件(item方法内的id是否匹配)。
some() 方法会依次执行数组的每个元素:
如果有一个元素满足条件,则表达式返回true , 剩余的元素不会再执行检测。
如果没有满足条件的元素,则返回false。

function(currentValue, index,arr)

参数 描述
currentValue 必须。当前元素的值
index 可选。当前元素的索引值
arr 可选。当前元素属于的数组对象

此处item是当前元素的值,i为元素的索引值

②findIndex()
findIndex() 方法返回传入一个测试条件(函数)符合条件的数组第一个元素位置。
findIndex() 方法为数组中的每个元素都调用一次函数执行:

当数组中的元素在测试条件时返回 true 时, findIndex() 返回符合条件的元素的索引位置,之后的值不会再调用执行函数。
如果没有符合条件的元素返回 -1
注意: findIndex() 对于空数组,函数是不会执行的。

注意: findIndex() 并没有改变数组的原始值。

function(currentValue, index,arr)

参数 描述
currentValue 必需。当前元素
index 可选。当前元素的索引
arr 可选。当前元素所属的数组对象

此处使用findIndex()来获取符合条件数据的索引

作者:GaleaWong
链接:https://www.jianshu.com/p/9c5dcbe0cf9f
来源:简书

查找

<!-- v-for的数据都是根据数组渲染,现在自定义search方法,同时把查询的关键字通过传参,传递给方法 -->
<!-- 在search方法内部,通过 执行 for循环,把所有符合 关键字 ,保存在新数组中,返回 -->
<tr v-for="item in search(keyWords)" :key="item.id">
    <td>{{item.id}}</td>
    <td v-text="item.name"></td>
    <td>{{ item.cTime }}</td>
    <td>
        <a href="" @click.prevent="del(item.id)">删除</a>
    </td>
</tr>
search(keyWords){ //根据关键字,进行数据的搜索
    var newList = [] //创建空数组
    this.list.forEach(item =>{ //循环遍历list
        if(item.name.indexOf(keyWords) != -1 ){ //判断数组是否含有搜索框值
            newList.push(item) //有,将item对象添加至newList数组内
        }
    })
    return newList //返回 newList数组
}

①forEach()
forEach() 方法用于调用数组的每个元素,并将元素传递给回调函数。
注意: forEach() 对于空数组是不会执行回调函数的。

function(currentValue, index, arr)

参数 描述
currentValue 必需。当前元素
index 可选。当前元素的索引值。
arr 可选。当前元素所属的数组对象。

② filter

search: function(keyword) {
/es6的语法为字符串提供了一个新方法叫做string.protetype.includes(‘要包含的字符串’)
如果包含返回true,不包含返回false
/
return this.list.filter(function(item){
if(item.name.includes(keyword)){
return item
}
})
},
}

  • map():返回一个新的Array,每个元素为调用func的结果。新数组的长度和原来的是一样的,他只不过是逐一对原来数据里的每个元素进行操作。

  • filter():返回一个符合func条件的元素数组。筛选条件,把数组符合条件的放在新的数组里面返回。新数组和原来的数组长度不一定一样。

  • some():返回一个boolean,判断是否有元素是否符合func条件。数组里面所有的元素有一个符合条件就返回true。

  • every():返回一个boolean,判断每个元素是否符合func条件。数组里面所有的元素都符合才返回true。

  • forEach():没有返回值,只是针对每个元素调用func 。循环数组。和for的用法一样的。

全局过滤器

直接在 new Vue 的外部定义全局过滤器

// 全局的过滤器,进行时间的格式化 pattern形参不能等于undenfind
        Vue.filter('deteFormat', function(dateStr, pattern=""){
            // 根据给定的时间字符串,得到特定的时间
            var dt = new Date(dateStr)

            // yyyy-mm-dd
            var y = dt.getFullYear()
            var m = dt.getMonth() + 1
            var d = dt.getDate()

            // return y + '-' + m + '-' + d


            if(pattern.toLowerCase() === 'yyyy-mm-dd' ){
                return `${y}-${m}-${d}`
            }else{
                var hh = dt.getHours()
                var mm = dt.getMinutes()
                var ss = dt.getSeconds()

                return `${y}-${m}-${d} ${hh}:${mm}:${ss}`
            }

        })

局部过滤器

在 new Vue 的内部定义局部过滤器,只会在 el对象元素内执行,且优先执行局部过滤器再执行全局过滤器,注意全局过滤器定义是 filter,而局部过滤器是filters可以理解为全局只有一个,局部可以多个

filters:{
    // 过滤器调用的时候,采用的是就近原则
    deteFormat:function(dateStr, pattern=""){
        // 根据给定的时间字符串,得到特定的时间
        var dt = new Date(dateStr)

        // yyyy-mm-dd
        var y = dt.getFullYear()
        var m = (dt.getMonth() + 1).toString().padStart(2, '0')
        var d = dt.getDate().toString().padStart(2, '0')

        // return y + '-' + m + '-' + d


        if(pattern.toLowerCase() === 'yyyy-mm-dd' ){
            return `${y}-${m}-${d}`
        }else{
            var hh = dt.getHours().toString().padStart(2, '0')
            var mm = dt.getMinutes().toString().padStart(2, '0')
            var ss = dt.getSeconds().toString().padStart(2, '0')

            return `${y}-${m}-${d} ${hh}:${mm}:${ss}`
        }

    }
}

生命周期函数

在这里插入图片描述

创建时

beforeCreate
data和methods还没有初始化。
created
初始化数据和方法
beforemount
执行V指令生成模板字符串在内存中,渲染内存中的dom,(只是在内存中渲染好了模板)页面中的数据尚未与vue中同步只显示模板字符串
mounted
挂在内存中的模板,创建完成

运行时

beforeUpdate
数据已被更新,但此时页面上的数据还是旧的
Update
页面与data已同步

销毁

beforeDestory
所有data和methods,仍可用
destoryed
全部销毁

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值