我正在编写第一次展示原型模式的javascript代码。我有问题。当我在用户点击添加按钮时调用添加功能时,它会在控制台中显示此错误。
Uncaught TypeError: Cannot call method 'add' of undefined
我该如何解决这个问题?
这是我的script.js代码
$(function () {
var todo = Todo('contents');
$('.addBtn').on('click', function() {
var name = $(this).parent().find('input[type="text"]').val();
todo.add(name);
});
$('.contents').on('click', '.remove', function() {
var el = $(this).parent();
todo.remove(el);
});
$('.contents').on('click', '.update', function() {
var dom = $(this);
todo.addUpdateField(dom);
});
$('.contents').on('click', '.updateBtn', function() {
var el = $(this);
todo.update(el);
});
});
这是我的todo.js代码
var Todo = function(c) {
this.contents = $('.' + c);
};
Todo.prototype = function() {
var showel = function (d) {
this.contents.prepend(d);
},
add = function (name) {
if(name != "") {
var div = $('<div class="names"></div>')
.append('<span>' + name + '</span>')
.append("<button class='update' class='update'>Edit</button>")
.append("<button class='remove' name='remove'>Remove</button>");
}
return showel(div);
},
addUpdateField = function (dom) {
var name = dom.parent().find('span').text(),
field = $('<input type="text" value="' + name + '" />'),
update = $('<button class="updateBtn">Update</button>');
dom.parent().html('').append(field).append(update);
return;
},
update = function(el) {
var val = el.parent().find('input').val();
el.parent().html('<span>' + val + '</span>')
.append('<button class="update" class="update">Edit</button>')
.append('<button class="remove" class="remove">Remove</button>');
return;
},
remove = function (el) {
return el.remove();
};
return {
add : add,
update : update,
remove : remove,
addUpdateField : addUpdateField
};
}();
更新
改变之后
var todo = Todo('contents');
到
var todo = new Todo('contents');
我收到此错误
Object [object Object] has no method 'add'
更新2
这是我的jsfiddle
答案 0 :(得分:3)
你没有正确构建你的对象,所以它没有任何原型:
var todo = Todo('contents');
应该是:
var todo = new Todo('contents');
以下是SO question解释忘记new
时发生的情况。
编辑:你定义原型函数的方式是弄乱上下文(this
指向的内容)。尝试这样的模式:
Todo.prototype = {
method1: function () { ... },
method2: function () { ... }
};
答案 1 :(得分:1)
您正在尝试将Todo
的{{1}}分配给自助调用功能。但是,原型只是被分配给一个函数而不是预期的返回对象。
这是你的工作fiddle。我用您的方法将原型直接分配给了一个对象。
此外,JS从上到下进行解析。因此,在声明prototype
之后,请定义Todo
的新实例。
这就是自我调用函数的样子:
Todo