Vue学习笔记(二)动态绑定、计算属性和事件监听
一、为属性绑定变量
在前面第一部分中,我们已经可以使用Vue来动态绑定元素中的值了,但是我们该怎样绑定为元素的属性绑定一个变量呢?
1. v-bind的基本使用
我们可以使用v-bind来为一个元素的属性绑定一个在Vue实例中定义好的变量,语法为:
v-bind:属性名="表达式"
如下例所示:
var app = new Vue({
el: '#app',
data: {
imgURL: "https://dss1.baidu.com/6ONXsjip0QIZ8tyhnq/it/u=2296203553,2815843260&fm=58",
aHref: "http://baidu.com",
aName: "百度一下"
}
});
<div id="app">
<!-- 错误的做法 -->
<!-- <img src="{{imgURL}}" alt=""> -->
<img v-bind:src="imgURL" alt="">
<a v-bind:href="aHref">{{aName}}</a>
<!-- 语法糖写法,实际开发主要使用 -->
<img :src="imgURL" alt="">
<a :href="aHref">{{aName}}</a>
</div>
运行结果:

可以发现元素上属性的值都可以由变量指定了,而 :属性名="表达式"是原始写法的语法糖。
2. v-bind动态绑定class(对象语法)
语法:
v-bind:class="obj"
其中obj是一个js对象,它的键(变量名)是某个类的类名,值为bool类型,决定这个类是否绑定到该元素上。
示例:
var app = new Vue({
el: '#app',
data: {
message: "你好啊",
active: "active",
isActive: true,
isLine: true,
},
methods: {
btnClick: function () {
this.isActive = !this.isActive;
},
getClasses: function () {
return { active: this.isActive, line: this.isLine };
}
}
});
.active {
color: red;
}
<div id="app">
<h2 class="active">第一个:{{message}}</h2>
<h2 :class="active">第二个:{{message}}</h2>
<!-- <h2 v-bind:class="{key1:value, key2:value}"></h2> -->
<!-- <h2 v-bind:class="{类名1:true, 类名2:false}"></h2> -->
<h2 class="title" v-bind:class="{active:isActive, line:isLine}">TrueOrFalse</h2>
<h2 class="title" v-bind:class="getClasses()">TrueOrFalse</h2>
<button v-on:click="btnClick">变色</button>
</div>
运行结果:

3. v-bind动态绑定class(数组语法)
语法:
v-bind:class="list"
其中list是一个js数组,其中的各个元素的值(字符串)是要绑定到该html元素的class。
示例如下:
var app = new Vue({
el:'#app',
data:{
message:"你好啊",
active:"aaaa",
line:"bbbb",
},
methods:{
getClasses:function(){
return ["aaa","bbb"]
}
}
});
<div id="app">
<!-- 有单引号当做字符串,无当做变量解析 -->
<h2 :class="['active','line']">{{message}} </h2>
<h2 :class="[active, line]">{{message}} </h2>
<h2 :class="getClasses()">{{message}} </h2>
</div>
运行结果:

4. v-bind动态绑定style(对象语法)
语法:
v-bind:style="obj"
其中obj是Vue实例中的一个js对象,它的键(变量名)对应着css的样式属性,而值对应着该样式属性的值,因此我们可以通过改变obj中的某个键的值来改变某个样式。
示例:
var app = new Vue({
el: '#app',
data: {
message: "你好啊",
finalSize: "100px",
finalInt: 100,
finalColor: "red"
},
methods: {
getStyles: function () {
return { fontSize: this.finalInt + 'px', color: this.finalColor }
},
addSize: function () {
if (this.finalInt < 130) {
this.finalInt += 10;
}
},
subSize: function () {
if (this.finalInt > 50) {
this.finalInt -= 10;
}
},
change: function () {
if (this.finalColor == 'blue') {
this.finalColor = 'red';
}
else {
this.finalColor = 'blue';
}
}
}
});
<div id="app">
<!-- <h2 :style="{key(属性名):value(属性值)}">{{message}} </h2> -->
<!-- <h2 :style="{fontSize:'50px'}">{{message}} </h2> -->
<!-- <h2 :style="{fontSize: finalSize}">{{message}}</h2> -->
<h2 :style="{fontSize: finalInt+'px', color: finalColor}">{{message}}</h2>
<h2 :style="getStyles()">{{message}}</h2>
<button @click="addSize">+</button>
<button @click="subSize">-</button>
<button @click="change">变色</button>
</div>
5. v-bind动态绑定style(数组语法)
语法:
v-bind:style="list"
其中list是一个js数组,其中的各个元素的值(对象)是要绑定到该html元素的style键值对。其中键名(变量名)是style属性名,值是对应属性值。
示例:
var app = new Vue({
el:'#app',
data:{
message:"你好啊",
baseStyle:{backgroundColor:'red'},
baseStyle1:{fontSize:'100px'}
},
methods:{}
});
<div id="app">
<h2 :style="[baseStyle, baseStyle1]">{{message}}</h2>
</div>
运行效果:

