javascript - 使用vue.js要达到效果:点击li,获取当前点击li的html值,参数this变成变成了window对象?
本文介绍了javascript - 使用vue.js要达到效果:点击li,获取当前点击li的html值,参数this变成变成了window对象?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
问 题
要达到的效果:
点击li,获取当前点击li的html值;
主要代码
<body>
<div id="page">
<ul>
<li v-on:click="aa(this)" v-for="item in items">{{item}}</li>
</ul>
</div>
<script type="text/javascript">
new Vue({
el: '#page',
data: {
items:[11,22,33,44]
},
methods:{
aa:function(obj){
console.log(obj); //打印出来的是 window对象?
alert(obj.html()); //找不到点击的值;
}
}
})
</script>
</body>
问题描述:
点击li后传递的this打印出来是window对象,而不是li这个对象,所以找不到对象;怎么传递当前的li这个对象到js中呢?
解决方案
看文档的时候看的仔细一点……不要臆想这些莫名其妙的用法。
内联事件需要访问原始事件对象的时候,给里面加上$event
参数就行了。像这样:
<li v-on:click="aa($event)" v-for="item in items">{{item}}</li>
你要拿到当前li
标签的对象,读取事件对象下的currentTarget
属性就行了,即event.currentTarget
。
这篇关于javascript - 使用vue.js要达到效果:点击li,获取当前点击li的html值,参数this变成变成了window对象?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!
查看全文