javascript - 如何使用 browserify 捆绑主干应用程序?

标签 javascript node.js backbone.js browserify

我在使用 browserify 时遇到了一点问题。

目标

我正在尝试使用 Backbone 构建基本的 TodoMVC 单页应用程序,而不是 <script> 的堆。我的 index.html 中的标签,我正在尝试将它们与 browserify 捆绑在一起。

这是我到目前为止所做的。

lib/models/todo.js

var backbone = require("backbone");

var Todo = module.exports = backbone.Model.extend({

  defaults: function() {
    return {
      title: "",
      completed: false,
      createdAt: Date.now(),
    };
  },

});

lib/collections/todo.js

var backbone     = require("backbone"),
    LocalStorage = require("backbone.localstorage");

var TodoCollection = module.exports = backbone.Collection.extend({

  localStorage: new LocalStorage('todomvc'),

});

lib/app.js

var Todo            = require("./models/todo"),
    TodoCollection  = require("./collections/todo");

(function(global) {

  global.todoCollection = new TodoCollection([], {model: Todo});

})(window);

为了构建我的 bundle ,我正在使用

browserify lib/app.js > js/app.js

最后,我的index.html很简单

<!doctype html>
<html>
  <head>
    <meta charset="UTF-8">
    <title>Todo MVC</title>
  </head>
  <body>
    <script src="//ajax.googleapis.com/ajax/libs/jquery/2.0.3/jquery.min.js"></script>
    <script src="/js/app.js"></script>
  </body>
</html>

问题

当我打开控制台并尝试运行此命令时

todoCollection.create({title: "My first todo"});

我收到一个错误

"Cannot read property 'Deferred' of undefined"

堆栈跟踪

TypeError: Cannot read property 'Deferred' of undefined
    at Backbone.LocalStorage.sync.window.Store.sync.Backbone.localSync (http://localhost:4000/js/app.js:182:47)
    at Backbone.sync (http://localhost:4000/js/app.js:255:40)
    at _.extend.sync (http://localhost:4000/js/app.js:1773:28)
    at _.extend.save (http://localhost:4000/js/app.js:1979:18)
    at _.extend.create (http://localhost:4000/js/app.js:2370:13)
    at <anonymous>:2:16
    at Object.InjectedScript._evaluateOn (<anonymous>:580:39)
    at Object.InjectedScript._evaluateAndWrap (<anonymous>:539:52)
    at Object.InjectedScript.evaluate (<anonymous>:458:21)

问题

我已经对如何浏览主干应用程序进行了大量搜索,但我几乎没有找到符合我目标的东西。

如何将我的单页主干应用程序捆绑到一个 app.js 中我可以在 html 中要求吗?

顺便说一句

我也不确定我是否正确地包含了 jQuery。如果 Backbone 也不是我的 browserified bundle 的一部分,那么 Backbone 是否会无法连接到 jQuery?

非常感谢任何提示。

最佳答案

编辑:

最新版本的 jquery 已通过 npm 分发和使用!这使得在 browserify 中使用 jquery 更加简单。

我们现在需要做的就是安装软件包:

npm install jquery backbone

并且需要模块:

var $ = require('jquery');
var Backbone = require('backbone');
Backbone.$ = $;

旧答案:

我用过 jquery-browserify模块成功。

运行 npm install jquery-browserify 主干

在名为 app-view.js 的文件中创建 View 模块:

var Backbone = require('backbone');
var $ = require('jquery-browserify');
Backbone.$ = $;

module.exports = Backbone.View.extend({
  initialize: function(){
    this.render();
  },

  render: function(){
    console.log('wuuut')
    $('body').prepend('<p>wooooooooooooooo</p>');
  }
});

使用模块:

var AppView = require('./app-view')

var appView = new AppView();

您可以像在代码中一样将 jquery 保留在脚本标记中,而不是使用 jquery-browserify,但在这种情况下,而不是这样:

var $ = require('jquery-browserify');
Backbone.$ = $;

我会这样做:

var $ = Backbone.$ = window.$;

关于javascript - 如何使用 browserify 捆绑主干应用程序?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19747500/

相关文章:

javascript - 如何将 fullcalender 数据导出为 iCal 格式?

javascript - 在 Electron 应用程序中为 TypeScript 编译器选择哪个 ECMAScript 版本?

javascript - 如何将数据从 express 传递到我的 hbs View

javascript - 从特定 Javascript 生成 v4 UUID

javascript - javascript 中的面向对象编程 : is it good practice to have attributes being objects themselves?

javascript - new Backbone.Router.extend ...在没有括号的情况下使用它时的区别

javascript - axios 不会分别返回响应和错误

php - 将 php/mysql 值传递给 div,可通过 javascript 访问

node.js - 缺少 `pino-pretty` 模块 : `pino-pretty` must be installed separately

javascript - 如何通过获取获取添加到 Backbone 集合的项目的索引?