javascript - 主干下划线版本错误

标签 javascript backbone.js underscore.js version

我刚刚开始学习如何制作带有 Backbone (和下划线)的单 View 应用程序。我阅读了教程,但是当我尝试复制 Backbone 应用程序的最基本版本并将其放在我的服务器上时,我收到了错误。代码没问题,但过了一会儿,我发现我的backbone.js 和 underscore.js 文件不能一起工作。 所以我从他们的网站下载了最新版本:仍然无法工作...... 我做错了什么?

感谢您的回答。

这是我的代码: 索引.html

<!DOCTYPE html>
  <html>
  <head>
    <meta charset="utf-8">
    <title>hello-backbonejs</title>
  </head>
  <body>
    <script src="https://ajax.googleapis.com/ajax/libs/jquery/1.6.1/jquery.min.js"></script>
    <script src="http://ajax.cdnjs.com/ajax/libs/json2/20110223/json2.js"></script>
    <script src="http://ajax.cdnjs.com/ajax/libs/underscore.js/1.1.6/underscore-min.js"></script>
    <script src="http://cdnjs.cloudflare.com/ajax/libs/backbone.js/1.1.0/backbone-min.js"></script>

    <script src="js/1.js" type="text/javascript"></script>
  </body>
  </html>

以及: js/1.js

$(function() {
    var ListView = Backbone.View.extend({
        el: $('body'), // attaches `this.el` to an existing element.

        initialize: function(){
            _.bindAll(this, 'render'); // fixes loss of context for 'this' within methods
            this.render(); // not all views are self-rendering. This one is.
        },
        render: function(){
            $(this.el).append("<ul> <li>hello world</li> </ul>");
        }
    });

    var listView = new ListView();
});

JQuery 和 Json2 工作正常。主干和下划线在这里 fork ,但我也尝试了最新版本。

编辑:

我现在尝试了下面的两行和最新版本的 JQuery:

<script src="http://ajax.cdnjs.com/ajax/libs/underscore.js/1.7.0/underscore-min.js"></script>
<script src="http://cdnjs.cloudflare.com/ajax/libs/backbone.js/1.1.0/backbone-min.js"></script>
<script type="text/javascript" src="js/jquery-1.11.2.js"></script>

但我仍然收到此错误:

[Error] TypeError: undefined is not a valid argument for 'instanceof' (evaluating 't instanceof a.$')
    setElement (backbone-min.js, line 1)
    _ensureElement (backbone-min.js, line 1)
    View (backbone-min.js, line 1)
    r (backbone-min.js, line 1)
    (anonyme Funktion) (1.js, line 14)
    fire (jquery-1.11.2.js, line 3143)
    fireWith (jquery-1.11.2.js, line 3255)
    ready (jquery-1.11.2.js, line 3467)
    completed (jquery-1.11.2.js, line 3498)

已解决:

谢谢大家。我刚刚在一个较新的 tut 中找到了一个组合,效果很好:

<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.9.1/jquery.min.js"></script>
<script src="http://documentcloud.github.com/underscore/underscore-min.js"></script>
<script src="http://documentcloud.github.com/backbone/backbone-min.js"></script>

最佳答案

 <script src="http://ajax.cdnjs.com/ajax/libs/underscore.js/1.7.0/underscore-min.js"></script>
 <script src="http://cdnjs.cloudflare.com/ajax/libs/backbone.js/1.1.0/backbone-min.js"></script>

只是你的下划线版本太旧,使用版本1.7.0。您正在使用的 Backbone 版本尝试使用_.has,它仅在下划线版本1.3.1

中引入

关于javascript - 主干下划线版本错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27912399/

相关文章:

javascript - 单击按钮时显示菜单,单击页面或按钮上的任意位置时隐藏菜单

javascript - 调用 Backbone View 中定义的下划线模板内的函数

javascript - 单页 Web 应用程序应该保持一个到服务器的 Web Socket 连接还是多个?

javascript - jQuery $(window).scroll 事件处理程序关闭但仍在触发?

javascript - Underscore.js - 从嵌套数组中删除项目?

javascript - 基于索引数组过滤数组

javascript - iOS 上的 JS formdata Chrome

javascript - 如何从服务每秒发送 $http.get 请求

javascript - 如何在 AJAX 调用后使用 javascript 设置选择下拉菜单的默认值

javascript - 未捕获的类型错误 : View is not a constructor