vue实现 toggle显示隐藏效果
背景介绍
jQuery中有个toggle()方法,可以切换元素的显示状态,在用vue时如果不引入jQuery如何实现这种效果?
使用场景
常见有三种场景:
1.控制页面中一个dom元素
2.控制页面中多个dom元素
3.控制页面中的dom元素是从服务端返回,且有多个
技术分析
1.一二场景下实现这种效果可以用v-if指令,通过设置true或false来控制dom的隐藏与显示。如果控制一个dom或多个dom我们可以在data中定义对应的flag,每次点击事件发生时 flag=!flag ,来切换flag的值。这样点击的dom可以做的显示或隐藏切换。
2.第一和第二种场景比较简单按照上述方式可以实现,第三种场景用这种方法就不行了,因为我们不知道会从服务端返回几个dom,所以也就不能具体的定义控制dom的flag变量。这种情况下要怎么实现点击从用服务端返回的数据渲染成的dom,来达到却换隐藏和显示效果?
实现方法
实现第三种场景可以用Vue.set()方法。具体实现方式如下:
1.第一步先定义一个data对象来接收从服务端返回的数据
data(){
return {
listAll:{}
}
}
2.先定义个toggleShow()方法:
methods: {
toggleShow(index){
let obj = this.listAll[index]; // 找到点击的dom对象
obj.hide = !obj.hide; // 向这个对象中添加 hide 属性
this.$set(this.listAll, index, obj); // 把添加完hide 属性的新对象set()进data数据中
}
}
3.在标签模板中调用toggleShow()方法
<div v-for="(item, index) in listAll" :key="index">
<card @click.native="toggleShow(index)">
</card>
<div v-if="item.hide ? true:false">
// 显示或隐藏区域
</div>
</div>
归纳总结
实现这种需要有两种方式
1.在data中定义固定的flag值,根据用切换flag值的方式来达到切换dom的显示或隐藏
2.使用Vue.set()方法,在异步请求会的数据中添加临时hide属性,来控制点击的dom元素隐藏或显示
如果不知道如何把从服务端接收的数据实时渲染的页面中,可以翻看这篇文章:
vue异步请求的数据怎样实时渲染到页面上?
vue实现 toggle显示隐藏效果的更多相关文章
- js鼠标滑动图片显示隐藏效果
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...
- vue+element-ui实现显示隐藏密码
<template> <el-form :model="cuser_info" label-width="115px" label-posit ...
- jquery显示隐藏效果
通过 jQuery,您可以使用 hide() 和 show() 方法来隐藏和显示 HTML 元素toggle() 方法来切换 hide() 和 show() 方法. 1.hide()隐藏元素 $(se ...
- 基于jQuery实现页面滚动时顶部导航显示隐藏效果
<!DOCTYPE html> <html lang="zh-cn"> <head> <meta charset="UTF-8& ...
- 兼容IE6及以上的导航栏子菜单栏滑过显示隐藏效果
;(function(window){ var li = document.getElementById('parentnav').getElementsByTagName('li')[ ...
- react better-scroll 编写类似手机chrome的header显示隐藏效果
关键代码 const H = 50; // header的高度 const H2 = H / 2; let cy = 0; class Home extends Component { @observ ...
- WinForm实现类似QQ停靠,显示隐藏过程添加特效效果
原文:WinForm实现类似QQ停靠,显示隐藏过程添加特效效果 这可能是个老题长谈的问题了,只是在项目中会用到这个效果,所以今天做个记录.大家见了别喷我.在项目中的需求是这样的. 打开程序,在屏幕的右 ...
- js进阶 13-1 jquery动画中的显示隐藏函数有哪些
js进阶 13-1 jquery动画中的显示隐藏函数有哪些 一.总结 一句话总结:show(),hide(),toggle(),这三个. 1.jquery动画中显示隐藏效果函数有哪些? show()h ...
- jquery的toggle动画效果显示隐藏
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...
随机推荐
- asp.net session锁导致ajax请求阻塞
问:为了可以顺序访问Session的状态值,Session是否提供了锁定机制?答:Session实现了Reader/Writer的锁机制:当页面对Session具有可写功能(即页面有<%@Pag ...
- partial_sum
版本1: template < class InputIterator, class OutputIterator > OutputIterator partial_sum(InputIt ...
- 2^n算法
题目描述: 如题…… 那么,可以用c++自带快速幂:pow: #include<cstdio> using namespace std; int n; int main() { scanf ...
- Java中Integer和int的异同
public void Test1() { int a = 128; Integer b = 128; Integer c = 128; //Integer会自动拆箱成int,所以为ture Syst ...
- 内层DIV超出后,出现滚动条问题
使用:overflowy:'unset'属性,可以解决
- PrimeNG之Validation
Validation ----primeng输入组件显示验证错误时自动标记为无效值. demo code export class ValidationDemo implements OnInit { ...
- Django之Cookie、Session、CSRF、Admin
Django之Cookie.Session.CSRF.Admin Cookie 1.获取Cookie: 1 2 3 4 5 6 request.COOKIES['key'] request.get ...
- LeetCode 993 Cousins in Binary Tree 解题报告
题目要求 In a binary tree, the root node is at depth 0, and children of each depth k node are at depth k ...
- winfrom弹出窗口用timer控件控制倒计时20秒后关闭
功能描述: 因为在程序退出时需要确认是否是误操作,所以加了密码输入的子窗体,子窗体在20秒内会自动关闭 代码如下: private int count; private void Form2_Load ...
- Cestos7安装Elasticsearch5.4.3
Elasticsearch及配件下载地址:https://www.elastic.co/cn/downloads 为了简单起见,我们使用tar文件. 在/usl下创建elk目录 一.安装elastic ...