gulp - css url修改

作者: Addy_Zhou | 来源:发表于2016-06-01 11:23 被阅读1655次

    说明

    • 这篇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

    相关文章

      网友评论

        本文标题:gulp - css url修改

        本文链接:https://www.haomeiwen.com/subject/ffgcdttx.html