Vue的基本语法(二),双向绑定
文章目录事件修饰符:Vue指令之`v-model`和`双向数据绑定`事件修饰符:.stop阻止冒泡.prevent阻止默认事件.capture添加事件侦听器时使用事件捕获模式.self只当事件在该元素本身(比如不是子元素)触发时触发回调.once事件只触发一次<!DOCTYPE html><html l...
·
事件修饰符:
- .stop 阻止冒泡
- .prevent 阻止默认事件
- .capture 添加事件侦听器时使用事件捕获模式
- .self 只当事件在该元素本身(比如不是子元素)触发时触发回调
- .once 事件只触发一次
<!DOCTYPE html>
<html lang="zh-CN">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=0,minimal-ui:ios">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>Document</title>
<script src="./lib/vue-2.4.0.js"></script>
<style>
.inner{
height: 150px;
background-color: darkcyan;
}
.outer{
padding: 50px;
background-color: red;
}
</style>
</head>
<body>
<div class="fd-app">
<div class="inner" @click="div1Handler">
<!-- 使用.stop阻止冒泡 -->
<button @click.stop="btnHandler">戳他</button>
</div>
<!-- 使用.prevent阻止默认行为 -->
<a href="http://www.baidu.com" @click.prevent="linkClick">有问题,找百度</a>
<!-- 使用.capture实现捕获触发事件的机制 -->
<div class="inner" @click.capture="div1Handler">
<button @click="btnHandler">戳他</button>
</div>
<!-- 使用.self实现只要有点击当前元素时候,才会触发事件处理函数 -->
<div class="inner" @click.self="div1Handler">
<button @click="btnHandler">戳他</button>
</div>
<!-- 使用.once值触发一次事件处理函数 -->
<a href="http://www.baidu.com" @click.prevent.once="linkClick">有问题,找百度</a>
<!-- 演示:.stop和.self区别 -->
<!-- .self只会阻止自己身上冒泡行为的触发,并不会真正阻止冒泡的行为 -->
<div class="outer" @click="div2Handler">
<div class="inner" @click.self="div1Handler">
<button @click="btnHandler">戳他</button>
</div>
</div>
</div>
<script>
var vm = new Vue({
el:".fd-app",
data:{},
methods:{
div1Handler(){
console.log('这是触发了inner div的点击事件');
},
btnHandler(){
console.log('这是触发了按钮的点击事件');
},
linkClick(){
console.log('出发了链接的点击事件');
},
div2Handler(){
console.log('这是触发了outer div的点击事件');
}
}
})
</script>
</body>
</html>
Vue指令之v-model
和双向数据绑定
<!DOCTYPE html>
<html lang="zh-CN">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=0,minimal-ui:ios">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>Document</title>
<script src="./lib/vue-2.4.0.js"></script>
</head>
<body>
<div class="fd-app">
<h4>{{msg}}</h4>
<!-- 使用v-model指令,可用实现表单元素和Model中数据的双向数据绑定 -->
<!-- 注意:v-model只能运用在表单元素中 -->
<!-- input(radio,text,address,email。。。) select checkbox textarea -->
<input type="text" v-model="msg" style="width: 100%">
<select v-model="selected">
<option v-for="option in options" v-bind:value="option.value">
{{ option.text }}
</option>
</select>
<span>Selected: {{ selected }}</span>
</div>
<script>
var vm = new Vue({
el:".fd-app",
data:{
msg:'大家都是好学生,爱敲代码,爱学习。',
selected: 'A',
options: [
{ text: 'One', value: 'A' },
{ text: 'Two', value: 'B' },
{ text: 'Three', value: 'C' }
]
},
methods:{
}
})
</script>
</body>
</html>
例子:简易计算器
<!DOCTYPE html>
<html lang="zh-CN">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=0,minimal-ui:ios">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>Document</title>
<script src="./lib/vue-2.4.0.js"></script>
</head>
<body>
<div class="fd-app">
<input type="text" v-model="n1">
<select v-model="opt">
<option value="+">+</option>
<option value="-">-</option>
<option value="*">*</option>
<option value="/">/</option>
</select>
<input type="text" v-model="n2">
<input type="button" value="=" @click="calc">
<input type="text" v-model="result">
</div>
<script>
var vm = new Vue({
el:".fd-app",
data:{
n1:0,
n2:0,
result:0,
opt: '+'
},
methods:{
/*calc(){ //计算器算数的方法
//逻辑:
switch(this.opt){
case '+':
this.result = parseInt(this.n1) + parseInt(this.n2);
break;
case '-':
this.result = parseInt(this.n1) - parseInt(this.n2);
break;
case '*':
this.result = parseInt(this.n1) * parseInt(this.n2);
break;
case '/':
this.result = parseInt(this.n1) / parseInt(this.n2);
break;
}
}*/
//注意:这是投机取巧的方式,正式开发中尽量少用。
calc(){
var codeStr = 'parseInt(this.n1)' + this.opt + 'parseInt(this.n2)';
this.result = eval(codeStr);
}
}
})
</script>
</body>
</html>
更多推荐
已为社区贡献1条内容
所有评论(0)