19.品牌列表案例之品牌名称检索功能filter
数组filter的应用
<!DOCTYPE html> <html lang="en"> <head> <meta charset="utf-8"> <meta name="viewport" content="width=device-width,initial-scale=1.0"> <meta http-equiv="X-UA-Compatible" content="ie=adge"> <title>Document</title> <script src="vue.js"></script> </head> <body> <div id="app"> id:<input type="text" v-model="id"> name:<input type="text" v-model="name"> <input type="button" value="添加" @click="add">     品牌检索: <input type="text" v-model="keywords" @change="searchName"> <table border="1"> <tr> <th>序号</th> <th>名称</th> <th>时间</th> <th>操作</th> </tr> <tr v-for="item in searchName()" :key="item.id"> <td>{{item.id}}</td> <td>{{item.name}}</td> <td>{{item.date}}</td> <td> <a href="#" @click.prevent="del(item.id)">删除</a> </td> </tr> </table> </div> </body> <script> //创建Vue实例,得到ViewModel var vm=new Vue({ el:"#app", data:{ id:'', name:'', keywords:'', pinpai:[ {id:1,name:"奔驰",date:new Date()}, {id:2,name:"宝马",date:new Date()}, {id:3,name:"奔奔",date:new Date()}, {id:4,name:"野马",date:new Date()} ] }, methods:{ add(){ this.pinpai.push({id:this.id,name:this.name,date:new Date()}) this.id=this.name="" }, del(id){ //console.log(id) //分析业务逻辑: //1.根据拿到的商品id,查找到对应的商品索引 //2.根据拿到的索引值,去数组中调用splice方法删除对应的那个元素 /*for(let i=0;i<this.pinpai.length;i++){ if(this.pinpai[i].id==id){ this.pinpai.splice(i,1) break; } }*/ //另一种判断id,及删除方法 const index=this.pinpai.findIndex(function(item,i,arr){ //if(item.id==id){ //return true //} return item.id==id }) this.pinpai.splice(index,1) console.log(index) }, searchName(){ //数组的filter方法,作用是循环指定的数组,并把满足回调函数中指定条件的项返回,从而得到一个新数组 /* return this.pinpai.filter((item)=>{ return item.name.includes(this.keywords) })*/ //也可以把上面三行代码变一行 return this.pinpai.filter(item => item.name.includes(this.keywords)) } } }); </script> </html>