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属性。只要确保最后一个具有真正导出功能的模块之后的所有“无导出”模块都位于末尾即可。