TypeError:this.getAttribute不是一个函数-javascript
TypeError: this.getAttribute is not a function - javascript
我不明白为什么我不能在下面的代码中获得"this"的属性:
var Deferjs = {
init: function(){
if(document.getElementById('js-currentPage')!=null){
var file = this.getAttribute('data-page');
Deferjs.LoadJs(file);
}
},
LoadJs:function(file){
alert("ok");
}
}
Deferjs.init();
但是,如果我改变this.getAttribute('data-page');到document.getElementById('jscurrentPage').getAttribute它工作于
请帮助我理解以上
thx
如果要重用document.getElementById('js-currentPage')
,请将其保存在变量中。在this
指向容器对象(DeferJs
)的情况下,不能用this
引用它
init: function(){
var elem=document.getElementById('js-currentPage');
if(elem!=null){
var file = elem.getAttribute('data-page');
Deferjs.LoadJs(file);
}
}
if(document.getElementById('js-currentPage')!=null){
var file = this.getAttribute('data-page');
这里this
将指代Deferjs
。相反,如果要在其他位置访问变量,则必须将对DOM的引用存储到该变量。
var ele = document.getElementById('js-currentPage');
if(ele!=null){
var file = ele.getAttribute('data-page');
您的init函数位于Deferjs中,因此,当您使用"this"时,它指的是Deferjs。Deferjs没有名为getAttribute的函数。你需要使用
document.getElementById('js-currentPage').getAttribute(...)
DOM 实际上提供了一组API来访问HTML元素,并且这个指针指向对象的范围,该对象只能访问属性>类、ID、样式等。
在对象的作用域中,也就是说,您可以通过对象属性访问(this.data-message)。但是,在对象的范围中有没有getAttribute()方法,所以您不能使用this.getAttribute(
相关文章:
- 我可以在json对象中添加一个函数吗
- 如何在JQuery函数中定义一个值,然后调用另一个函数并使用该值
- 是否可以将一个函数输入连接到另一个函数调用的文本
- 在另一个函数中使用变量this
- 在另一个函数成功结束后调用该函数
- mongoose.connect undefined不是一个函数
- 监听器必须是一个函数
- 使用JS函数来使用另一个函数的语法?node.js
- 如何取消object.prototypes javascript的一个函数
- 从Chrome扩展名中的popup.html文件在background.js文件中运行一个函数
- 嵌套到另一个函数中的Fancybox函数;不起作用
- 如何在javascript中使用不止一个函数
- jQuery-在页面加载时执行一个函数
- jquery UI draggable:UI.children不是一个函数
- jQuery Mobile Undefined不是一个函数
- 如何在php中创建一个函数,该函数与文本区域一起工作,通过输入类似[color:red]的内容来打印具有等效颜色的文本
- javascript函数将数据添加到屏幕,但随后被另一个函数覆盖
- JS异常:animate不是一个函数
- 如何将一个函数附加到一个不存在的元素上
- JavaScript/jQuery-添加添加和删除类与下一个函数之间的延迟