webpack打包部署react文件夹路径问题

首先我的项目需要放在服务器子目录下如图的Opsystem

clipboard.png

打开后会报几个文件夹的路径错误,想请问该如何配置webpack
项目目录:

clipboard.png
webpack配置
webpack.common.js:

var webpack = require('webpack');
var CopyWebpackPlugin = require('copy-webpack-plugin');
var HtmlWebpackPlugin = require('html-webpack-plugin');
var ExtractTextPlugin = require('extract-text-webpack-plugin');
var path = require('path');
var pkgBower = require('./package.json');

var baseHref = process.env.WP_BASE_HREF ? process.env.WP_BASE_HREF : '/Opsystem';

module.exports = {

    entry: {
        'vendor': './app/Vendor.jsx',
        'app': './app/App.jsx'
    },

    resolve: {
        root: path.join(__dirname, ''),
        modulesDirectories: ['node_modules', 'bower_components'],
        extensions: ['', '.js', '.jsx']
    },

    module: {
        loaders: [{
                test: /jquery\.flot\.resize\.js$/,
                loader: 'imports?this=>window'
            }, {
                test: /\.js/,
                loader: 'imports?define=>false'
            }, {
                test: /\.jsx?$/,
                exclude: /(node_modules|bower_components)/,
                loaders: ['react-hot']
            }, {
                test: /\.jsx?$/,
                exclude: /(node_modules|bower_components)/,
                loader: 'babel',
                query: {
                    presets: ['es2015', 'react'],
                    compact: false
                }
            }, {
                test: /\.css$/,
                exclude: path.join(process.cwd(), '/app'),
                loader: ExtractTextPlugin.extract('style', 'css?sourceMap')
            }, {
                test: /\.css$/,
                include: path.join(process.cwd(), '/app'),
                loader: 'raw'
            }, {
                test: /\.woff|\.woff2|\.svg|.eot|\.ttf/,
                loader: 'url?prefix=font/&limit=10000'
            }, {
                test: /\.(png|jpg|gif)$/,
                loader: 'url?limit=10000'
            }, {
                test: /\.scss$/,
                loader: 'style!css!sass?outputStyle=expanded'
                // loader: 'style!css!rtlcss-loader!sass?outputStyle=expanded' // uncomment for RTL
            }]
            // , noParse: [/\.min\.js/]
    },

    resolveLoader: {
        alias: {
            'rtlcss-loader': path.join(__dirname, 'rtlcss-loader.js')
        }
    },

    devServer: {
        outputPath: path.join(__dirname, 'dist')
    },

    plugins: [
        new webpack.optimize.CommonsChunkPlugin('vendor', 'vendor[hash:6].js'),
        new HtmlWebpackPlugin({
            template: 'app/index.html',
            baseUrl: baseHref
        }),
        new webpack.ResolverPlugin([
            // new webpack.ResolverPlugin.DirectoryDescriptionFilePlugin('package.json', ['main']),
            new webpack.ResolverPlugin.DirectoryDescriptionFilePlugin('.bower.json', ['main'])
        ]),
        new CopyWebpackPlugin([{
            from: 'img',
            to: 'img',
            context: path.join(__dirname, 'app')
        }, {
            from: 'server',
            to: 'server',
            context: path.join(__dirname, 'app')
        }, {
            from: 'fonts',
            to: 'fonts',
            context: path.join(__dirname, 'app')
        }]),
        new webpack.ProvidePlugin({
            $: 'jquery',
            jQuery: 'jquery',
            'window.jQuery': 'jquery'
        }),
        new webpack.ContextReplacementPlugin(/\.\/locale$/, 'empty-module', false, /js$/),
        new webpack.DefinePlugin({
            WP_BASE_HREF: JSON.stringify(baseHref)
        })
    ]
};

webpack.prod.js:

var webpack = require('webpack');
var webpackMerge = require('webpack-merge');
var ExtractTextPlugin = require('extract-text-webpack-plugin');
var commonConfig = require('./webpack.common.js');
var path = require('path');

const ENV = process.env.NODE_ENV = process.env.ENV = 'production';

module.exports = webpackMerge(commonConfig, {
    // devtool: 'source-map',

    output: {
        path: path.join(process.cwd(), '/dist/Opsystem'),
        publicPath: '/Opsystem/',
        filename: '[name].[hash].js'
    },

    plugins: [
        new webpack.NoErrorsPlugin(),
        new webpack.optimize.DedupePlugin(),
        new webpack.optimize.UglifyJsPlugin({
            mangle: {
                keep_fnames: true,
                except: ['$super']
            }
        }),
        new ExtractTextPlugin('[name].[hash].css'),
        new webpack.DefinePlugin({
            'process.env': {
                NODE_ENV: JSON.stringify('production')
            }
        })
    ]
});

错误信息:

clipboard.png

阅读 5.9k
1 个回答

Opsystem是根目录吗?如果是把publicPath改为'/'

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题