详细介绍HTML favicon尺寸 格式 制作等相关知识 « 张鑫旭 |
您所在的位置:网站首页 › 图标有两种类型一种是 › 详细介绍HTML favicon尺寸 格式 制作等相关知识 « 张鑫旭 |
by zhangxinxu from https://www.zhangxinxu.com/wordpress/?p=8747 本文欢迎分享与聚合,全文转载就不必了,尊重版权,圈子就这么大,若急用可以联系授权。 本文大部分内容源自这个stackoverflow问题的最高赞回答,然后结合其他一些我知道的favicon知识整理而成。 一、favicon的格式favicon通常使用下面这几种文件格式: favicon.ico图标 PNG格式图标favicon.ico类型的图标所有桌面浏览器都支持,包括旧版本的IE浏览器。 PNG格式的图标现代桌面浏览器(如IE11,Chrome,Firefox)都支持。 为了在跨桌面浏览器(Windows/IE, MacOS/Safari等)的时候有最好的效果,建议结合这两种类型的图标。 二、favicon的尺寸favicon必须是正方形,桌面浏览器以及苹果iOS是不支持非正方形的图标的。 favicon.ico ICO格式的图片和PNG格式图片是不一样的,PNG图片就是一张单独的图片,但是作为Favicon的ICO格式图片应该是一组16×16、32×32和48×48图像集合。所以,一张PNG图标格式转换成ICO格式后尺寸会大很多,是因为这个ICO图标包含了多个尺寸。 有些人会直接把.png图标改后缀为.ico来使用,这种用法是错误的,两种类型的图标是不一样的,但是很诡异的是,有些浏览器足够的智能,虽然你的后缀是.ico,其也能正确解析为PNG格式。 微软官方是推荐把16×16, 32×32 以及 48×48这几个尺寸的图标整合在favicon.ico中的。例如,IE会把16×16版本的用在浏览器的地址栏上,而32×32这个尺寸用在快捷任务栏上。 使用示意如下: 注意,我们直接使用rel="icon"就可以了,现在很多网站依然使用rel="shortcut icon",这是一种过时的用法,可以被淘汰掉了。 当然,对于favicon.ico的使用,最推荐的做法是放在网站的根目录下,不需要有任何额外的声明。同时在页面头部声明PNG格式的favicon,给现代浏览器使用,因为体积更小,使用也更灵活。 PNG icons 对于现代桌面浏览器,推荐使用PNG图标作为favicon。 通常期望的尺寸是 16×16, 32×32以及越大越好。例如,MacOS/Safari使用196×196尺寸图标,如果这是这些浏览器能够找到的最大的图片。 那应该推荐什么尺寸是什么呢?下面是一些平台favicon最佳尺寸列表: 绝大多数桌面浏览器:16×16, 32×32以及尽可能大 Android Chrome:192×192 Google TV:96×96 其他平台自己可以找找文档,查查资料。我们还可以使用sizes属性指定PNG图标的尺寸,这样浏览器自己可以选择合适尺寸的小图标。 例如: ...我们可以实际测试下这种sizes尺寸设定在常见桌面浏览器下的效果: 您可以狠狠地点击这里:PNG格式favicon多个尺寸设置测试demo 测试HTML如下: 结果,Chrome,Firefox,IE edge下小图标均换成了圆角的“鑫”: 然后我们来看下请求: Chrome浏览器下请求的是32×32的尺寸PNG图标: Firefox则是请求16×16以及128×128这两个尺寸: 16×16应该用来显示在地址栏上,128×128这个尺寸不知道干什么用的,需要专业人士告知了。, 三、favicon的生成favicon.ico类型的文件生成需要专门的工具,不像PNG这么方便。 之前我都是下载个工具制作,不过这样做成本有点高,其实有很多在线的favicon生成工具做的很不错的。 推荐这个:https://realfavicongenerator.net/ 无广无告,作者对favicon研究很深入,适合于多种平台,还支持favicon压缩。 例如,选一张“鑫”图片: 其可以生成在各个平台下favicon,以及预览效果: 其他备选在线页面(有广有告): https://www.favicon.cc/ http://faviconit.com/ 四、favicon与404本地网页开发的时候,Chrome浏览器经常可以看到 favicon.ico 404错误,这个可以忽略,只要线上服务器跟地址有favicon.ico就可以了,不要担心上线会出问题,因为网页如果没有指定favicon浏览器会自动从域名的根目录下查找名为favicon.ico的文件,如果找不到就会404。 如果本地这个错误提示让你很烦,则你可以制作一个和线上favicon.ico形状图形一样,但颜色不同的favicon.ico放在本地开发目录的跟地址中。颜色不同的建议是:线上favicon蓝色系的,则本地环境的favicon.ico使用橙色或者红色;线上favicon橙色系的,本地使用蓝色系。 这样一眼就看清楚到底是线上环境还是本地环境,免得数据测试的时候不小心在线上环境操作。我找了张css-tricks的示意图: 五、favicon与base64favicon除了使用线上地址,还支持base64格式内联,例如: file://协议打开的本地HTML静态页面可以使用这种方式让浏览器地址栏的favicon显示。 六、结语下面这段是供大家参考的favicon现代用法,跨PC和移动端的项目可以参考参考: 另外,windows 8+系统还有browserconfig.xml的概念,可以用来创建贴片图标,类似下图这样: 使用示意: browserconfig.xml内容示意: #FFFFFF总之,favicon的水还是很深了,因为不同平台下的尺寸啊,使用方式啊都有所不同,本文的内容也只能尽量涉及。 如果以后出现新的平台,例如鸿蒙操作系统,说不定又是另外的favicon尺寸规则。 技术就是这样,有时候看上去好像挺了解的东西一旦深入,发现原来自己懂的只是皮毛。 要时刻保持谦逊才是! 本文为原创文章,欢迎分享,勿全文转载,如果内容你实在喜欢,可以加入收藏夹,永不过期,而且还会及时更新知识点以及修正错误,阅读体验也更好。 本文地址:https://www.zhangxinxu.com/wordpress/?p=8747 (本篇完) 相关文章本地开发设置个区分明显的favicon吧~ (0.650)响应式图片srcset全新释义sizes属性w描述符 (0.200)HTML5响应式图片技术中文图解 (0.200)HTML rel属性值释义大全 (0.200)link rel=alternate网站换肤功能最佳实现 (0.200)如何使用JS把相对地址变成绝对地址? (0.200)利用废弃的html rel import实现页面include功能 (0.200)为什么HTML 元素很少见人使用? (0.200)Web referrer策略详解与防盗链图片的显示 (0.200)聊聊Web网页中资源加载的优先级 (0.200)未来必热:SVG Sprites技术介绍 (RANDOM - 0.050) |
今日新闻 |
推荐新闻 |
CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3 |