我目前正在使用最新版本的微风js(1.4.2),带有requirejs和knout。我有以下要求配置...
require.config({
paths:
{
"jquery": "../Scripts/jquery-1.10.2.min", //using jquery 1.x for older browsers
"bootstrap": "../Scripts/bootstrap.min",
"knockout": "../Scripts/knockout-2.3.0",
"knockoutMapping": "../Scripts/knockout.mapping-latest",
"toastr": "../Scripts/toastr.min",
"Q": "../Scripts/Q.min",
"es5-shim": "../Scripts/es5-shim.min",
"es5-polyfill": "../Scripts/es5-polyfill",
"breeze": "../Scripts/breeze.min",
"kendo": "../Scripts/kendo/2013.2.716/kendo.web.min",
"knockoutKendo": "../Scripts/knockout-kendo.min",
"globalize": "../Scripts/globalize/globalize",
"globalize-au": "../Scripts/globalize/cultures/globalize.culture.en-AU"
},
shim:
{
"jquery": { exports: "$" },
"knockout": { deps: ["jquery"] },
"Q": { deps: ["jquery", "knockout"] },
"breeze": { deps: ["knockout", "jquery", "Q", "es5-shim", "es5-polyfill"] },
"globalize-au": { deps: ["globalize"] },
"bootstrap": { exports: "Bootstrap", deps: ["jquery"] },
"kendo": { deps: ["jquery"] },
"knockoutKendo": { deps: ["knockout", "kendo"] },
"knockoutMapping": { deps: ["knockout"] }
}
});
查看网络流量,微风.min.js 在上面列出的所有依赖项之后加载,但我仍然得到微风查询返回的常规 JSON 对象,而不是像我预期的那样淘汰可观察属性。
如果我在 requirejs 之外添加淘汰脚本,在微风脚本之前使用标准脚本标签,那么一切正常。因此,这确实表明了我无法解决的依赖项和加载顺序首选项的问题。
这是我用来返回微风实体的示例查询。请注意,我当前的所有微风查询都返回具有不可观察属性的实体:
// Look for the log in manager"s cache first
// Fetch from the database if not found in the cache
return manager
.fetchEntityByKey("SqlLog", sqlLogId, true)
.then(function (data)
{
log("Retrieved [SQL DETAILS] from remote data source", data, true);
// using entity values here as breeze not returning observables.
sqlText(data.entity.SqlText);
parameters(data.entity.Parameters);
exceptionMessage(data.entity.ExceptionMessage);
})
.fail(queryFailed);