Весь мой код работает задолго до того, как я добавил удалить функциональность этого демо-кода. Хотя я называю это привязкой с $root
, но он дает ту же ошибку. Я также прилагаю скриншот ошибки, которую я получаю.Невозможно обработать привязку foreach с не может прочитать свойство
//my product class
function Product(name, price) {
this.name = ko.observable(name);
this.price = ko.observable(price);
};
//my observable array
this.shoppingCart = ko.observableArray([
new Product("milk", 10.99),
new Product("bread", 7.99),
new Product("Jam",1.39)
]);
//below is my view model
function personViewModel() {
var self = this;
firstName= ko.observable("John");
lastName = ko.observable("Smith");
checkOut = function() {
alert("Trying to Checkout");
};
fullName = ko.computed(function() {
return firstName() + " " + lastName();
})
this.addProduct = function() {
self.shoppingCart.push(new Product("Yogurt", 10.99));
};
//this method is bind with the button and producing error
this.removeProduct = function (product) {
self.shoppingCart.remove(product)
};
};
ko.applyBindings(personViewModel);
<!-- language: lang-html -->
<script src="https://cdnjs.cloudflare.com/ajax/libs/knockout/3.1.0/knockout-min.js"></script>
<body>
<h1>Hello, Knockout.js</h1>
<p><span data-bind='text: fullName'></span>'s Shopping cart</p>
<button data-bind="click: checkOut">Checkout</button>
<table>
<thead>
<tr>
<th>Product</th>
<th>Price</th>
</tr>
</thead>
<tbody data-bind="foreach: shoppingCart">
<tr>
<td data-bind="text: name"></td>
<td data-bind="text:price"></td>
<!--below binding is breaking the script-->
<td><button data-bind="click: $root.removeProduct">Remove</button></td>
</tr>
</tbody>
</table>
<button data-bind="click: addProduct">Add Item</button>
</body>
<!-- end snippet -->
Вы пропускаете 'new' в операторе:' ko.applyBindings (personViewModel), '' должны быть ko.applyBindings (new personViewModel); ' – nemesv
@nemesv, если я прокомментирую функцию removeProduct и привязку $ root.removeProduct, я могу добавлять продукты в свою корзину. Я попробовал ko.applyBindings (новый personViewModel); Единственное, что у меня есть, - это весь мой список продуктов в представлении, но я не могу добавлять и удалять продукты, а измененная ошибка - «Неподготовлено TypeError: невозможно прочитать свойство« удалить »неопределенного». – satyanshu
Ваш код довольно перепутался: вы не всегда используете 'this' и' self', и вы пропускаете их из нескольких мест, что приводит к глобально определенным объектам и т. Д. Вот фиксированная версия: http: // jsfiddle. net/y7wrjywn/ – nemesv