webpack打包后直接访问页面图片路径错误的解决方法

2019-11-20,,,,

前言

本文说的这种图片路径错误是这样的,运行webpack-dev-server,一切正常,没有错误。当webpack之后,直接打开index页面,报错,图片找不到,找不到的原因是路径错误。

先看我的项目代码

webpack.config.js

var Webpack = require("webpack");
var path = require("path");

module.exports = {
 entry: './js/entry.js',
 output: {
 path: path.join(__dirname, '/build'),
 filename: 'bundle.js',
 publicPath: "/src/"
 },
 module: {
 loaders: [{
  test: /\.css$/,
  loader: 'style-loader!css-loader'
  }, {
  test: /\.(png|jpg)$/,
  loader: 'url-loader?limit=8192&name=images/[hash:8].[name].[ext]'
  }, 
  {
  test: require.resolve('zepto'),
  loader: 'exports-loader?window.Zepto!script-loader'
  }
 ]
 },
 watch: true,
 devtool: "cheap-module-eval-source-map"
}

这里设置了publicPath,用法点击这里

index.html中引用路径如下:

<script type="text/javascript" src="src/bundle.js" ></script>

当运行webapck-dev-server时,http://localhost:8080/显示正常。

紧接着,要打包,目的是脱离命令能直接访问页面。

操作如下:

  1.执行webpack

  2.将build中的文件全部拷贝到src中

  3.查看页面

因为图片路径错误,所以找不到图片。

我通过单独给处理图片的loader设置publicPath解决了这个问题,如下:

   {
  test: /\.(png|jpg)$/,
  loader: 'url-loader?limit=8192&name=images/[hash:8].[name].[ext]',
  options:{
   publicPath:'/'
  }
  }

然后测试,webapck-dev-server成功,wepback成功,打开页面访问,成功。

路径是这个样子的。

总结

以上就是这文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如有疑问大家可以留言交流,谢谢大家对北冥有鱼的支持。

您可能感兴趣的文章:

  • 详解webpack 多页面/入口支持&公共组件单独打包
  • webpack常用配置项配置文件介绍
  • 基于vuejs+webpack的日期选择插件
  • webpack中引用jquery的简单实现
  • Vue.js中用webpack合并打包多个组件并实现按需加载
  • 详解如何使用webpack打包Vue工程
  • 深入理解Webpack 中路径的配置
  • webpack实现热加载自动刷新的方法
  • Webpack+Vue如何导入Jquery和Jquery的第三方插件
  • 详解webpack分离css单独打包
  • webpack独立打包和缓存处理详解
  • 详解使用vue脚手架工具搭建vue-webpack项目
  • Webpack 实现 Node.js 代码热替换
  • 深入浅出webpack之externals的使用
  • Webpack实现按需打包Lodash的几种方法详解
  • 详解webpack 如何集成第三方js库
  • Vue项目webpack打包部署到服务器的实例详解
  • 加速Webpack构建技巧总结

《webpack打包后直接访问页面图片路径错误的解决方法.doc》

下载本文的Word格式文档,以方便收藏与打印。