Есть у меня файл, в котором определяются некоторые глобальные переменные
let isClient = !!('undefined' !== typeof window && window.document)
if (isClient) {
window.global = window
}
global.isClient = isClient
global.isServer = !isClient
global.isChrome = isClient && !!self.chrome && !!window.chrome.webstore;
global.isBlink = isClient && isChrome && !!window.CSS;
global.isFirefox = isClient && self.InstallTrigger;
global.DEBUG = true
Object.defineProperty(global, 'DEBUG', {
writable: false,
value: !!('undefined' !== typeof localStorage && +localStorage.getItem('debug'))
})
global.debug = console.log.bind(console)
global.announce = function announce(objects) {
for (let name in objects) {
Object.defineProperty(global, name, {
writable: true,
value: objects[name]
})
}
}
И настройка webpack
const isProduction = 'prod' === process.env.MODE
const config = {
entry: [
__dirname + '/globals.js',
__dirname + '/entry.jsx'
],
watch: !isProduction,
output: {
path: __dirname + '/public',
filename: 'gay.js',
comments: false
},
module: {
loaders: [
{test: /\.css$/, loaders: ['style']},
{test: /\.scss$/, loaders: ['style', 'css', 'sass']},
{test: /\.less$/, loaders: ['less']},
{
test: /\.woff(2)?(\?v=[0-9]\.[0-9]\.[0-9])?$/,
loader: "url-loader?limit=10000&minetype=application/font-woff"
},
{
test: /\.(ttf|eot|svg)(\?v=[0-9]\.[0-9]\.[0-9])?$/,
loader: "file-loader"
},
{
test: /\.jsx$/,
exclude: /(node_modules)/,
loader: 'babel',
query: {
presets: ['es2015', 'react'],
plugins: ['transform-class-properties']
}
}
]
},
resolve: {
modulesDirectories: [__dirname + '/node_modules']
},
plugins: []
}
if (isProduction) {
config.plugins.push(
new (require('webpack-uglify-js-plugin'))({
cacheFolder: '/tmp',
debug: false,
minimize: false,
sourceMap: false,
compress: {
warnings: true
}
})
)
}
else {
config.devtool = 'source-map'
}
module.exports = config
Если uglify включен, выдает ошибку что isClient (и другие глобальные переменные определены в globals.js) не существует?
Есть ли способ определить глобальные переменные или нужно обязательно использовать require/import?