Ho un po 'di problemi con il mio requirejs optimizer. Dopo aver eseguito l'ottimizzazione, ricevo alcuni messaggi di errore nel mio file compilato/compilato. Quando eseguo la mia applicazione Web senza il passaggio di ottimizzazione, non ho errori.Impossibile caricare i plugin jQuery quando si utilizza requirejs & r.js optimizer
Questo è il mio file Client.js (contiene config) (CoffeeScript)
requirejs.config
baseUrl: '/source/'
paths:
text: 'lib/text'
io: 'lib/socket.io'
underscore: 'lib/underscore'
backbone: 'lib/backbone'
jquery: 'lib/jquery'
# almond: 'lib/almond'
bootstrap: 'lib/bootstrap'
bootstrapFileUpload: 'lib/bootstrap-fileupload'
jqueryUniform: 'lib/jquery.uniform'
jqueryBrowser: 'lib/jquery.browser'
datatables: 'lib/jquery.dataTables'
datatables_bootstrap: 'lib/DT_bootstrap'
shim:
io:
exports: 'io'
jquery:
exports: 'jQuery'
jqueryBrowser:
deps: ['jquery']
jqueryUniform:
deps: ['jqueryBrowser', 'jquery']
underscore:
exports: '_'
backbone:
deps: ['underscore', 'jquery']
exports: 'Backbone'
datatables_bootstrap:
deps: ['jquery', 'datatables']
datatables:
deps: ['jquery']
require ['routers/router', 'backbone'], (Router, Backbone) ->
MainRouter = new Router()
Backbone.history.start()
E qui è il mio config per l'ottimizzatore. Eseguo l'ottimizzatore da nodejs dopo aver richiesto 'requirejs' come modulo.
config =
baseUrl: __dirname + '/../client/source'
name: 'lib/almond'
include: './client'
optimize: 'none'
out: __dirname + '/../client/' + hash + '.js'
paths:
text: 'lib/text'
io: 'lib/socket.io'
underscore: 'lib/underscore'
backbone: 'lib/backbone'
jquery: 'lib/jquery'
bootstrap: 'lib/bootstrap'
bootstrapFileUpload: 'lib/bootstrap-fileupload'
jqueryUniform: 'lib/jquery.uniform'
jqueryBrowser: 'lib/jquery.browser'
datatables: 'lib/jquery.dataTables'
datatables_bootstrap: 'lib/DT_bootstrap'
shim:
bootstrap:
exports: 'bootstrap'
bootstrapFileUpload:
exports: 'bootstrapUpload'
io:
exports: 'io'
jquery:
exports: 'jQuery'
jqueryBrowser:
deps: ['jquery']
jqueryUniform:
deps: ['jqueryBrowser', 'jquery']
underscore:
exports: '_'
backbone:
deps: ['underscore', 'jquery']
exports: 'Backbone'
datatables:
deps: ['jquery']
datatables_bootstrap:
deps: ['jquery', 'datatables']
requirejs.optimize config, (buildResponse) ->
js = true
if js && css
require './server'
, (err) ->
console.log 'requirejs err'
console.log err
L'errore specifico che sto vedendo in cromo è: "TypeError Uncaught: Impossibile leggere proprietà 'default' di indefinito"
che è correlato a questo frammento di codice:
/* Set the defaults for DataTables initialisation */
$.extend(true, $.fn.dataTable.defaults, {
Qualsiasi idea cosa potrebbe andare storto? Grazie!
ciao, sto lottando anche su questo. Ma la mia console dice che $ .fn.DataTable non è una funzione – w3jimmy
In questa linea define ([ 'jquery', 'dataTable', 'bootstrap'] sostituire 'dataTable' con il nome di variabile dal percorso requirejs di DataTable –