javascript – 事件处理程序出错:“this.data()不是函数”

栏目: jQuery · 发布时间: 7年前

内容简介:翻译自:https://stackoverflow.com/questions/32212029/error-in-event-handler-this-data-is-not-a-function
我有一个 HTML

列表,每个链接都有data- …属性:

<ul id="list">
    <li><a data-info="link1"> **** </a></li>
    <li><a data-info="link2">****</a></li>
    <li><a data-info="link3">**** </a></li>
    <li><a data-info="link4">****</a> </li>
</ul>

我需要在点击链接时收到链接的数据信息值.所以我想到这样的事情:

var my_links = $('#list').find('a');

my_links.on('click', function(){
     console.log(this.data(info));
});

但后来我得到:

Uncaught TypeError: this.data is not a function

如果我这样做:

var my_links = $('#list').find('a');

my_links.on('click', function(){
  console.log(this);
});

我得到每个链接的完整HTML代码,例如:

<a data-info="link1"> **** </a>

为什么两件事都在发生,我该如何解决?

data()是一个jQuery方法,而不是本机DOM对象的方法.

这将是<a>单击的元素 – 本机DOM对象( HTMLAnchorElement ).给它一个jQuery包装器来调用jQuery方法:

my_links.on('click', function() {
  console.log( $(this).data('info') );
});

(并注意你没有信息变量 – 你正在寻找字符串’info’访问的数据)

翻译自:https://stackoverflow.com/questions/32212029/error-in-event-handler-this-data-is-not-a-function


以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

Egret——HTML5游戏开发指南

Egret——HTML5游戏开发指南

张鑫磊 等 / 电子工业出版社 / 2016-3 / 85

《Egret——HTML5游戏开发指南》由浅入深,在讲解游戏开发基础的同时提供众多实战案例供读者学习。《Egret——HTML5游戏开发指南》章节内容包含Egret基础概念及基础图形图像处理方法、网络相关操作、移动设备适配、性能优化、文本动画相关知识、调试技巧、DragonBones骨骼动画系统和P2物理引擎等。通过《Egret——HTML5游戏开发指南》,读者可以了解并掌握HTML5游戏开发技能......一起来看看 《Egret——HTML5游戏开发指南》 这本书的介绍吧!

JSON 在线解析
JSON 在线解析

在线 JSON 格式化工具

RGB转16进制工具
RGB转16进制工具

RGB HEX 互转工具

正则表达式在线测试
正则表达式在线测试

正则表达式在线测试