gpt4 book ai didi

javascript - KO - foreach 绑定(bind)似乎没有绑定(bind),但我无法解决

转载 作者:行者123 更新时间:2023-11-28 13:39:36 25 4
gpt4 key购买 nike

我正在学习Knockout JS的过程。我正在阅读 John Papa 关于 Pluralsight 的一些有关 Knockout 和 Javascript 的教程。

<div data-bind="text: people().length" class="label">部分似乎工作没有问题。然而 foreach 绑定(bind)似乎有问题。

我尝试过并做了什么:

  1. 我检查了 Javascript 代码和 Markpup,并将其与他的进行比较,发现没有任何区别。
  2. 我查看了 Chrome 中的开发者工具错误控制台。没有发生错误。
  3. 将简单的文本属性绑定(bind)到可观察对象,它可以工作。
  4. 将硬代码 observableArray 绑定(bind)到标记即可工作。

JS

    $(function () {
var Person = function (name) {
this.name = ko.observable(name);
};

var viewModel = (function () {
var p1 = new Person('Da Vinci');
var p2 = new Person('Michangelo');
var people = ko.observableArray([p1, p2]);
return {
people: people
};
})();

ko.applyBindings(viewModel);
});

HTML 标记

<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<title>Knockout</title>
<link href="../Content/bootstrap.css" rel="stylesheet" />
</head>
<body>
<h1>Hello Knockout!</h1>
<section>
Records:
<div data-bind="text: people().length" class="label">
<ul data-bind="foreach: people">
<li>
<span data-bind="text: name"></span>
</li>
</ul>
</div>
</section>
<script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1.10.2/jquery.min.js"></script>
<script type="text/javascript" src="http://ajax.aspnetcdn.com/ajax/knockout/knockout-2.2.1.js"></script>
<script src="../Js/ViewModel/AuthorCart.js"></script>
</body>
</html>

我得到以下结果,但我希望两个人的名字(“Da Vinci”和“Michangelo”)出现在记录下方。

你好 knockout !

记录:2

最佳答案

包含 div 上的 text 绑定(bind)会覆盖该元素的子元素,因此您的 foreach 消失了。

您需要先关闭容器:

  <div data-bind="text: people().length" class="label"></div>
<ul data-bind="foreach: people">
<li>
<span data-bind="text: name"></span>
</li>
</ul>

关于javascript - KO - foreach 绑定(bind)似乎没有绑定(bind),但我无法解决,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18746384/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com