标签:例子 cti name body 作用 lis 名称 匿名 lang
实例事件就是在构造器外部写一个调用构造器内部的方法。这样写的好处是可以通过这种写法在构造器外部调用构造器内部的数据。
我们还是写一个点击按钮,持续加1的例子。
app.$on('reduce',function(){
console.log('执行了reduce()');
this.num--;
});
$on接收两个参数,第一个参数是调用时的事件名称,第二个参数是一个匿名方法。
如果按钮在作用域外部,可以利用$emit来执行。
//外部调用内部事件
function reduce(){
app.$emit('reduce');
}
全部代码:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>example03</title>
<script type="text/javascript" src="../assets/js/vue.js"></script>
</head>
<body>
<h1>example03</h1>
<hr>
<div id="app">
{{num}}
<p><button @click="add">add</button></p>
</div>
<p><button onclick="reduce()">reduce</button></p>
<script type="text/javascript">
var app = new Vue({
el:'#app',
data:{
num:1
},
methods:{
add:function(){
this.num++;
}
}
});
app.$on("reduce",function(){
console.log("执行了reduce方法");
this.num--;
})
function reduce(){
app.$emit('reduce');
}
</script>
</body>
</html>
浏览器效果:
app.$once('reduceOnce',function(){
console.log('只执行一次的方法');
this.num--;
});
全部代码:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>example03</title>
<script type="text/javascript" src="../assets/js/vue.js"></script>
</head>
<body>
<h1>example03</h1>
<hr>
<div id="app">
{{num}}
<p><button @click="add">add</button></p>
</div>
<p><button onclick="reduce()">reduce</button></p>
<p><button onclick="reduceOnce()">reduceOnce</button></p>
<script type="text/javascript">
var app = new Vue({
el:'#app',
data:{
num:1
},
methods:{
add:function(){
this.num++;
}
}
});
app.$on("reduce",function(){
console.log("执行了reduce方法");
this.num--;
})
app.$once('reduceOnce',function(){
console.log('只执行一次的方法');
this.num--;
});
function reduce(){
app.$emit('reduce');
}
function reduceOnce(){
app.$emit('reduceOnce');
}
</script>
</body>
</html>
浏览器效果:
···
//关闭事件
function off(){
app.$off(‘reduce‘);
}
···
全部代码:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>example03</title>
<script type="text/javascript" src="../assets/js/vue.js"></script>
</head>
<body>
<h1>example03</h1>
<hr>
<div id="app">
{{num}}
<p><button @click="add">add</button></p>
</div>
<p><button onclick="reduce()">reduce</button></p>
<p><button onclick="reduceOnce()">reduceOnce</button></p>
<p><button onclick="off()">off</button></p>
<script type="text/javascript">
var app = new Vue({
el:'#app',
data:{
num:1
},
methods:{
add:function(){
this.num++;
}
}
});
app.$on("reduce",function(){
console.log("执行了reduce方法");
this.num--;
})
app.$once('reduceOnce',function(){
console.log('只执行一次的方法');
this.num--;
});
function reduce(){
app.$emit('reduce');
}
function reduceOnce(){
app.$emit('reduceOnce');
}
//关闭事件
function off(){
app.$off('reduce');
}
</script>
</body>
</html>
浏览器效果:
标签:例子 cti name body 作用 lis 名称 匿名 lang
原文地址:https://www.cnblogs.com/Elva3zora/p/12510155.html