Web前端之路Web 前端开发 前端开发

gulp - css url修改

2016-06-01  本文已影响1655人  Addy_Zhou

说明

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文件的目录层级关系

源文件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)           
            }        
      }    
   })
)
然后生成的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

上一篇 下一篇

猜你喜欢

热点阅读