这个插件修改自gulp-prefix,用于为html中的某些标签特定的属性值,如link[href]的值添加前缀,往往是静态资源cdn域名地址。
<!-- 添加前缀钱 -->
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>gulp-prefix-url test</title>
<link rel="stylesheet" href="/a.css">
</head>
<body>
<img src="/a.png" alt="test">
<script src="a.js"></script>
</body>
</html>
<!-- 添加前缀后 -->
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>gulp-prefix-url test</title>
<link rel="stylesheet" href="http://cdn/a.css">
</head>
<body>
<img src="http://cdn/a.png" alt="test">
<script src="http://cdn/a.js"></script>
</body>
</html>
npm install gulp-prefix-url --save
const gulp = require('gulp'),
prefixUrl = require('gulp-prefix-url'),
prefix = 'http://cdn';
gulp.task('prefix',function() {
return gulp.src(__dirname + '/src/*.html')
.pipe(prefixUrl(prefix))
.pipe(gulp.dest(__dirname + '/dist'));
});
-
prefix
type string|function 需要添加的前缀。如果prefix为函数,该函数需要返回一个字符串,这个字符串即为需要添加的前缀,如下:
const gulp = require('gulp'), prefixUrl = require('gulp-prefix-url'); let prefixFn = function() { let prefix = 'http://cdn'; return prefix; }; gulp.task('prefix',function() { return gulp.src(__dirname + '/src/*.html') .pipe(prefixUrl(prefixFn)) .pipe(gulp.dest(__dirname + '/dist')); });
-
selectors
type object 是一个key-value对象,key为属性选择器,value为具体的属性,如果不提供,插件会使用默认值进行前缀添加,具体格式如下:
const gulp = require('gulp'), prefixUrl = require('gulp-prefix-url'), prefix = 'http://cdn/', selectors = { "img[data-lazyload-src]" : "data-lazyload-src" }; gulp.task('prefix',function() { return gulp.src(__dirname + '/src/*.html') .pipe(prefixUrl(prefix,selectors)) .pipe(gulp.dest(__dirname + '/dist')); }); //默认的选择器配置如下 /* let defaultSelector = { "script[src]" : "src", "link[href]" : "href", "img[src]" : "src" }; //最后得到的选择器 finalSelectors = { "script[src]" : "src", "link[href]" : "href", "img[src]" : "src", "img[data-lazyload-src]" : "data-lazyload-src" } */
-
ignore
string regex 用于过滤一些不需要处理的属性值。这里的
regexString
最后会通过new Regex(regexString)
创建得到正则表达式。const gulp = require('gulp'), prefixUrl = require('gulp-prefix-url'), prefix = 'http://cdn/'; let ignore = 'filter'; gulp.task('prefix',function() { return gulp.src(__dirname + '/src/*.html') .pipe(prefixUrl(prefix,{},ignore)) .pipe(gulp.dest(__dirname + '/dist')); });