vue中的dom指令控制
一、条件控制指令
1、v-if,条件渲染
<div id="J_app"> <p v-if="show">显示该标签</p> </div> var vapp = new Vue({ el: '#J_app', data: { show: true } })
2、template使用
template元素最终不会出现在dom中
<div id="J_app"> <template v-if="isdisplay"> <h1>模板标签会隐藏</h1> <p>模板标签会隐藏</p> <p>模板标签会隐藏</p> </template> </div> var vapp = new Vue({ el: '#J_app', data: { isdisplay: true } })
3、v-else使用
<div id="J_app"> <div v-if="type === 'A'"> A </div> <div v-else-if="type === 'B'"> B </div> <div v-else-if="type === 'C'"> C </div> <div v-else> Not A/B/C </div> </div> var vapp = new Vue({ el: '#J_app', data: { type: 'D' } })
4、数据遗留
<div id="J_app"> <template v-if="loginType === 'username'"> <label>Username</label> <input placeholder="Enter your username"> </template> <template v-else> <label>Email</label> <input placeholder="Enter your email address"> </template> </div>
5、数据不遗留
<div id="J_app"> <template v-if="loginType === 'username'"> <label>Username</label> <input placeholder="Enter your username" key="username-input"> </template> <template v-else> <label>Email</label> <input placeholder="Enter your email address" key="email-input"> </template> </div>
6、v-show,条件展示
<div id="J_app"> <p v-show="isdisplay">只是做了隐藏,元素本身没有从dom上消失</p> </div> var vapp = new Vue({ el: '#J_app', data: { isdisplay: true } })
v-show不支持template,也不支持v-else,通过是否添加display:none控制显隐,v-if的切换开销比较大。
二、循环控制指令
1、固定值
<div id="J_app"> <span v-for="i in 10"> {{ i }} </span> </div>
2、template使用
<div id="J_app"> <ul> <template v-for="item in items"> <li>{{ item.option }}</li> <li class="divider"></li> </template> </ul> </div> var vapp = new Vue({ el: '#J_app', data: { items: [ { option: '前进' }, { option: '后退' }, { option: '休息' } ] } })
3、遍历数组
<div id="J_app"> <ol> <li v-for="item in items" :key="item.id"> {{ item.text }} </li> </ol> </div> var vapp = new Vue({ el: '#J_app', data: { items: [ { text: '学习 webpack' }, { text: '学习 Vue' }, { text: '整个牛项目' } ] } })
<div id="J_app"> <ol> <li v-for="(item,index) in items"> {{ flag }} - {{ item.index }} - {{ item.text }} </li> </ol> </div> var vapp = new Vue({ el: '#J_app', data: { flag: "parent", items: [ { text: '学习 webpack' }, { text: '学习 Vue' }, { text: '整个牛项目' } ] } }) //改变原数组,数组变异 vapp.items.push({text:'学习es6'}) //返回新数组 vapp.items = vapp.items.filter(function (item) { return item.text.match(/学习/) }) //修改某项 Vue.set(vapp.items, 2, { text: '学习vue,需要基础知识做铺垫'})
<div id="J_app"> <ol> <li v-for="num in evenNumbers"> {{ num }} </li> </ol> </div> //显示数组过滤的副本,而不改变原来的数组 var vapp = new Vue({ el: '#J_app', data: { numbers: [ 1, 2, 3, 4, 5 ] }, computed: { evenNumbers: function () { return this.numbers.filter(function (number) { return number % 2 === 0 }) } } })
<div id="J_app"> <ol> <li v-for="num in even(numbers)"> {{ num }} </li> </ol> </div> var vapp = new Vue({ el: '#J_app', data: { numbers: [ 1, 2, 3, 4, 5 ] }, methods: { even: function (numbers) { return numbers.filter(function (number) { return number % 2 === 0 }) } } })
4、遍历对象
<ul id="J_app"> <li v-for="value in personObj"> {{ value }} </li> </ul> var vapp = new Vue({ el: '#J_app', data: { personObj: { firstName: 'Camille', lastName: 'Hou', age: 30 } } }) //添加sex属性到personObj对象 Vue.set(vapp.personObj,'sex','male') //也可以用 vapp.$set(vapp.personObj,'sex','male') //为已有对象赋予多个属性值 vapp.personObj = Object.assign({}, vapp.personObj, { weight: 105, len: '158cm' })
<div id="J_app"> <div v-for="(value, key) in personObj"> {{ key }}:{{ value }} </div> </div> var vapp = new Vue({ el: '#J_app', data: { personObj: { firstName: 'Camille', lastName: 'Hou', age: 30 } } })
<div id="J_app"> <div v-for="(value, key, index) in personObj"> {{ index }}、{{ key }}、{{ value }} </div> </div> var vapp = new Vue({ el: '#J_app', data: { personObj: { firstName: 'Camille', lastName: 'Hou', age: 30 } } })
vue中的dom指令控制的更多相关文章
- Vue中获取dom元素
Vue.js虽然说是数据驱动页面的,但是有时候我们也要获取dom对象进行一些操作. vue的不同版本获取dom对象的方法不一样 Vue.js 1.0版本中,通过v-el绑定,然后通过this.els ...
- 第七十六篇:ref引用(在vue中引用Dom的方法)
好家伙, 引子: jQuery简化了程序员操作DOM的过程 vue 优势:MVVM 在vue中,程序员不需要操作DOM.程序员只需要把数据维护好即可!(数据驱动视图) 那么若要在vue中操作dom,这 ...
- vue中常见的指令
1,差值表达式{{}} <p >{{ msg }}</p> 2.v-cloak解决差值表达式闪烁的问题 <p v-cloak>{{ msg }}</p> ...
- [记录] Vue中的dom操作
使用过Vue的同学都应该有这样一个感觉,在vue中页面是基于数据驱动的,不需要我们自己操作dom,框架帮我们完成了这一步,事实上Vue官方也建议我们这样做 在绝大多数情况下是不需要操作dom就可以完成 ...
- 在vue中创建自定义指令
原文:https://dev.to/ratracegrad/creating-custom-directives-in-vue-58hh 翻译:心上有杨 指令是带有 v- 前缀的特殊属性.指令的作用是 ...
- Vue中v-on的指令以及一些其他指令
1.v-on的基本使用 <div id="app"> <!-- 使用事件绑定的简写形式 --> <input type="button&qu ...
- Vue中 等待DOM或者数据完成 在执行 --this.$nextTick()
虽然 Vue.js 通常鼓励开发人员沿着“数据驱动”的方式思考,避免直接接触 DOM,但是有时我们确实要这么做.比如一个新闻滚动的列表项.如果在这里需要操作dom, 应该是等待 Vue 完成更新 DO ...
- 在vue中操作dom元素
在vue中可以通过给标签加ref属性,就可以在js中利用ref去引用它,从而达到操作该dom元素,以下是个参考例子 1 <template> 2 <div> 3 <div ...
- vue中操作Dom节点的方法
1.vue中ref操作dom节点 <template> <div id="app"> <div </div> <button @cl ...
随机推荐
- python渗透
计划写一个获取qq空间加密相册的工具. 分析: 她的相册密码是手机号,先写一个生成手机号的脚本 空间有她之前的手机号,那么她现在的手机号也极有可能是一样的运营商,比如移动(缩小密码范围) 自己新建一个 ...
- MFC_CFileDialog_选择文件夹
场景 在MFC中有时候只需要选择一个文件夹而不需要选择文件,这时候可以通过下列方式来进行选择 技术点 BROWSEINFO typedef struct_browseinfo { HWND hwndO ...
- nginx报错:403 Forbidden 并且访问首页index.php是下载文件的状态
nginx报错:403 Forbidden 并且访问首页index.php是下载文件的状态,不能正常解析php 系统有其他两个站访问是正常的 看日志没有看到明显的错误 搜索了下: 答案如下: php的 ...
- Error: Cannot retrieve metalink for repository: epel. Please verify its path and try again
# yum install -y vim Loaded plugins: fastestmirror, presto Loading mirror speeds from cached hostfil ...
- nginx1.8.1反向代理、负载均衡功能的实现
nginx1.8.1 proxy 服务器192.168.8.40 web1 centos6.5 httpd2.2.15 web2 centos7.2 httpd2.4.6 1.代理功能的简单实现 ng ...
- 容器平台选型的十大模式:Docker、DC/OS、K8S 谁与当先?【转】
网易企业服务2017-10-13 无论是在社区,还是在同客户交流的过程中,总会被问到到底什么时候该用 Docker?什么时候用虚拟机?如果使用容器,应该使用哪个容器平台? 显而易见,我不会直接给大家一 ...
- 100以内的质数(for和if)
- 测试开发之前端——No6.HTML5中的键盘事件
键盘事件 由键盘触发的事件. 适用于所有 HTML 5 元素: 属性 值 描述 onkeydown script 当按下按键时运行脚本 onkeypress script 当按下并松开按键时运行脚本 ...
- PHP常见错误提示含义解释
1.Notice: Undefined variable: 变量名 in 注:使用了一个没有被定义的变量 2.Parse error: syntax error, unexpected T_ELSE ...
- swich使用
package demo; import java.util.Scanner; /** * swich(变量){//byte\shore\char\int'枚举(jdk1.5)/String(1.7) ...