Próbuję zbudować aplikację SPA (requirejs, durandal 2, knockout) w pojedynczym pliku main-build.js za pomocą polecenia i "Występują poważne problemy z wtyczką" tekstową "używaną przez durandal do ładowania moich widoków.Użycie r.js do spakowania aplikacji SPA, która ładuje widoki za pomocą "tekstu"
W wersji deweloperskiej z powodzeniem używam "tekstu" do dynamicznego ładowania widoków zgodnie ze standardowym sposobem budowania durandalnych aplikacji. Różnica polega na tym, że muszę wykonać szablony po stronie serwera dla widoków i tak naprawdę są one generowane dynamicznie.
Mając to na uwadze, chciałbym użyć r.js do spakowania modeli aplikacji, przeglądania modeli i usług (za pomocą wtyczki grunt-durandal) do pojedynczego pliku, ale NIE pakować widoków (.html) i nadal ładuj je dynamicznie w razie potrzeby.
W mojej konfiguracji gruntowej używam opcji inlineText: false
- co sprawdziłem, to tłumienie modułów "text! *" W kompilacji. Ale kiedy uruchomić aplikację Dostaję:
Uncaught TypeError: undefined is not a function
od wewnątrz text.load
na następującej linii:
var parsed = text.parseName(name),
nonStripName = parsed.moduleName +
(parsed.ext ? '.' + parsed.ext : ''),
url = req.toUrl(nonStripName), // EXCEPTION THROWN HERE
Nazwa modułu ładowane wydaje się być prawidłowe (jego „!” Jeden tekst *) ale poza tym nie mam pojęcia, jak przystąpić do debugowania tego problemu. Co ja robię źle?
Moja grunt configuraiton jest:
/*global module, require */
module.exports = function (grunt) {
'use strict';
// library that allows config objects to be merged together
var mixIn = require('mout/object/mixIn');
var requireConfig = {
baseUrl: 'App/',
paths: {
'jquery': '../Scripts/jquery-2.1.0',
'knockout': '../Scripts/knockout-3.1.0',
'text': '../Scripts/text',
'durandal': '../Scripts/durandal',
'plugins': '../Scripts/durandal/plugins',
'transitions': '../Scripts/durandal/transitions',
}
};
grunt.initConfig({
pkg: grunt.file.readJSON('package.json'),
jshint: {
options: {
"-W099": true, // allowed mixed tabs and spaces
"-W004": true, // needed to avoid errors where TS fakes inheritance
ignores: [
'App/main-built.js' // ingore the built/compacted file
]
},
all: [ // run jshint on these files
'gruntfile.js',
'App/**/*.js'
]
},
// TODO: could add jasmine here to do JS testing
clean: {
build: ['build/*']
},
copy: {
scripts: {
src: 'Scripts/**/**',
dest: 'build/'
}
},
durandal: {
main: {
src: [
'App/**/*.*',
'!App/main-built.js', // ignore the built file!
'Scripts/durandal/**/*.js'
],
options: {
name: '../Scripts/almond-custom',
baseUrl: requireConfig.baseUrl,
mainPath: 'App/main',
paths: mixIn(
{},
requireConfig.paths,
{ 'almond': '../Scripts/almond-custom.js' }),
exclude: [],
inlineText: false, // prevent bundling of .html (since we are dynamically generating these for content)
optimize: 'none', // turn off optimisations - uglify will run seperately by grunt to do this
out: 'build/app/main-built.js'
}
}
},
uglify: {
options: {
banner: '/*! <%= pkg.name %> <%= grunt.template.today("yyyy-mm-dd") %> \n' +
'* Copyright (c) <%= grunt.template.today("yyyy") %> Kieran Benton \n' +
'*/\n'
},
build: {
src: 'build/App/main.js',
dest: 'build/App/main-built.js'
}
}
}
);
// loading plugin(s)
grunt.loadNpmTasks('grunt-contrib-clean');
grunt.loadNpmTasks('grunt-contrib-connect');
grunt.loadNpmTasks('grunt-contrib-copy');
grunt.loadNpmTasks('grunt-contrib-jasmine');
grunt.loadNpmTasks('grunt-contrib-jshint');
grunt.loadNpmTasks('grunt-contrib-uglify');
grunt.loadNpmTasks('grunt-contrib-watch');
grunt.loadNpmTasks('grunt-open');
grunt.loadNpmTasks('grunt-durandal');
// only one grunt task
grunt.registerTask('build', [
'jshint',
'clean',
'copy',
'durandal:main']);
};
Czy istnieje sposób użycia r.js do zbudowania zoptymalizowanego pakietu, ale nadal zawierają pełną wersję wymaganego js (i nie migdałowy), który znasz? Nie jestem pewien, co mogę zrobić dalej ... –
Cześć, Ciernie, też mam ten sam problem z tym, ale używam gulp-durandal. –