美文网首页vue学习
Vue入坑记(二)

Vue入坑记(二)

作者: GaleaWong | 来源:发表于2018-11-13 01:01 被阅读0次

    视频地址 https://www.bilibili.com/video/av29192186/

    友情GitHub项目地址 https://github.com/zc910704/Vue.js-personal-note

    授课老师的码云 https://gitee.com/vsdeveloper/projects

    正在进行day2的课程

    品牌列表的案例

    image

    今天所学的页面大致如上图所示

    功能介绍如下:

    1.搭建页面——使用Bootstrap css框架构建列表页面

    2.添加数据——创建一个获取id和name的数组,通过push()把数据添加至列表内(因为Vue是数据双向绑定,所以立即可看到添加改变)

    3.删除数据——获取到数据的下标,使用splice(index,i)来删除该行

    4.查询数据——使用** v-for **方法渲染list列表,使用 **v-for="item in search(keyWords)" **进行方法渲染列表

    css框架 Bootstrap的介绍和使用在这就不多说了(我也不会!)

    一、添加数据

    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()来获取符合条件数据的索引

    三、搜索数据

    <!-- 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 可选。当前元素所属的数组对象。

    此处forEach()与some()实现效果一样,具体区别 https://blog.csdn.net/qq_33769914/article/details/70213722

    四、Vue过滤器

    (一)定义

    1、全局过滤器

    直接在 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}`
                }
    
            })
    

    2、局部过滤器

    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}`
            }
    
        }
    }
    

    (二)使用
    在数据绑定之后使用管道符号 | 后接过滤器的名称,此处是 deteFormat()

    <td>{{ item.cTime | deteFormat() }}</td>
    

    【函数】形参内不可以是undefined

    deteFormat:function(dateStr, pattern=""){}

    dateStr是管道符号前的数据 pattern是自定义形参

    待续....

    相关文章

      网友评论

        本文标题:Vue入坑记(二)

        本文链接:https://www.haomeiwen.com/subject/cfahfqtx.html