Knockout.js mapping plugin with require.js

2019-06-25 18:54发布

什么是require.js加载映射插件的标准方式?

下面是我的config.js(require.js配置文件)

require.config({
    // Initialize the application with the main application file.
    deps: ["app"],

    paths:{
        // JavaScript folders.
        libs: "lib",
        plugins: "lib/plugin",
        templates: "../templates",

        // Libraries.
        jquery: "lib/jquery-1.7.2.min",
        underscore: "lib/lodash",
        text: 'text',
        order: 'order',
        knockout: "lib/knockout",
        knockoutmapping: "lib/plugin/knockout-mapping"

    },

    shim:{
        underscore:{
            exports: '_'
        },

        knockout:{
            deps: ["jquery"],
            exports: "knockout"
        }
    }
}

在我看来模型

define(['knockout', 'knockoutmapping'], function(ko, mapping) {
}

然而,映射未绑定到ko.mapping。 任何指针/建议将不胜感激。

谢谢你,拉维

Answer 1:

当与AMD使用的,映射插件出口它的功能到一个单独的对象。 因此,该功能将被连接到您的mapping变量,你会调用方法关闭它(如mapping.fromJS )。

您可以选择设置ko.mapping等于mapping在你的代码,如果你有依赖的代码ko.mapping ,你是无法改变的。



Answer 2:

您的配置对象可以指定一组依赖的,并且其中可以执行进一步的依赖性配置/操作的回调:

var require = {
  paths: {
    'knockout': '...',
    'mapping': '...'
  },

  // configuration dependencies

  deps: ['knockout', 'mapping'],

  // configuration callback

  callback: function (ko, mapping) {
    ko.mapping = mapping;
  }
};

当您在标记你的脚本,配置应要求之前加载:

<script src="/scripts/config.js" />
<script src="/scripts/require.js" />

现在,Knockout.js将可与ko.mapping在模块定义中使用时,作为所期望的性质。

define(['knockout'], function (ko) {
  // ko.mapping is available
});

请注意,这是一个简化的配置示例。 有需要的映射插件指定正确的出口,只是不记得了我的头顶是什么一些匀场。



Answer 3:

在一个侧面说明,因为使用的是罗短跑你不需要包括“下划线”在RequireJS“垫片”选项。 罗短跑具有出炉AMD的支持。



文章来源: Knockout.js mapping plugin with require.js