我正在编写一个小型 javascript 游戏...设置游戏时间,我有一个变量来保存当前游戏中的日期和时间,我想显示这个日期和每秒,将该日期增加几小时。
我正在使用 JSViews 进行数据绑定,它在应用程序中运行良好,除了那个日期,我不明白!我创建了一个代表这个想法的 JSFiddle:
http://jsfiddle.net/ClaudeVernier/w8cwkarr/5/
try {
var tmplDates = $.templates("#tmplDates");
tmplDates.link("#gameSet", model);
gameLoop();
}
catch(e) {
alert(e);
}
我有一个带有日期和整数的数据模型。我有一个使用转换器显示数据模型的模板
<script id="tmplDates" type="text/x-jsrender">
<hr /> <span data-link="{toDateString:gameDate}"></span>
<hr /> <span data-link="{toTimeString:gameDate}"></span>
<hr /> <span data-link="{toString:gameInt}"></span>
</script>
每秒钟,我都会使用 Observable 方法更新日期和整数。整数会更新,但日期不会更新!
function gameLoop() {
var tDate = model.gameDate;
tDate.addHours(4);
$.observable(model).setProperty("gameDate", tDate);
var tInt = model.gameInt + 1;
$.observable(model).setProperty("gameInt", tInt);
$("#lastUpdate").text( gameDateString(model.gameDate, 0) + "-" + gameDateString(model.gameDate, 6) + " - [" + model.gameInt + "]");
window.setTimeout(gameLoop, 1000);
}
我添加了一行我在没有数据绑定的情况下写入值以显示值已更新..