gpt4 book ai didi

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

转载 作者:IT老高 更新时间:2023-10-28 23:15:08 26 4
gpt4 key购买 nike

我在使用 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/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com