这真让我困扰。请看看knockout.js的Hello World example。无法获得最简单的knockout.js示例工作?
这里是我的代码:
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8" />
<title>Home Page</title>
<script src="knockout-1.2.1.debug.js" type="text/javascript"></script>
<script type="text/javascript">
// Here's my data model
var viewModel = {
firstName: ko.observable("Planet"),
lastName: ko.observable("Earth")
};
viewModel.fullName = ko.dependentObservable(function() {
// Knockout tracks dependencies automatically. It knows that fullName depends on firstName and lastName, because these get called when evaluating fullName.
return viewModel.firstName() + " " + viewModel.lastName();
});
ko.applyBindings(viewModel); // This makes Knockout get to work
</script>
</head>
<body>
<p>First name: <input data-bind="value: firstName" /></p>
<p>Last name: <input data-bind="value: lastName" /></p>
<h2>Hello, <span data-bind="text: fullName"> </span>!</h2>
</body>
</html>
看来,该绑定不起作用。如果我alert(viewModel.fullName());
我得到“行星地球”预期。但是输入元素和跨度都不会被数据填充。
我在做什么错?
Here是一个zip文件,其中包括我的两个文件,并knockout.js
这并没有诀窍。并且在该示例中,dependentObservable也没有viewModel参数 – Sandro
您使用的是哪种浏览器?我使用的是Chrome:Mac,我得到了你的确切代码在这里工作:http://jsfiddle.net/3Appe/1/ – gislikonrad
@GísliKonráð它看起来像你的代码工作在jsfiddle的原因是因为它设置为加载时运行js库。 – Zack