javascript - 如何在 CommonJS 模块配置中设置 Backbone.$?

标签 javascript backbone.js

我正在浏览下面从 http://backbonejs.org/backbone.js 复制的 Backbone.js 源代码

(function(root, factory) {

  // Set up Backbone appropriately for the environment. Start with AMD.
  if (typeof define === 'function' && define.amd) {
    define(['underscore', 'jquery', 'exports'], function(_, $, exports) {
      // Export global even in AMD case in case this script is loaded with
      // others that may still expect a global Backbone.
      root.Backbone = factory(root, exports, _, $);
    });

  // Next for Node.js or CommonJS. jQuery may not be needed as a module.
  } else if (typeof exports !== 'undefined') {
    var _ = require('underscore');
    factory(root, exports, _);

  // Finally, as a browser global.
  } else {
    root.Backbone = factory(root, {}, root._, (root.jQuery || root.Zepto || root.ender || root.$));
  }

}(this, function(root, Backbone, _, $) {

  // Initial Setup
  // -------------

  // Save the previous value of the `Backbone` variable, so that it can be
  // restored later on, if `noConflict` is used.
  var previousBackbone = root.Backbone;

  // Create local references to array methods we'll want to use later.
  var array = [];
  var push = array.push;
  var slice = array.slice;
  var splice = array.splice;

  // Current version of the library. Keep in sync with `package.json`.
  Backbone.VERSION = '1.1.2';

  // For Backbone's purposes, jQuery, Zepto, Ender, or My Library (kidding) owns
  // the `$` variable.
  Backbone.$ = $;

在 CommonJS/node.js 配置中,它说 Next for Node.js 或 CommonJS。 jQuery 可能不需要作为一个模块。 并调用 factory(root, exports, _) 并使用未定义的 jquery 的第四个 $ 参数。在工厂函数中它是 Backbone.$ = $ 所以 Backbone.$ 是未定义的?那么很多东西(AJAX、$el 包装等)不会中断吗?

最佳答案

使用 jQuery 的主要原因是为了处理 DOM 操作,而这在后端 (nodejs) 中是无用的,因此无需将其作为依赖项加载。要解决这个问题,您可以创建一个简单的模块,用 jQuery 返回 BackboneJS。

// libs/backbone.js
var backbone = require("backbone");
backbone.$ = require("jquery");
module.exports = backbone;

关于javascript - 如何在 CommonJS 模块配置中设置 Backbone.$?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25924595/

相关文章:

javascript - 从一个 View 触发事件到另一个 View

backbone.js - 何时使用 Backbone.View 与 Backbone.Marionette.ItemView?

javascript - Angular JS - 如何将 JSON 值转换为 JSON 键?

javascript - 从 http get 请求 Angular7 获取结果

javascript - jquery 点击功能不工作

node.js - model.save() 的 Backbone.js/express.js 参数

javascript - 页面在 DELETE 请求完成之前呈现

javascript - 如何制作单击按钮时显示的加载动画?它应该占据全屏并且应该从右到左并消失

javascript - 如何区分 Javascript 中的扫描仪输入和键盘输入?

javascript - 使用backbone.js获取集合,但未设置每个模型的id