我在使用 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);
为了构建我的捆绑包,我正在使用
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"});
我收到一个错误
“无法读取未定义的属性‘延迟’”
堆栈跟踪
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 捆绑包的一部分,那么 Backbone 将无法将其连接到 jQuery 吗?
非常感谢任何提示。