TypeError xxx不是一个函数
TypeError xxx is not a function
所有,我正在努力解决一个错误,上面写着TypeError: curTemplete.addSection is not a function
,请原谅我不熟悉js OO,请帮助审查我的问题。谢谢。
代码如下所示:
Templete.js
LayoutTemplete=function(currentTmpContainer,templeteId,data)
{
var curTemplete = this;
curTemplete.addSection(null, null);//this line run with error above.
this.addSection = function(uiItem, data) {
alert('ddd');
};
};
在dom就绪事件.
function loadTempleteContent(templeteId)
{
var jData=[{name: 'jerry'},{name: 'mike'},{name: 'claire'}];
var tmp = new LayoutTemplete($("#currentTmpContainer"),templeteId,jData);
}
不能调用未定义的函数。这与OOP无关。考虑这个例子:
foo();
var foo = function() {
alert(42);
};
会抛出类似的错误。
在访问之前定义函数/属性:
this.addSection = function(uiItem, data) {
alert('ddd');
};
this.addSection(null, null);
更好的是,在原型上定义addSection
,这样您就不必每次创建LayoutTemplete
的实例时都创建一个新函数。
LayoutTemplete = function(currentTmpContainer,templeteId,data) {
this.addSection(null, null);
};
LayoutTemplete.prototype.addSection = function(uiItem, data) {
alert('ddd');
};
Felix试图告诉你你的问题是什么,这里是明确的:
var curTemplete = this;
curTemplete.addSection(null, null);//this line run with error above.
这里你引用并尝试调用curTemplete.addection
,它还没有被赋值,所以它解析为undefined
。当尝试调用时,undefined不是一个函数(正如错误告诉您的那样)。addSection
直到下面的赋值才被定义:
this.addSection = function(uiItem, data) {
alert('ddd');
};
现在它被定义了。在调用之前移动赋值(如果要将this
赋值给一个局部变量,也可以使用它):
var curTemplete = this;
curTemplete.addSection = function(uiItem, data) {
alert('ddd');
};
curTemplete.addSection(null, null);
相关文章:
- 我可以在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-添加添加和删除类与下一个函数之间的延迟