Webpack SCSS图像URL链接在嵌套路由上断开

时间:2016-08-18 17:35:17

标签: sass webpack react-router babeljs sass-loader

这是我的目录结构:

- public
- src
  - app.js
  - assets
    - images
      - logo-b-green.png 
    - stylesheets
      - nav.scss

// webpack.config.js

module.exports = {
  entry: './src/app.js',
  output: {
    path: './public',
    filename: 'bundle.js'
  },
  module: {
    loaders: [
      {
        test: /.jsx?$/,
        exclude: /node_modules/,
        loader: 'babel-loader'
      },
      {
        test: /\.scss$/,
        loaders: ['style', 'css', 'sass']
      },
      {
          test: /\.(eot|svg|ttf|woff|woff2)$/,
          loader: 'file?name=fonts/[name].[ext]'
      },
      {
        test: /\.(png|jpg|gif)$/,
        loader: "file-loader?name=images/img-[hash:6].[ext]"
      }
    ]
  },
  resolve: {
    extensions: ['', '.js', '.json']
  }
};

/* nav.scss */

#nav-logo {
  height: 26px;
  width: 26px;
  background-size: 100%;
  background-image: url('../images/logo-b-green.png');
  float: left;
  margin: 16px 0 0 23px;
}

加载单级路线时,我的图片链接正常工作。

例如,在/search,图片链接呈现为url(images/img-75fa3d.png)并且有效。

但是,如果我转到嵌套路线(通过React Router),例如/properties/1图片链接相同,无法找到正确的图片位置,因为它是相对链接:url(images/img-75fa3d.png)

此示例中的图片为logo-b-green.png

编辑:

我将publicPath添加到output部分并且它有效,现在网址是根目录。有人可以确认这是处理此问题的正确方法吗?

output: {
 path: './public',
 filename: 'bundle.js',
 publicPath: '/'
}, ...

1 个答案:

答案 0 :(得分:1)

我已将publicPath添加到output部分,但它确实有效,现在网址已成为根目录。

output: {
 path: './public',
 filename: 'bundle.js',
 publicPath: '/'
}, ...