我的应用程序是一个使用 Hot Towel 模板(durandal.js、knockout.js、require.js)的单页应用程序。我正在尝试使用锚点更改为另一个视图,但它不起作用。我在带有敲除的锚标记中使用数据绑定(attr 属性)并调用 showAbout 方法。这是我的html-
<li><a data-bind="attr: { href: showAbout }">About</a></li>
我的 shell.js 视图模型 -
define(['durandal/system', 'durandal/plugins/router', 'services/logger', 'services/SecurityDataService'],
function (system, router, logger, SecurityDataService) {
var HasAccess = ko.observable();
var vm = {
activate: activate,
router: router,
User: ko.observable(),
showAbout: showAbout
};
return vm;
function showAbout() {
router.map([
{ url: 'About', moduleId: 'viewmodels/About', name: 'About', visible: false }
]);
return router.activate('About'); // should show about view
}
function activate() {
$.when($.getJSON('/api/security', function(data) {
strHasAccess = "";
if (typeof (data) == "string") {
strHasAccess = $.parseJSON(data);
HasAccess = strHasAccess[0].HasAccess;
vm.User = strHasAccess[0].UserName;
$('#spnUserName').text(vm.User);
} else {
HasAccess = false;
}
return strHasAccess;
})).then(function (HasAccess) {
if (strHasAccess[0].HasAccess == true) {
router.mapNav('home');
router.mapNav('CAApproval');
vm.User = strHasAccess[0].UserName;
return router.activate('home');
}
else {
router.map([
{ url: 'AccessDenied', moduleId: 'viewmodels/AccessDenied', name: 'AccessDenied', visible: false }
]);
return router.activate('AccessDenied'); // should show details page of a particular folder
log('Access Denied!', null, true);
}
});
}
function log(msg, data, showToast) {
logger.log(msg, data, "shell.js", showToast);
}
});
当我将鼠标悬停在锚点上时,我看到了整个激活函数,而不是我期待的 #/about。这里有什么问题?