To naprawdę przeszkadza mi. Proszę spojrzeć na Hello World example z knockout.js.Nie można pobrać najprostszej próbki knockout.js do pracy?
Oto mój kod:
<!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>
Wydaje się, że wiązanie nie działa. Jeśli I alert(viewModel.fullName());
otrzymam "Planeta Ziemia" zgodnie z oczekiwaniami. Ale ani elementy wejściowe, ani zakres nie zostaną wypełnione danymi.
Co robię źle?
Here jest plik ZIP, który zawiera zarówno mój plik i knockout.js
To nie wystarczy. I w tym przykładzie nie ma również parametr viewModel dla dependObservable – Sandro
Jakiej przeglądarki używasz? Używam Chrome: Mac i ja mamy tutaj swój dokładny kod: http://jsfiddle.net/3Appe/1/ – gislikonrad
@ GísliKonráð Wygląda na to, że twój kod działa na jsfiddle, ponieważ jest ustawiony na uruchom bibliotekę js przy obciążeniu. – Zack