本文实例讲述了Vue常用指令。分享给大家供大家参考,具体如下:
1、创建一个vue实例
vue的一个特点就是数据驱动界面,一旦对js中的数据进行修改,界面中用到数据的地方也会立马做出更改。为了对界面进行操纵,需要先获取到界面的标签元素,并实例化一个vue实例。
例如在HTML创建一个div:
<div id="app"> <p>{{msg}}</p> </div>
在js中将其实例化为vue对象:
let app=new Vue({ el:'#app',//标签的类名、id,用于获取元素 //以键值对的形式存放用到的数据成员 data:{ msg:'显示的内容' }, //包含要用到的函数方法 methods:{ } });
这样js中msg的内容就会在p标签内显示出来。
2、vue常用指令
1、 v-model:将组件与变量进行双向绑定,当组件数据修改时,变量会随之改变。它后面可加修饰符,例如.lazy,只有在标签中的值发生改变时才同步到变量,.trim过滤用户输入中的空格。
2、v-once:不允许修改数据,例如HTML中有如下三个标签:
<div id="app"> <p v-once>{{msg}}</p> <p>{{msg}}</p> <input type="text" v-model="msg"> </div>
在input框内输入内容后,会传到msg变量中,第二个p标签内显示的信息会随着msg发生变化,而第一个带有v-once的p标签则只会显示msg的初始值,不会随之变化。
3、v-if="表达式",根据表达式的结果来判断,是true则渲染元素,false则将元素注释掉
4、v-show与v-if类似,true就渲染,但是false并不是注释掉,而是通过display:none;来将元素隐藏,如果需要来回切换,使用v-show更好。例如:
<p v-if="show">显示内容</p> <p v-if="hide">注释内容</p> <p v-show="hide">v-show隐藏</p>
令show:true,hide:false,结果如下:
5、v-else、v-else-if与v-if连在一起使用构成逻辑判断,根据返回值决定是否显示,不可以单独或者分开使用,例如:
<p>请输入分值:</p> <input type="text" v-model="score"> <p v-if="score>90">优秀</p> <p v-else-if="score>80">良好</p> <p v-else-if="score>60">中等</p> <p v-else>不及格</p>
测试结果为:
6、v-for用于遍历元素,使用格式为v-for="(值,键) in 遍历内容",其遍历的内容可以是数组、对象、字符串,例如在js的data中有一个person对象,person:{name:'tony',age:15,sex:'男'},将其内容在页面遍历输出:
<p v-for="(value,key) in person"> {{key+':'+value}} </p>
生成结果如下:
7、v-text:向标签内注入数据,并且覆盖标签内的其他内容
8、v-html:向标签内覆盖注入HTML内容作为其子元素。例如:
<div v-html="vhtml">标签内原来内容</div>
结果插入一个子div并将覆盖原内容:
9、v-bind:给标签绑定属性、类、样式等,可以缩写为冒号,例如:
<!-- 完整语法 --> <a v-bind:href="url" rel="external nofollow" rel="external nofollow" >...</a> <!-- 缩写 --> <a :href="url" rel="external nofollow" rel="external nofollow" >...</a>
由于vue的界面元素都是由数据驱动的,js代码从服务器获得的属性、样式等数据需要通过绑定加到HTML界面元素上,通过绑定可以更为灵活地选择要添加属性的元素。Vue并不是直接操纵元素的class,而是通过绑定一个数据到class上,然后通过数据驱动class的有无,从而改变页面的显示,这充分显示了vue数据驱动的特点。
例如给上面person对象中key为'name'的那一行信息绑定一个active类使其高亮显示:
<!--通过v-for循环遍历person数组,绑定class,如果键值为name,绑定的class='active'--> <p v-for="(value,key) in person" :class="key==='name' "> {{key+':'+value}} </p>
结果:
也可以使用如下方法来绑定一个类名,页面会根据变量isActive与hasError的true或false来确定是否绑定active与text-danger类,甚至可以将active设为计算属性,运算后返回true/false。
注意:绑定的属性可以用驼峰命名法或使用短横线来连接,但使用短横线要用引号引起来
<div class="static" v-bind:class="{ active: isActive, 'text-danger': hasError }"> </div>
10、v-on:给标签绑定函数,可以缩写为@,例如绑定一个点击函数
<p>{{msg}}</p> <button @click="changeContent()">change</button>
在Vue的methods中实现changeContent函数:
let app=new Vue({ el:'#app', data:{ msg:'第一次输入信息', }, methods:{ changeContent(){ this.msg="修改后的输入信息"; } } });
原页面与点击后:
Vue.js 为 v-on 提供了事件修饰符。修饰符是由.开头的指令后缀来表示的,用于对事件进行约束。例如:
<!-- 阻止单击事件继续传播 --> <a v-on:click.stop="doThis"></a> <!-- 提交事件不再重载页面 --> <form v-on:submit.prevent="onSubmit"></form> <!-- 修饰符可以串联使用,并且使用的顺序很重要 --> <a v-on:click.stop.prevent="doThat"></a> <!-- 添加事件监听器时使用事件捕获模式 --> <!-- 即元素自身触发的事件先在此处处理,然后才交由内部元素进行处理 --> <div v-on:click.capture="doThis">...</div> <!-- 只当在 event.target 是当前元素自身时才触发函数 --> <!-- 即事件不从内部元素触发 --> <div v-on:click.self="doThat">...</div> <!-- 点击事件将只会触发一次 --> <a v-on:click.once="doThis"></a>
除了点击事件外,还有按键事件,例如按下键盘码为13的按钮时触发:
<input v-on:keyup.13="submit">
为了方便使用vue将一些常用按键重命名,可以使用事件修饰符来使用,包括:.enter、.delete、.tab、.space、.esc、.up、.down、.right、.left等,也可以自定义:
Vue.config.keyCodes.f1 = 112;
希望本文所述对大家vue.js程序设计有所帮助。
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
稳了!魔兽国服回归的3条重磅消息!官宣时间再确认!
昨天有一位朋友在大神群里分享,自己亚服账号被封号之后居然弹出了国服的封号信息对话框。
这里面让他访问的是一个国服的战网网址,com.cn和后面的zh都非常明白地表明这就是国服战网。
而他在复制这个网址并且进行登录之后,确实是网易的网址,也就是我们熟悉的停服之后国服发布的暴雪游戏产品运营到期开放退款的说明。这是一件比较奇怪的事情,因为以前都没有出现这样的情况,现在突然提示跳转到国服战网的网址,是不是说明了简体中文客户端已经开始进行更新了呢?
更新日志
- 凤飞飞《我们的主题曲》飞跃制作[正版原抓WAV+CUE]
- 刘嘉亮《亮情歌2》[WAV+CUE][1G]
- 红馆40·谭咏麟《歌者恋歌浓情30年演唱会》3CD[低速原抓WAV+CUE][1.8G]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[320K/MP3][193.25MB]
- 【轻音乐】曼托凡尼乐团《精选辑》2CD.1998[FLAC+CUE整轨]
- 邝美云《心中有爱》1989年香港DMIJP版1MTO东芝首版[WAV+CUE]
- 群星《情叹-发烧女声DSD》天籁女声发烧碟[WAV+CUE]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[FLAC/分轨][748.03MB]
- 理想混蛋《Origin Sessions》[320K/MP3][37.47MB]
- 公馆青少年《我其实一点都不酷》[320K/MP3][78.78MB]
- 群星《情叹-发烧男声DSD》最值得珍藏的完美男声[WAV+CUE]
- 群星《国韵飘香·贵妃醉酒HQCD黑胶王》2CD[WAV]
- 卫兰《DAUGHTER》【低速原抓WAV+CUE】
- 公馆青少年《我其实一点都不酷》[FLAC/分轨][398.22MB]
- ZWEI《迟暮的花 (Explicit)》[320K/MP3][57.16MB]