我正在尝试使用ASMVC3的“剃刀”视图引擎来实现this Knockout example。
第一个主题介绍了使用标准C#视图引擎的简单数据绑定。我正在使用"Razor“尝试这个示例,下面这行代码:
<script type="text/javascript">
var initialData = <%= new JavaScriptSerializer().Serialize(Model) %>;
</script>
导致initialData的变量为空。
我还尝试了这个:
@{
string data = new System.Web.Script.Serialization.JavaScriptSerializer().Serialize(Model);
}
然后像这样指定initialData:
var initialData = @Html.Raw(data);
这将使用dataset填充initialData,但绑定不起作用。
我只是尝试对这个集合进行数据绑定,以便显示想法的计数,如下面的示例所示:
<p>You have asked for <span data-bind="text: gifts().length"> </span> gift(s)</p>
为什么数据绑定在这个实例中不起作用?
发布于 2011-05-04 04:12:53
在MVC3中,最简单的方法是:
var initialData = @Html.Raw(Json.Encode(Model));
发布于 2011-09-03 10:01:05
我遇到了同样的问题,发现是我自己的愚蠢导致了这个问题(它经常是这样的)。我忘了等到DOM加载后才调用ko.applyBindings(viewModel)
--所以只需使用:
$(document).ready(function () { ko.applyBindings(viewModel); });
所以整个脚本是这样的
<script type="text/javascript">
var initialData = @Html.Raw( new JavaScriptSerializer().Serialize(Model));
var viewModel = {
gifts: ko.observableArray(initialData)
};
$(document).ready(function () { ko.applyBindings(viewModel); });
</script>
这适用于knockout-1.2.1.js和jquery-1.5.1.js
https://stackoverflow.com/questions/5873636
复制相似问题