二、计算属性
计算属性被编写到Vue实例中的computed属性中
语法:
...
computed: {
计算属性名(一般以名词命名): function () {
// 相当于一个属性
return xxx;
}
},
...
在语法上和方法的写法基本相同。
1. 基本使用
var app = new Vue({
el: '#app',
data: {
firstName: "Lebron",
lastName: "James"
},
computed: {
fullName: function () {
// 相当于一个属性
return this.firstName + " " + this.lastName;
}
},
methods: {
getFullName: function () {
return this.firstName + " " + this.lastName;
}
}
});
<div id="app">
<h2>{{firstName+" "+lastName}} </h2>
<h2>{{firstName}} {{lastName}} </h2>
<h2>{{getFullName()}} </h2>
<h2>{{fullName}} </h2>
</div>
运行结果:

可以发现使用方法和计算属性都可以得到正确的结果。
2. 计算属性的setter和getter
语法:
computed:{
计算属性名:{
set:function(){
...
},
get:function(){
...
}
}
},
且计算属性一般是没有set方法的
3. 计算属性和method对比
最主要的差别是计算属性在第一次返回结果后会有缓存机制,若结果相同则不会再次计算,如下例所示:
var app = new Vue({
el: '#app',
data: {
firstName: "Kobe",
lastName: "Bryant",
},
computed: {
fullName: function () {
console.log("+++++")
return this.firstName + " " + this.lastName;
}
},
methods: {
getFullName: function () {
console.log("=========")
return this.firstName + " " + this.lastName;
}
}
});
<div id="app">
<h2>{{getFullName()}} </h2>
<h2>{{getFullName()}} </h2>
<h2>{{getFullName()}} </h2>
<h2>{{getFullName()}} </h2>
<!-- 缓存机制 -->
<h2>{{fullName}} </h2>
<h2>{{fullName}} </h2>
<h2>{{fullName}} </h2>
<h2>{{fullName}} </h2>
</div>
运行结果:

可以发现getFullName()方法执行了4次,而fullName计算属性只执行了1次
三、事件监听
v-on的基本使用可以参照上个部分的计数器。
1. v-on的参数问题
- 如果没有传入参数,则默认的参数为undifined
<button @click="click1()">按钮1</button>
- 如果不写函数的括号,则会默认将
event对象传递过去
<button @click="click2">按钮2</button>
- 如何手动获得浏览器产生的event对象(使用
$event)
<button @click="click3(123, $event)">按钮3</button>
示例:
var app = new Vue({
el: '#app',
data: {},
methods: {
click1() {
console.log("按钮1");
},
click2(abc) {
console.log(abc);
},
click3(abc, event) {
console.log(abc, event);
}
}
});
<div id="app">
<button @click="click1()">按钮1</button>
<!-- 如果没有传入参数,则默认参数为undefined -->
<!-- <button @click="click2(123)">按钮2</button> -->
<!-- <button @click="click2()">按钮2</button> -->
<!-- 这种情况会将event对象传递过去 -->
<button @click="click2">按钮2</button>
<!-- 如何手动获得浏览器产生的event对象 -->
<button @click="click3(123, $event)">按钮3</button>
</div>
运行结果:


