Сложность заставить browserify-shim работать с grunt-browserify (> 2.0.2) в качестве преобразования
В версии 2.0.2grunt-browserify
, browserify-shim
был удален из самого модуля и преобразован для использования в качествеtransform
, а не простоoption
наgrunt-browserify
задача.
старый версия использования прокладки сgrunt-browserify
будет выглядеть так:
'libs-dev': {
src: [path.join('<%= config.dirs.browserLibs %>', 'angular', 'angular.js')],
dest: path.join('<%= config.dirs.dest.dev %>', 'js', 'libs.js'),
options: {
shim: {
angular: {
path: path.join('<%= config.dirs.browserLibs %>', 'angular', 'angular.js'),
exports: 'angular'
}
}
}
}
Это сработало замечательно, и создало обертку вокругlibs.js
модуль как таковой:
require=(function(e,t,n){function i(n,s){if(!t[n]){if(!e[n]){var o=typeof require=="function"&&require;if(!s&&o)return o(n,!0);if(r)return r(n,!0);throw new Error("Cannot find module '"+n+"'")}var u=t[n]={exports:{}};e[n][0].call(u.exports,function(t){var r=e[n][1][t];return i(r?r:t)},u,u.exports)}return t[n].exports}var r=typeof require=="function"&&require;for(var s=0;s<n.length;s++)i(n[s]);return i})({"angular":[function(require,module,exports){
module.exports=require('i10PRm');
},{}],"i10PRm":[function(require,module,exports){
(function(global){(function browserifyShim(module, exports, define, browserify_shim__define__module__export__) {
browserify_shim__define__module__export__(typeof angular != "undefined" ? angular : window.angular);
}).call(global, undefined, undefined, undefined, function defineExport(ex) { module.exports = ex; });
})(window)
},{}]},{},["i10PRm"]);
Однако, основываясь на (невероятно редкой и разочаровывающей) документации,новый версия подкладки внутриgrunt-browserify
используется какtransform
, в качестве таких:
'libs-dev': {
src: [path.join('<%= config.dirs.browserLibs %>', 'angular', 'angular.js')],
dest: path.join('<%= config.dirs.dest.dev %>', 'js', 'libs.js'),
options: {
transform: ['browserify-shim']
}
}
и с тех порbrowserify-shim
Конфигурация теперь полностью основана наpackage.json
конфигурация мояpackage.json
выглядит так:
"browser": {
"angular": "./bower_components/angular/angular.js"
},
"browserify-shim": {
"angular": "angular"
}
Тем не менее, это создает оболочку, которая выглядит следующим образом:
(function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require=="function"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);throw new Error("Cannot find module '"+o+"'")}var f=n[o]={exports:{}};t[o][0].call(f.exports,function(e){var n=t[o][1][e];return s(n?n:e)},f,f.exports,e,t,n,r)}return n[o].exports}var i=typeof require=="function"&&require;for(var o=0;o<r.length;o++)s(r[o]);return s})({1:[function(require,module,exports){
(function (global){
__browserify_shim_require__=require;(function browserifyShim(module, exports, require, define, browserify_shim__define__module__export__) {
browserify_shim__define__module__export__(typeof angular != "undefined" ? angular : window.angular);
}).call(global, undefined, undefined, undefined, undefined, function defineExport(ex) { module.exports = ex; });
}).call(this,typeof self !== "undefined" ? self : typeof window !== "undefined" ? window : {})
},{}]},{},[1]);
Как видите, чего-то не хватает в этой новой оболочке; похоже, что нет эквивалентаi10PRm
значение экспорта присваивается в старой оболочке. Предположительно, это означает, что я каким-то образом неправильно использую экспорт, хотя я следую заbrowserify-shim
документы и все это кажется довольно простым.
Буду рад любой помощи или ясности в отношении новейших версийgrunt-browserify
(>= 2.0.2
) а такжеbrowserify-shim
и как правильно их использовать вместе.