Browserify-shim Poltergeist/Phantom.JS проблемы со строгим режимом
Я делаю проект Rails, используя Browserify. Загрузочный Javascript загружается через browserify-shim.
Когда я запускаю свой проект и смотрю на него в Firefox, все в порядке. Однако, когда я тестирую его через Poltergeist (или просто запускаю его с PhantomJS 2.1.1), возникает ошибка:
Capybara::Poltergeist::JavascriptError:
One or more errors were raised in the Javascript code on the page. If you don't care about these errors, you can ignore them by setting js_errors: false in your Poltergeist configuration (see documentation for details).
ReferenceError: Strict mode forbids implicit creation of global property 'jQuery'
ReferenceError: Strict mode forbids implicit creation of global property 'jQuery'
at http://127.0.0.1:47269/assets/application-038b5f3da112b67153daa218adfed54030ee9e0085fd9586c0bb13fa320b830e.js:12
Вот такая строка:
;jQuery = global.jQuery = require("jquery");
Который, на мой взгляд, выглядит как строчка для jQuery (за ней следует код bootstrap.js).
Вот мой package.json:
{
"name": "billy-bones-rails",
"version": "0.0.1",
"description": "Billy-bones-rails asset package",
"main": "index.js",
"directories": {
"doc": "doc",
"test": "test"
},
"scripts": {
"bundle-js": "./node_modules/.bin/browserify app/assets/javascripts/index.js -o app/assets/javascripts/bundle.js",
"watch-js": "./node_modules/.bin/watchify app/assets/javascripts/index.js -o app/assets/javascripts/bundle.js -d -v"
},
"repository": {
"type": "git",
"url": "git+https://github.com/art-solopov/billy-bones-rails.git"
},
"author": "Artemiy Solopov",
"license": "MIT",
"bugs": {
"url": "https://github.com/art-solopov/billy-bones-rails/issues"
},
"homepage": "https://github.com/art-solopov/billy-bones-rails#readme",
"dependencies": {
"babel-cli": "^6.8.0",
"babel-preset-es2015": "^6.6.0",
"babelify": "^7.3.0",
"bootstrap": "^3.3.6",
"browserify": "^13.0.0",
"browserify-shim": "^3.8.12",
"jquery": "^2.2.2",
"normalize.css": "^4.0.0",
"watchify": "^3.7.0"
},
"browser": {
"bootstrap": "./node_modules/bootstrap/dist/js/bootstrap.js"
},
"browserify": {
"transform": [
"browserify-shim",
[
"babelify",
{
"presets": "es2015"
}
]
]
},
"browserify-shim": {
"bootstrap": {
"depends": [
"jquery:jQuery"
]
}
}
}
Могу ли я что-нибудь сделать с этой ошибкой, кроме отключения отчетов об ошибках Poltergeist?
PS Следует отметить, что я могу повторить эту ошибку только с помощью PhantomJS 2.1.1. Firefox (46 и 48), Chromium и PhantomJS 1.9.0 выводят без ошибок.
1 ответ
По-видимому, проблема была вызвана сочетанием babelify
неверная конфигурация и browserify-shim
, Я добавил это к моему babelify
конфигурации:
"ignore": "node_modules"
Это избавило от строгого режима верхнего уровня в модуле Bootstrap.