main.js:

 requirejs.config({
   enforceDefine: true,
   paths: {
     "jquery": "libs/jquery/jquery-min",
     "underscore": "libs/underscore/underscore-min",
     "backbone": "libs/backbone/backbone-min",
     "jquery.pnotify":"libs/jquery/jquery.pnotify.min"

},
shim: {
   "underscore": {
       deps: [],
       exports: "_"
    },
   "backbone": {
       deps: ["jquery", "underscore"],
       exports: "Backbone"
    },
   "jquery.pnotify" : {
       deps : ["jquery"],
       exports : "jQuery.fn.pnotify"
    }
  }
});


查看:

define(["jquery" ,
       "underscore" ,
       "backbone" ,
       "jquery.pnotify",
       "models/CartModel" ,
        ],function($ , _ , Backbone , Cart ){

var CartView = Backbone.View.extend({
    initialize: function() {
        this.updateQtyLabel("qtyCart");
    },
    el: '.addToCart-form',
    events : {
        "click #addToCart" : "addToCart"
    },
    addToCart : function (){
        $.pnotify({
            title: 'Go to Cart and Check Out',
            text: '1 item added to Cart',
            shadow:false,
            delay:1000
        });
    },
    render: function(){

    }
});
return CartView;
});


我收到一个错误Uncaught Error: No define call for jquery.pnotify

任何帮助深表感谢。

最佳答案

您已导入pnotify,但未为其声明变量。更改

function($ , _ , Backbone , Cart ){




function($ , _ , Backbone , pnotify, Cart ){


请注意,实际上调用变量并不重要,因为您将永远不会使用它。严格来说,您甚至不需要定义变量-jQuery插件仅存在于您已经定义的jQuery名称空间中-除了使用enforceDefine = true之外。但是,如果要删除该属性,则也可以删除填充程序配置上的exports属性。只要确保最后一个具有真正导出功能的模块之后的所有“无导出”模块都位于末尾即可。

09-20 03:15