我是一个整体(剑道 UI && MVVM)的新手。
我正在尝试将下拉列表与本地数据库绑定,并在标记为 //<<<<<<
我在这里做错了什么?- 我已经看到了 JayData 上可用的示例,但它并没有清楚地说明如何绑定本地数据库。
我的代码看起来像这样。
<div id="wrapper">
<div id="NESTForm">
<select data-role="dropdownlist" data-value-field="UserID" data-text-field="Name"
data-bind="source: userSource">
</select>
</div>
</div>
<script>
var userDB;
$(document).ready(function () {
$data.Entity.extend("Users",
{
UserID: { type: "int", key: true, required: true },
Name: { type: "string", required: true }
});
$data.EntityContext.extend("EXAMPLEDB", {
Users: { type: $data.EntitySet, elementType: Users }
});
userDB = new EXAMPLEDB({
name: "webSql", databaseName: "EXMPLEDB",
dbCreation: $data.storageProviders.DbCreationType.DropTableIfChange
});
var viewModel = kendo.observable({
//Initial data binders ,
userSource: userDB.Users.asKendoDataSource() //<<<<<< this throws error
});
// apply the bindings
kendo.bind(document.body.children, viewModel);
});
</script>
错误是
Uncaught TypeError: Object function (a,b){var c=this,d,e;c.trigger(w,{field:a}),a==="this"?d=c:(e=O[a]=O[a]||n.getter(a,!0),d=e(c),b&&typeof d=="function"&&(d=d.call(c)));return d} has no method 'push'