网站首页 > 博客文章 正文
window.onload = function(){ new Vue({ el:'#my', data:{ lists:[ {name:'张学友1',qq:'23456324',id:1,state:false}, {name:'张学友2',qq:'25155345',id:2,state:false}, {name:'张学友3',qq:'5435525',id:3,state:false}, {name:'张学友4',qq:'5253266',id:4,state:false}, {name:'张学友5',qq:'52436546',id:5,state:false}, {name:'张学友6',qq:'5436745745',id:6,state:false}, {name:'张学友7',qq:'246154',id:7,state:false}, {name:'张学友8',qq:'146464',id:8,state:false}, {name:'张学友9',qq:'4536754',id:9,state:false}, {name:'张学友10',qq:'875464',id:10,state:false}, {name:'张学友11',qq:'353543',id:11,state:false} ], selectorList:[], flag:'show' }, methods:{ addList:function(list){ list.state = true; //当前单击的状态 //ID重复 三种方法 for(var i=0;i<this.selectorList.length;i++){ if(list.id == this.selectorList[i].id) return; }; //filter // var idRepeat = this.selectorList.filter(function(v){ // return v.id == list.id // }); // if(idRepeat.length >0) return; //ES6 this.selectorList.push(list); // this.selectorList = [...new Set(this.selectorList)]; }, delList:function(list,index){ this.selectorList.splice(index,1); //index 位置 1个数 this.lists.forEach((v,i)=>{ if(v.id == list.id) { v.state = false; } }) } } }) }
html:
<div id='my'> <div class="container"> <div class="row"> <!--左侧--> <div class="col-xs-6 col-sm-6" > <div class="panel panel-success"> <!--标题--> <div class="panel-heading"> <h3 class="panel-title">总好友 ({{lists.length}})</h3> </div> <!--内容--> <div class="panel-body panel-height"> <ul> <li v-for="(list,index) in lists" @click="addList(list)" :class="list.state ? 'selected':''" > <span class="glyphicon glyphicon-fire photo"></span> {{list.name}}({{list.qq}}) </li> </ul> </div> </div> </div> <!--右侧--> <div class="col-xs-6 col-sm-6" > <div class="panel panel-success"> <!--标题--> <div class="panel-heading"> <h3 class="panel-title">已选择 ({{selectorList.length}})</h3> </div> <!--内容--> <div class="panel-body panel-height"> <ul > <li v-for="(list,index) in selectorList" @mouseover="flag=index" @mouseout="flag='hide'"> <span class="glyphicon glyphicon-fire photo"></span> {{list.name}}({{list.qq}}) <span class="glyphicon glyphicon-trash del" @click="delList(list,index)" v-if="flag==index"></span> </li> </ul> </div> </div> </div> </div> </div> </div>
猜你喜欢
- 2024-09-23 vue的数据驱动原理及简单实现(vue driver)
- 2024-09-23 分享:vue使用技巧和项目中遇到的问题
- 2024-09-23 「1分钟知识——前端01」vue双向绑定
- 2024-09-23 如何使用Vue中的嵌套插槽(包括作用域插槽)
- 2024-09-23 5.6 vue更新数组时触发视图更新的方法,熟记JavaScript原生方法
- 2024-09-23 学习Vue笔记012(3)- 列表渲染的注意
- 2024-09-23 vue更新数组时触发视图更新方法(vue中数组发生变化但视图没有更新)
- 2024-09-23 深入浅出 Vue Mixin(深入浅出全文免费阅读笔趣阁番外)
- 2024-09-23 Vue3 样式绑定: 内联样式与Class属性的数组语法
- 2024-09-23 vue 基础- mixins 多继承方式的代码复用
你 发表评论:
欢迎- 最近发表
-
- 给3D Slicer添加Python第三方插件库
- Python自动化——pytest常用插件详解
- Pycharm下安装MicroPython Tools插件(ESP32开发板)
- IntelliJ IDEA 2025.1.3 发布(idea 2020)
- IDEA+Continue插件+DeepSeek:开发者效率飙升的「三体组合」!
- Cursor:提升Python开发效率的必备IDE及插件安装指南
- 日本旅行时想借厕所、买香烟怎么办?便利商店里能解决大问题!
- 11天!日本史上最长黄金周来了!旅游万金句总结!
- 北川景子&DAIGO缘定1.11 召开记者会宣布结婚
- PIKO‘PPAP’ 洗脑歌登上美国告示牌
- 标签列表
-
- ifneq (61)
- messagesource (56)
- aspose.pdf破解版 (56)
- promise.race (63)
- 2019cad序列号和密钥激活码 (62)
- window.performance (66)
- qt删除文件夹 (72)
- mysqlcaching_sha2_password (64)
- ubuntu升级gcc (58)
- nacos启动失败 (64)
- ssh-add (70)
- jwt漏洞 (58)
- macos14下载 (58)
- yarnnode (62)
- abstractqueuedsynchronizer (64)
- source~/.bashrc没有那个文件或目录 (65)
- springboot整合activiti工作流 (70)
- jmeter插件下载 (61)
- 抓包分析 (60)
- idea创建mavenweb项目 (65)
- vue回到顶部 (57)
- qcombobox样式表 (68)
- vue数组concat (56)
- tomcatundertow (58)
- pastemac (61)
本文暂时没有评论,来添加一个吧(●'◡'●)