10

我正在尝试使用 require 在 noConflict 模式下加载 jquery

require.config({
    paths: {
        'jquery': 'libs/jquery-req',
        underscore: 'libs/underscore',
        backbone: 'libs/backbone'
    },
    shim: {
        jquery: {
            init: function() {
                console.log('jq init');
                var jq = this.jQuery.noConflict(true);
                jq.support.cors = true;

                return jq;
            },
            exports: '$'
        },
        backbone: {
            deps: ['underscore', 'jquery'],
            init: function() {
                console.log('b init');
            },
            exports: 'Backbone'
        },
        underscore: {
            exports: '_'
        }
    }
});

并像这样使用它:

define([
    'jquery',
    'underscore',
    'backbone'
], function(jq, _, Backbone) {
    console.log(jq);
    var initialize = function() {
//        Router.initialize();
    };

    return {
        initialize: initialize
    };
});

不幸的是,似乎从未调用过 shim.jquery.init 函数。有人可以帮我理解为什么吗?当我重命名 jquery -> jquery-reg 时奇怪的是它似乎可以工作,但它需要更改每个文件中定义的依赖项。

4

2 回答 2

24

创建以下 noconflict.js 模块:

define(["jquery"], function($) {
  //drop the `true` if you want jQuery (but not $) to remain global
  return $.noConflict(true); 
});

然后,在你的 require.config 添加:

map: {
  "*": {
    "jquery": "noconflict"
  },
  "noconflict": {
    "jquery": "jquery"
  }
}

jQuery 的 noconflict 版本将交给所有模块(noconflict 除外)。摆脱 jQuery 垫片。

请注意,将 jQuery 排除在全局命名空间之外会阻止您使用任何非 AMD 的 jQuery 插件,而无需将这些插件修改为 AMD 模块。Shim 没有做任何神奇的事情来利用这个设置。对于您可能想要填充的任何非 AMD 模块也是如此,这取决于您制作“纯”AMD 的东西。

于 2013-06-07T02:52:56.387 回答
0

我正在使用这个:

require.config({
    paths: {
        jquery: 'libraries/jquery/jquery.min',
        underscore: 'libraries/underscore.min',
        backbone: 'libraries/backbone.min',
        jquery_ui: 'libraries/jquery/jquery.ui.min',
    },

    shim: {
        'backbone': {
            deps: ['underscore', 'jquery'],
            exports: 'Backbone'
        },
        'underscore': {
            exports: '_'
        },
        'jquery_ui': {
            deps: ['underscore', 'jquery'],
            exports: 'ui'
        }
    }
});

然后在我的应用程序中,我使用本地范围来定义 jquery 的实例。在下面的例子中 $ 是 jquery,但它也可以是别的东西。

define([
    'jquery', 
    'backbone'
    ], function ($, Backbone) {

    'use strict';

    var app = Backbone.View.extend({
        el: 'body',

        initialize: function() { },

    });

    return app;

});
于 2013-04-09T14:18:30.373 回答