gulp - css url修改

说明

  • 这篇blog以实际问题驱动来写;
  • Q: 表示问题表述;

Q: 在实际项目中,font-awesome.css在编译到dest目录生成krp_index.css,并加载到页面,css引用的图片路径出错,无法加载;

页面分页的上下翻页的图标消失了,下图红框标注处:


分页上下图标消失了

Q:为什么会产生这个问题

下面寻找导致这个问题的原因

图标由css@font-face定义

以上图标的定义在krp_index.css中定义如下

@font-face {  font-family: 'FontAwesome';  
src: url("../../font/fontawesome-webfont.eot?v=3.1.0");  
src: 
url("../../font/fontawesome-webfont.eot?#iefix&v=3.1.0") format('embedded-opentype'), 
url("../../font/fontawesome-webfont.woff?v=3.1.0") format('woff'), 
url("../../font/fontawesome-webfont.ttf?v=3.1.0") format('truetype'), 
url("../../font/fontawesome-webfont.svg#fontawesomeregular?v=3.1.0") format('svg'); 
font-weight: normal;  font-style: normal;
}
源文件font-awesome.css中的定义

与源文件font-awesome.css的@font-face的定义比较,发现他们的url设置是一样的

@font-face {  font-family: 'FontAwesome';  
src: url("../../font/fontawesome-webfont.eot?v=3.1.0");  
src: 
url("../../font/fontawesome-webfont.eot?#iefix&v=3.1.0") format('embedded-opentype'), 
url("../../font/fontawesome-webfont.woff?v=3.1.0") format('woff'), 
url("../../font/fontawesome-webfont.ttf?v=3.1.0") format('truetype'), 
url("../../font/fontawesome-webfont.svg#fontawesomeregular?v=3.1.0") format('svg'); 
font-weight: normal;  font-style: normal;
}
查看目录font与krp_index.css文件的目录层级关系
  • 通过查看dest目录下font和krp_index.css文件的层级关系,发现他们只是上下单层层级;
  • 而源文件与font目录是两层层级,中间多了一个lib目录层;
  • so,从源文件编译到目标文件,目录层级发生了改变,但css引用的font文件路径却没改变,因此导致这个问题;

源文件font-awesome.css与font的层级关系:

源文件font-awesome.css与font的两层层级关系

目标文件krp_index.css与font的层级关系:

目标文件krp_index.css与font的单层层级关系

Q:怎么办?

在google上搜到一个gulp-modify-css-urls插件,可以帮助我们解决这个issue;

我是这样使用的:
var modifyCssUrls=require('gulp-modify-css-urls');
....
.pipe(concat('krp_index.css'))
.pipe(modifyCssUrls(
     {  
        modify: function (url, filePath) {           
            if (url.indexOf('fontawesome-webfont') != -1) {
                return url.substring(3)           
            }        
      }    
   })
)
  • gulp-modify-css-urls 会去遍历css里的所有url;
    modifyCssUrls方法会去遍历krp_index.css文件流中的所有url;

  • 对每个url的处理函数你可以自定义;
    比如我定义的当url包含'fontawesome-webfont'字符串的时候,截取并返回从第3个字符开始到字符串末尾的字符串

然后生成的krp_index.css中@font-face的定义是这样的

在如下的@font-face路径设置下,the issue is fixed;

@font-face {  font-family: 'FontAwesome';  
src: url("../font/fontawesome-webfont.eot?v=3.1.0");  
src: 
url("../font/fontawesome-webfont.eot?#iefix&v=3.1.0") format('embedded-opentype'), 
url("../font/fontawesome-webfont.woff?v=3.1.0") format('woff'), 
url("../font/fontawesome-webfont.ttf?v=3.1.0") format('truetype'), 
url("../font/fontawesome-webfont.svg#fontawesomeregular?v=3.1.0") format('svg'); 
font-weight: normal;  font-style: normal;
}

gulp-modify-css-urls插件文档参考

https://www.npmjs.com/package/gulp-modify-css-urls

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 在现在的前端开发中,前后端分离、模块化开发、版本控制、文件合并与压缩、mock数据等等一些原本后端的思想开始...
    Charlot阅读 5,550评论 1 32
  • 前言 本文默认你已经安装好node环境,并且熟悉node命令,和window cd命令。 gulp简介 基于nod...
    9I阅读 1,999评论 4 50
  • 安装Gulp首先需要安装Node.js,并在控制台输入$ npm install gulp -gMac端需要写成$...
    LaBaby_阅读 981评论 0 1
  • gulpjs是一个前端构建工具,与gruntjs相比,gulpjs无需写一大堆繁杂的配置参数,API也非常简单,学...
    依依玖玥阅读 3,235评论 7 55
  • 幸福的人过得很幸福 孤独的人 常念孤独 心中常抱希望 却也暗夜神伤 缘分可遇不可求 也许已经遇见 或者遥遥无期 难...
    冰梦月阅读 308评论 0 2