Skip to content

webpack的loader,处理html,以支持直接在html中使用img的src加载图片

Notifications You must be signed in to change notification settings

sxcooler/html-withimg-loader

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

16 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

html-withimg-loader

webpack处理资源无往不利,但有个问题总是很苦恼,html中直接使用img标签src加载图片的话,因为没有被依赖,图片将不会被打包。这个loader解决这个问题,图片会被打包,而且路径也处理妥当。额外提供html的include子页面功能。


安装

npm install html-withimg-loader --save

使用

var html = require('html-withimg-loader!../xxx.html');

或者写到配置中:

loaders: [
    {
        test: /\.(htm|html)$/i,
        loader: 'html-withimg-loader'
    }
]

额外支持一项黑科技:

<div>
    #include("./layout/top.html")
</div>

子页面将被引入,并且子页面中的img标签同样会进行处理。该语法支持嵌套。

如:xxx.html:

<!DOCTYPE html>
<html>
<head>
#include("./handlebars/layout.html")
<title>示例页面</title>
</head>
<body>
<img id='test2' src='images/logo.gif' />
<img id="test1" src="./images/test4.jpg" />
#include("./handlebars/scripts.html")
</body>
</html>

编译结果为:

<!DOCTYPE html><html><head><meta name="description" content=""><meta name="keywords" content=""><meta charset="utf-8"><meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1"><title>示例页面</title></head><body><img id='test2' src="/__build/images/logo_f7b644e2086e41139fa132fd229450f4.gif" /><img id="test1" src="/__build/images/test4_df538a9696eb4c032286f7f6bc0d1708.jpg" /><script src="https://static.yiji.com/resource/lib/jquery/1.11.2/jquery.min.js"></script></body></html>

结合html-webpack-plugin,在入口html中也可以使用img标签加载图片,不会打包失败

plugins:[ new HtmlWebpackPlugin({ template: 'html-withimg-loader!'+path.resolve(srcDir, 'xxx.html'), filename: 'xxx.html' }) ]

注意,必须请求虚拟目录/__build/下的html才是处理后的html,新手可能不知道这个,如:127.0.0.1/__build/xxx.html

github地址:https://github.com/wzsxyz/html-withimg-loader

支持查询参数:

  • query.exclude 匹配该参数的图片路径不进行处理。例如:

    {test: /.html$/, loader: 'html-withimg-loader?exclude=/upload/'},

则如:src="/upload/head.png"这个图片路径将不会被处理。暂不支持正则表达式字符串。

  • query.min 默认会去除html中的换行符,配置min=false可不去除

  • query.deep deep=false将关闭include语法嵌套子页面的功能

    require('html-withimg-loader?min=false!xxx.html');

更新记录:

0.1.17

  • 增加了对ogg、mp3和wav格式<audio>标签的支持

0.1.16

  • 增加了.svg .webp两种图片类型的支持

0.1.15

  • 增加了对link标签href图片路径的处理

0.1.13

  • 增加了exclude查询参数,用于排除特定的图片

0.1.11

  • 进行了一些合理化修改,绝对路径的图片,非静态图片(如以.htm结尾的图片路径)不会再被处理到

0.1.10

  • 修复img里面data-src这种属性被错误匹配、以及空的src造成编译失败的问题

0.1.9

  • 修复了编译后图片路径没有引号的问题

0.1.8

  • 修复了该loader被配置多次时,文件被反复编译引起异常的问题

0.1.7

  • 修复了min=false时的换行符问题

0.1.6:

  • 修复了不以/、./、../开头的不规范图片路径造成模块无法找到的问题

0.1.5:

  • 解决了页面中包含单引号会编译异常的bug

About

webpack的loader,处理html,以支持直接在html中使用img的src加载图片

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • JavaScript 100.0%