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 中 ...
随机推荐
- Java笔记(持续更新)
码云地址 https://gitee.com/MarkPolaris/Java_Mark
- nodejs的require是如何执行的
通常,在Node.js里导入是通过 require函数调用进行的. Node.js会根据 require的是相对路径还是非相对路径做出不同的行为. 相对路径 相对路径很简单. 例如,假设有一个文件路径 ...
- 深入Pytorch微分传参
导数 这段代码揭示了多个变量的微分以及如何求解loss为向量的导数 m1 = Variable(torch.ones((3,2)), requires_grad=True) m2 = Variable ...
- celery生产者-消费者
Celery是一个简单,灵活,可靠的分布式系统,用于处理大量消息,同时为操作提供维护此类系统所需的工具. 它是一个任务队列,专注于实时处理,同时还支持任务调度. celery解决了什么问题: 示例一: ...
- oracle学习笔记(十六) PL/SQL 异常和goto语句
PL/SQL 异常和goto语句 异常 预定义异常 oracle常见预定义异常: 错误号 异常错误信息名称 说明 ORA-0001 DUP_VAL_ON_INDEX 试图破坏一个唯一性限制 ORA-0 ...
- ASP.NET MVC AJAX 请求中加入 antiforgerytoken 解决“所需的防伪表单字段“__RequestVerificationToken”不存在”问题
在ASP.NET mvc中如果在表中使用了@Html.AntiForgeryToken(),ajax post不会请求成功 解决方法是在ajax中加入__RequestVerificationToke ...
- Python 内置函数补充匿名函数
Python3 匿名函数 定义一个函数与变量的定义非常相似,对于有名函数,必须通过变量名访问 def func(x,y,z=1): return x+y+z print(func(1,2,3)) 匿名 ...
- django7-cookie与session
1.有状态服务与无状态服务 服务实例存储了客户端的数据 ,那么这就是个有状态服务 服务实例不存储客户端数据 ,让其他缓存存储客户端数据 ,这就是无状态服务 ,http就是无状态的 2.什么是cooki ...
- 初始HTML_表格
Html表格 <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <ti ...
- ucoreOS_lab5 实验报告
所有的实验报告将会在 Github 同步更新,更多内容请移步至Github:https://github.com/AngelKitty/review_the_national_post-graduat ...