I'm getting Model not defined error with below code. I've added underscore, jquery, backbone etc but I can only get object returned with console.log function for jquery only $
Is there a reason why other objects are not returning inside define function?
Below is my code from main.js:
require.config({
paths: {
jquery: '//cdnjs.cloudflare/ajax/libs/jquery/2.0.0/jquery.min',
underscore: '//cdnjs.cloudflare/ajax/libs/underscore.js/1.4.4/underscore-min',
backbone: '//cdnjs.cloudflare/ajax/libs/backbone.js/1.0.0/backbone-min',
bootstrap: '//netdna.bootstrapcdn/twitter-bootstrap/2.3.1/js/bootstrap.min',
qunit: '//cdnjs.cloudflare/ajax/libs/qunit/1.11.0/qunit.min',
bootstrapDatepicker: '/js/bootstrap-datepicker',
backboneValidation: '//cdnjs.cloudflare/ajax/libs/backbone.validation/0.7.1/backbone-validation-min'
}
});
define([
'jquery',
'underscore',
'backbone',
'bootstrap',
'qunit',
'bootstrapDatepicker',
'backboneValidation'
], function($, _, Backbone, Bootstrap, Qunit, Datepicker, backboneValidation){
$(function(){
var ReportModel = Backbone.Model.extend({
validation: {
'date.from': {
required: true,
msg: 'Please enter a from date'
},
'date.to': {
required: true,
msg: 'Please enter a to date'
}
},
initialize: function(){
console.log('test');
}
});
$('#dp3').datepicker().on('changeDate', function(e){
$('#toDate').datepicker('setStartDate', new Date(e.date.valueOf()));
});
$('#dp4').datepicker().on('changeDate', function(e){
$('#fromDate').datepicker('setEndDate', new Date(e.date.valueOf()));
});
});
});
I'm getting Model not defined error with below code. I've added underscore, jquery, backbone etc but I can only get object returned with console.log function for jquery only $
Is there a reason why other objects are not returning inside define function?
Below is my code from main.js:
require.config({
paths: {
jquery: '//cdnjs.cloudflare./ajax/libs/jquery/2.0.0/jquery.min',
underscore: '//cdnjs.cloudflare./ajax/libs/underscore.js/1.4.4/underscore-min',
backbone: '//cdnjs.cloudflare./ajax/libs/backbone.js/1.0.0/backbone-min',
bootstrap: '//netdna.bootstrapcdn./twitter-bootstrap/2.3.1/js/bootstrap.min',
qunit: '//cdnjs.cloudflare./ajax/libs/qunit/1.11.0/qunit.min',
bootstrapDatepicker: '/js/bootstrap-datepicker',
backboneValidation: '//cdnjs.cloudflare./ajax/libs/backbone.validation/0.7.1/backbone-validation-min'
}
});
define([
'jquery',
'underscore',
'backbone',
'bootstrap',
'qunit',
'bootstrapDatepicker',
'backboneValidation'
], function($, _, Backbone, Bootstrap, Qunit, Datepicker, backboneValidation){
$(function(){
var ReportModel = Backbone.Model.extend({
validation: {
'date.from': {
required: true,
msg: 'Please enter a from date'
},
'date.to': {
required: true,
msg: 'Please enter a to date'
}
},
initialize: function(){
console.log('test');
}
});
$('#dp3').datepicker().on('changeDate', function(e){
$('#toDate').datepicker('setStartDate', new Date(e.date.valueOf()));
});
$('#dp4').datepicker().on('changeDate', function(e){
$('#fromDate').datepicker('setEndDate', new Date(e.date.valueOf()));
});
});
});
Share
Improve this question
asked May 7, 2013 at 2:29
Passionate EngineerPassionate Engineer
10.4k26 gold badges102 silver badges174 bronze badges
2 Answers
Reset to default 5Use shim config: http://requirejs/docs/api.html#config-shim. Example:
requirejs.config({
paths: {
jquery: '//cdnjs.cloudflare./ajax/libs/jquery/2.0.2/jquery.min',
underscore: '//cdnjs.cloudflare./ajax/libs/underscore.js/1.4.4/underscore-min',
backbone: '//cdnjs.cloudflare./ajax/libs/backbone.js/1.0.0/backbone-min',
},
shim: {
backbone: {
//These script dependencies should be loaded before loading backbone.js
deps: ['underscore', 'jquery'],
//Once loaded, use the global 'Backbone' as the module value.
exports: 'Backbone'
},
underscore: {
exports: '_'
},
}
});
Unfortunately Backbone.js isn't AMD enabled but you can use amdjs to do it.
This tutorial will use Require.js to implement a modular and organized Backbone.js.
http://backbonetutorials./organizing-backbone-using-modules/