vue通过v-for渲染的列表,可以单独操作的其中的列表的两种方法

如图,三个标题分别有多个子元素。通过点击三个标题分别控制显示和隐藏。上代码
第一种情况:点击 青1,其所有的标题下的列表全部隐藏,也就是只有一个标题的会显示子元素
<div class="items" v-for="(item,index) in list"> <div class="item_top" @click="clickTitle(index)"> //通过当前列表的index和data里面自定义的aIndex属性进行判断,如果相同,就显示当前子元素<span class="title">
{{item.title}}
</span><div class="item_right"><span class="num">{{item.items.length}}个</span><img src="data:images/top.png" alt="" v-show="aIndex == index"><img src="data:images/bottom.png" alt="" v-show="!aIndex == index"></div></div><!-- 子列表 --><div class="item" v-for="(proItem,proIndex) in item.items" v-show="aIndex == index">
{{proItem}}
</div></div>
clickTitle:function(index){
if(aIndex == index){
aIndex = -1;
}else{
aIndex = index;
} }
//如果当前元素已经被点击并显示子列表,那么aindex肯定就等于index,
所以让aindex赋值为负值,所以此时,aindex和所有的标题的index都不相等,所以当前的被点击的会被隐藏。否则,当前被点击的被index赋值,并显示子元素
data: {
aIndex:'', //定义一个中间变量
list:[{
title:'青1',
items:[
'青岛市市立医院1','青岛市市立医院2','青岛市市立医院3'
],
show: false, //在循环里面加一个状态判断条件,在方法里面通过show状态判断是显示还是隐藏
},
{
title:'青2',
items:[
'青岛市市立医院1','青岛市市立医院2'
],
show: false,
},
{
title:'青3',
items:[
'青岛市市立医院1','青岛市市立医院2','青岛市市立医院3'
],
show: false,
},]
},
第二种情况:点击青1,显示青1下的子元素。点击青2或者其他,青1子元素依旧存在,不会有状态的改变。
//通过点击传过来的当前item下的show属性,动态的切换显示和隐藏,不影响其他的列表
<div class="items" v-for="(item,index) in list">
<div class="item_top" @click="clickTitle(item)">
<span class="title">
{{item.title}}
</span>
<div class="item_right">
<span class="num">{{item.items.length}}个</span>
<img src="data:images/top.png" alt="" v-show="item.show">
<img src="data:images/bottom.png" alt="" v-show="!item.show">
</div>
</div>
<!-- 子列表 -->
<div class="item" v-for="(proItem,proIndex) in item.items" v-show="item.show">
{{proItem}}
</div>
</div>
data: {
list:[{
title:'青1',
items:[
'青岛市市立医院1','青岛市市立医院2','青岛市市立医院3'
],
show: false, //在循环里面加一个状态判断条件,在方法里面通过show状态判断是显示还是隐藏
},
{
title:'青2',
items:[
'青岛市市立医院1','青岛市市立医院2'
],
show: false,
},
{
title:'青3',
items:[
'青岛市市立医院1','青岛市市立医院2','青岛市市立医院3'
],
show: false,
},]
},
clickTitle:function(item){
//通过点击传过来的当前item下的show属性,动态的切换显示和隐藏,不影响其他的列表
item.show = !item.show;
}
vue通过v-for渲染的列表,可以单独操作的其中的列表的两种方法的更多相关文章
- vue里使用element饿了么的el-menu+vue-router实现路由跳转的两种方法
最近准备写一个echarts的可视化展示案例,首先用vue-cli3创建了一个项目(好像vue-cli4也出来,感觉变化不大,就没升级了) 然后,开始配置路由↓下面是我的router.js文件 imp ...
- 两种方法使vue实现jQuery调用
引言 如果说vue是前端工程化使用较多的骨架,那么JavaScript就是我们的前端的细胞.MVVM模式让我们体验到前端开发的便携,无需再过多的考虑DOM的操作.而vue的渐进式开发(逐步引用组件,按 ...
- 织梦首页、列表页调用文章body内容的两种方法
http://blog.csdn.net/langyu1021/article/details/52261411 关于首页.列表页调用文章body内容的两种方法,具体方法如下: 第一种方法: {ded ...
- DEDECMS5.5/5.6/5.7列表页调用TAG标签(热门标签)的两种方法
DEDECMS5.5/5.6/5.7列表页调用TAG标签的两种方法: 一.DedeCMSv5.6及其以前版本: dedecms默认在列表是无法调用tag标签的,经过各位版主们的帮助,现给大家提供出2种 ...
- 解决vue项目eslint校验 Do not use 'new' for side effects 的两种方法
import Vue from 'vue' import App from './App.vue' import router from './router' new Vue({ el: '#app' ...
- Vue 创建组件的两种方法
地址:https://blog.csdn.net/cofecode/article/details/74634301 创建组件的两种方法 1.全局注册 2.局部注册 var child=Vue.ext ...
- JMeter接口测试-提取动态列表最后一个值的两种方法
前言 在用JMeter做接口测试时,我们经常会遇到,一个接口返回一个json串,在这个json串中,某个节点的值是一个列表,而且这个列表的长度是动态变化的.今天我们来学习两种提取动态列表最后一个值的两 ...
- AE工程渲染的时间缓慢,两种方法减少对AE工程渲染的时间!
AE工程渲染的时间缓慢,两种方法减少对AE工程渲染的时间!3秒的片头,渲染时间竟然要花1个多小时,很多新手都产生过这样的疑问?是哪里不对吗?如何才能减少渲染视频的时间?且听我一一道来.主要原因是:工程 ...
- PyQt(Python+Qt)学习随笔:model/view架构中支持QListView列表中展示图标的两种方法
老猿Python博文目录 专栏:使用PyQt开发图形界面Python应用 老猿Python博客地址 在QListView列表视图中的项不但可以展示文字,也可以展示图标和复选框,同时可以指定项是否可以拖 ...
- vue中使用echarts的两种方法
在vue中使用echarts有两种方法一.第一种方法1.通过npm获取echarts npm install echarts --save 2.在vue项目中引入echarts 在 main.js 中 ...
随机推荐
- Python 相对路径和绝对路径--python实战(九)
一 背景信息 最近在运行python程序的过程中,无意遇到了这个一个问题,在同事那边一直执行ok的程序,到我这里怎么都有个错误,当初报的错误是这样的: FileNotFoundError: [Errn ...
- 搭建Tomcat服务器访问本地资源
目标,搭建Tomcat服务器,使同网络段下其他电脑可以访问分享的文件 下载安装Tomcat 如下图,在官网http://Tomcat.apache.org/下载对应版本的Tomcat,解压安装即可 启 ...
- 实例属性和方法的动态处理(__getattr__)
正常情况下,当调用类的方法或属性时,如果不存在,就会报错 要避免这个错误,除了可以加上那个要调用但不存在的属性外,Python还有另一个机制,那就是写一个__getattr__()方法,动态返回一个属 ...
- pytorch_13-图像处理之skimage
之前程序使用的是PIL(Python image library),今天遇到了另一种图像处理包--skimage. skimage即scikit-image,PIL和Pillow只提供最基础的数字图像 ...
- json递归查询
主体: class json_search(): '''递归查询依赖key''' def search_key(self,data,key): self.data = data self.key_va ...
- 利用代码生成工具生成基于ABP框架的代码
在前面随笔,我介绍了整个ABP优化过框架的分层模型,包括尽量简化整个ABP框架的各个层的关系,以及纳入一些基类的辅助处理,使得我们对应业务分层类或者接口尽可能减少代码,并具有生产环境所需要的基类接口, ...
- vs未能正确加载CSharpPackage包,未能正确加载“Microsoft.VisualStudio.Editor.Implementation.EditorPackage”包
VS2017打开项目时提示未能正确加载CSharpPackage包, 可以使用 devenv命令工具来解决,操作如下 打开vs2017开发人员命令提示符(请使用管理员身份运行),如图 敲入 deve ...
- MySQL学习——操作自定义函数
MySQL学习——操作自定义函数 摘要:本文主要学习了使用DDL语句操作自定义函数的方法. 了解自定义函数 是什么 自定义函数是一种与存储过程十分相似的过程式数据库对象.它与存储过程一样,都是由SQL ...
- 前端开发JS——jQuery常用方法
jQuery基础(三)- 事件篇 1.jQuery鼠标事件之click与dbclick事件 click方法用于监听用户单击操作,dbclick方法用于监听用户双击操作,这两个方法用法及其类似,所以 ...
- Tasteless challenges medium WP
http://chall.tasteless.eu/ 国外的一个靶场,都是单点知识,medium大部分还是比较简单 medium Level 1- Infiltration http://chall. ...