javascript - 使用vue.js要达到效果:点击li,获取当前点击li的html值,参数this变成变成了window对象?
曾经蜡笔没有小新
曾经蜡笔没有小新 2017-06-14 10:54:14
[JavaScript讨论组]

要达到的效果:

  • 点击li,获取当前点击li的html值;

主要代码

<body>
<p id="page">
    <ul>
        <li v-on:click="aa(this)" v-for="item in items">{{item}}</li>
    </ul>
</p>
<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中呢?

曾经蜡笔没有小新
曾经蜡笔没有小新

全部回复(4)
高洛峰

看文档的时候看的仔细一点……不要臆想这些莫名其妙的用法。

内联事件需要访问原始事件对象的时候,给里面加上$event参数就行了。像这样:

<li v-on:click="aa($event)" v-for="item in items">{{item}}</li>

你要拿到当前li标签的对象,读取事件对象下的currentTarget属性就行了,即event.currentTarget

女神的闺蜜爱上我
<li @click="aa(item)" v-for="item in items">{{item}}</li>
aa(item) {
  console.log(item) // 当前li的内容
}
ringa_lee

给li加个ref属性 然后在methods中通过this.$refs拿到dom节点

typecho

测试可行:

<li @click="aa($event)" v-for="item in items">{{item}}</li>
  methods:{
    aa:function(event){
        console.log(event.target.innerHTML);
    }
  }
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号