2. v-on修饰符
click的.stop修饰符
这个修饰符可以阻止事件气泡往下传递
对比:
<div @click="divClick">
inside div
<button @click="btnClick">按钮</button>
</div>
和:
<div @click="divClick">
inside div
<button @click.stop="btnClick">按钮</button>
</div>
第一种情况除了btnClick()方法会被调用外,button元素的父元素div也会收到点击事件,进而divClick()函数也会被调用。
而第二种情况则使用了.stop阻止气泡向下传递,只有btnClick()方法会被调用。
click的.prevent修饰符
作用:阻止事件的默认行为,然后执行后面引用的method。
例如:
<form action="baidu">
<input type="submit" value="提交" @click.prevent="submitClick">
</form>
这样当点击按钮时不会提交表单,而之后调用submitClick()方法。
click的.once修饰符
作用:事件只监听一次
<button @click.once="btn2Click">
按钮2
</button>
这种情况下多次点击button,只会执行一次btn2Click()方法
keydown的.enter修饰符
作用:监听键盘的点击
<input type="text" @keydown.enter="keyDown">
Vue学习笔记(二)动态绑定、计算属性和事件监听的更多相关文章
- Blazor和Vue对比学习(基础1.8):Blazor中实现计算属性和数据监听
1.7章<传递UI片断>,需要做几个案例,这部分暂停消化几天.我们先把基础部分相对简单的最后两章学习了. 计算属性和数据监听是Vue当中的概念,本质上都是监听数据的变化,然后做出响应.两者 ...
- WebView使用详解(二)——WebViewClient与常用事件监听
登录|注册 关闭 启舰 当乌龟有了梦想…… 目录视图 摘要视图 订阅 异步赠书:Kotlin领衔10本好书 免费直播:AI时代,机器学习如何入门? 程序员8 ...
- vue computed计算属性和watch监听属性解疑答惑
computed计算属性 计算属性类似于方法,用于输出data中定义的属性数据的结果,data数据变化时,计算属性的结果会同步变化,需要注意的是计算属性不可与data定义的属性同名. 相比于方 ...
- vue2.0 之计算属性和数据监听
计算属性computed <template> <div> <input type="text" name="" v-model= ...
- android菜鸟学习笔记23----ContentProvider(三)利用内置ContentProvider监听短信及查看联系人
要使用一个ContentProvider,必须要知道的是它所能匹配的Uri及其数据存储的表的结构. 首先想办法找到访问短信及联系人数据的ContentProvider能接受的Uri: 到github上 ...
- vue学习笔记(二)vue的生命周期和钩子函数
前言 通过上一章的学习,我们已经初步的了解了vue到底是什么东西,可以干什么,而这一篇博客主要介绍vue的生命周期和它常用的钩子函数,如果有学过java的园友可能有接触到在学习servlet的时候学过 ...
- Vue学习笔记二:v-cloak,v-text,v-html的使用
目录 v-cloak:解决插值表达式闪烁问题 安装插件Live Server 右键以HTTP形式运行HTML v-text:以属性方式使用插值表达式 v-cloak和v-text的区别 v-html: ...
- VUE 学习笔记 二 生命周期
1.除了数据属性,Vue 实例还暴露了一些有用的实例属性与方法.它们都有前缀 $,以便与用户定义的属性区分开来 var data = { a: 1 } var vm = new Vue({ el: ' ...
- VUE学习笔记二
package.json不可以写注释!!!!!!!!!!初始化:npm init -y 有时候使用 npm i node-sass -D 装不上,这时候,就必须使用 cnpm i node-sass ...
随机推荐
- ESCMScript(1)let和const
1.let命令 基本语法 ES6 新增了let命令,用来声明变量.它的用法类似于var,但是所声明的变量,只在let命令所在的代码块内有效. { let a = 1 var b = 2 console ...
- Linux网络命令与脚本使用
作为系统管理员,经常需要诊断和解决网络问题,而配置.监控与保护网络有助于发现问题并在事情范围扩大前得意解决,并且网络的性能与安全也是管理与诊断网络的重要部分.这里总结一下常用与Linux网络管理的命令 ...
- Spring Boot动态权限变更实现的整体方案
1.前言 在Web项目中,权限管理即权限访问控制为网站访问安全提供了保障,并且很多项目使用了Session作为缓存,结合AOP技术进行token认证和权限控制.权限控制流程大致如下图所示: 现 ...
- excel VBA返回选中单元格区域的行数、列数,以及活动单元格的行号和列号
Private Sub Worksheet_SelectionChange(ByVal Target As Range) '可以直接sub(),不然选择就会触发vba Dim rows_coun ...
- Sai学习笔记
颜色模块的功能介绍 色轮 RGB滑块 HSV滑块(常用) H:色相 S:纯度 V:明度 中间色条,主要用来混色 颜料盒 调色板 选择工具的使用 选择框 快捷键:Ctrl+D 套索 魔棒 图文工具使用 ...
- 单链表(LinkedList)
与数组相似,链表也是一种线性数据结构.这里有一个例子: 正如你所看到的,链表中的每个元素实际上是一个单独的对象,而所有对象都通过每个元素中的引用字段链接在一起. 链表有两种类型:单链表和双链表 ...
- MySQL数据库性能优化与监控实战(阶段四)
MySQL数据库性能优化与监控实战(阶段四) 作者 刘畅 时间 2020-10-20 目录 1 sys数据库 1 2 系统变量 1 3 性能优化 1 3.1 硬件层 1 3.2 系统层 1 3.3 软 ...
- 02 jumpserver系统设置
2.系统设置: (1)基本设置: (2)邮件设置: 1)163邮箱设置: 2)在jumpserver上填写邮箱信息: 3)邮件测试信息如下: (3)邮件内容设置: (4)终端设置: (5)安全设置:
- XCTF re-100
一.无壳并拉入ida64静态调试(注释说的很明白了) 二.confuseKey是个关键函数,进入看看 发现就是将我们所输入的字符串分割,并把顺序调换了,调回来就是我们的flag. 三.flag: 提交 ...
- 使用VS远程调试其他电脑上安装的软件
今天在用户的一台机器上遇到了很奇怪的问题.一个按钮点击时概率性的第一次点击无反馈. 因为是概率性的,概率又很低,而当初在设计Log时又设计的是必须重启软件才会生效log开关: 所以这里使用当时rele ...