0

我安装了热毛巾。修改后的Shell.html如下

<section id="content" >
     <!--ko compose: {view: 'master'} --><!--/ko-->
</section>

master.html文件中,我调用另一个名为search.html的 html 文件

<section >
        <div id="SearchDetails">
            <section>
                 <!--ko compose: {view: 'search'} --><!--/ko-->
            </section>

        </div>

它加载 search.html 很好。但它没有调用我的restservice,我已经编写了search.js,如下所示

define(['services/dataservice'], function (dataservice) {
var productVersionData = ko.observableArray();
var initialized = false;
var vm = {
    activate: activate,
    productVersionData: productVersionData

};
return vm;

function activate() {
    alert(" i am hit");
    if (initialized) { return; }
    initialized = true;
    return refresh();
}

function refresh() {
    return dataservice.getProductVersionPartials(productVersionData);
}

});

在我的shell.js 中,我正在调用所有视图模型,如下所示

define(['durandal/system', 'durandal/plugins/router', 'services/logger'],
function (system, router, logger) {
    var shell = {
        activate: activate,
        router: router
    };

    return shell;

    //#region Internal Methods
    function activate() {
        return boot();
    }

    function boot() {
        router.mapNav('master');
        router.mapNav('search');
        log('Hot Towel SPA Loaded!', null, true);
        return router.activate('master');
    }

    function log(msg, data, showToast) {
        logger.log(msg, data, system.getModuleId(shell), showToast);
    }

});

我将调试器语句、console.log 语句放在search.js中,但它并没有以某种方式加载 search.js。这就是为什么它没有调用我在 dataservice 中定义的服务。可能是什么问题?

4

1 回答 1

1

您的问题是您在内容部分的shell.html文件中所做的更改。进行以下更改,您的 404 应该会消失:

<section id="content" class="main container-fluid">
    <!--ko compose: {model: 'viewmodels/master', activate: true} -->
    <!--/ko-->
</section>

我不熟悉您使用的config.js模式,但我认为您想回到使用路由器动态设置shell.htmlmodel中的参数并在 shell 中配置激活的路由热毛巾模板附带的js函数。 boot

于 2013-06-06T18:27:57.857 回答