Vue入坑记(二)

视频地址 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是自定义形参

待续....

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

推荐阅读更多精彩内容