怎么用SVG给favicon添加标识

一、favicon 的获取方式

想知道获取方式,可以先了解设置方式。

一般有两种方式可以设置网站的 favicon

名列前茅种,通过 link 标签设置(需要rel="icon"属性)

<link rel="icon" href="xxx.png">

第二种,直接在网站根目录放一张favicon.ico(必须是这个名称,浏览器默认的),html 中什么也不用设置

- 网站目录    index.html    favicon.ico

如果以上都没有设置,那么大概率会看到以下错误

怎么用SVG给favicon添加标识

了解这些,获取就简单了,先通过link获取,只要rel包含icon就行了

const link = document.querySelector('link[rel~="icon"]');

如果找不到,可以请求/favicon.ico,这里直接添加一个link

function getLink(){    const link = document.querySelector('link[rel~="icon"]');    if (link) {        return link    } else {        const link = document.createElement('link');        link.rel = "icon";        link.href = "/favicon.ico"        document.head.append(link);        return link    }}

这样获取的link就保证存在了,然后就是绘制

二、利用 canvas 进行绘制

由于需要合成图像,所以需要先绘制原有图像。提到图像绘制,可以想到 canvas 绘制,只需要一点点 canvas 基础知识就足够了。具体实现如下

const canvas = document.createElement('canvas'),ctx = canvas.getContext('2d'),img = new Image();img.crossOrigin = 'anonymous';img.onload = () => {    canvas.height = img.height;    canvas.width = img.width;    ctx.drawImage(img, 0, 0, canvas.width, canvas.height);    let dataURL = canvas.toDataURL("image/png");    resolve(dataURL);    canvas = null;};img.src = url;

由于存在/favicon.ico没有设置的情况,所以需要在 img 加载失败的时候给一张默认图

img.onerror = () => {    resolve("默认图base64");}

这样就能获取到 favicon 的图像信息了

三、利用 SVG 进行图片合成

在上面的基础上,其实可以继续通过 canvas 进行绘制,再绘制一个标签也不是难事。不过这里可以采用 SVG 的方式来进行绘制,有以下一些优点

  • 成本更低,比 canvas 更易理解

  • 灵活性高,可以通过 CSS 进行一些样式控制

首先,我们可以在 HTML 中自由的、像正常网页开发一样,绘制这样一个布局,相信没有什么难度

怎么用SVG给favicon添加标识

<body>  <strong>local</strong>  <img src='xxx.png'></body>

由于宽度有限,所以需要强制文本换行,超出隐藏,关键样式如下

strong{  position: absolute;  bottom: 0;  left: 50%;  transform: translateX(-50%);  text-transform: uppercase;  background-color: orange;  color: #fff;  padding: 0px 2px;  border-radius: 2px;  font-size: 12px;  box-sizing: border-box;  max-width: 100%;  width: max-content;  height: 16px;  line-height: 16px;  word-break: break-all;  overflow: hidden;}

接着,将这一段 html 放入 foreignObject标签中,关于 foreignObject 的作用,有兴趣的可以参考张鑫旭老师的这篇文章 SVG 简介与截图等应用,在这里,你可以简单理解为是可以包含 HTML 的标签,而 SVG 本身也是一种图片,这样就达到了合成图像的目的

怎么用SVG给favicon添加标识

具体实现如下

const link = getLink();const icon = await img2Base64(link.href);const favicon = `data:image/svg+xml;charset=utf-8,<svg xmlns="http://www.w3.org/2000/svg" width="32" height="32"><foreignObject x="0" y="0" width="100%" height="100%"><body xmlns="http://www.w3.org/1999/xhtml">  <style>    html,body{      height: 100%;      margin: 0;      text-align: center;    }    img{      display: block;      width: 100%;      height: 100%;      object-fit: contain;    }    strong{      position: absolute;      bottom: 0;      left: 50%;      transform: translateX(-50%);      text-transform: uppercase;      background-color: ${color};      color: #fff;      padding: 0px 2px;      border-radius: 2px;      font-size: 12px;      box-sizing: border-box;      max-width: 100%;      width: max-content;      height: 16px;      line-height: 16px;      word-break: break-all;      overflow: hidden;    }  </style>  <strong>local</strong>  <img src='${icon}'></img>  </body></foreignObject></svg>`.replace(/n/g, '').replace(/t/g, '').replace(/#/g, '%23')

这里需要注意几点

  • img 标签在 svg 中需要写成<img></img>闭合形态,不然会被认为结构错误

  • img 只能使用内联图片,比如 base64,这也是为何绘制原始 favicon 的原因

  • 如果使用内联 svg,需要对 svg 进行转义

  • 字符串中的单双引号问题也需要注意一下

然后,将生成的 SVG 直接设置为 favicon

link.href= favicon;

怎么用SVG给favicon添加标识

四、一些局限性

首先是兼容性。

目前只有 Chrome 和 Firefox 是支持的,为了兼容其他浏览器,可以用一个 .ico来兜底

<link rel="icon" href="/favicon.ico" sizes="any"><link rel="icon" href="/favicon.svg" type="image/svg+xml">

另外,在 Chrome 上还有一个限制(不知道是不是Chrome 更新后的限制),当 favicon 使用 svg 格式图片时,此时的 svg 会处于一种secure-static-mode,在这种模式下,所有动画都不会执行,会处于名列前茅帧,比如下面这个例子

<svg xmlns="http://www.w3.org/2000/svg" width="100%" height="100%">  <foreignObject width="100%" height="100%">      <body xmlns="http://www.w3.org/1999/xhtml">        <style>        html,body{            margin: 0;            height: 100%        }        div{            height: 100%;            background: pink;            animation: hue 3s infinite;        }        @keyframes hue {            to {                filter: hue-rotate(360deg)            }        }        </style>        <div></div>      </body>    </foreignObject></svg>

很简单的一个背景颜色动画。在 Firefox 上是用作 favicon 是有动画的

怎么用SVG给favicon添加标识

但是,Chrome 上却不行,只有禁止的名列前茅帧

怎么用SVG给favicon添加标识

所以之前想实现标识文本滚动的效果可以就此打住了

比较类似的还有媒体查询,之前在网上看到有这样的实现,直接在 SVG 中实现黑暗模式

<svg width="128" height="128" viewBox="0 0 128 128" fill="none" xmlns="http://www.w3.org/2000/svg">    <style>        path {            fill: #fff;        }        rect {            fill: #B09AFE;        }        @media (prefers-color-scheme: dark) {            path {                fill: #B09AFE;            }            rect {                fill: #fff;            }        }    </style>    <rect width="128" height="128" rx="64" fill="#B09AFE"/>    <path d="M32.375 37.5714H22C22 58.004 38.2596 74.5714 58.3125 74.5714V98.3571C58.3125 99.8107 59.4797 101 60.9062 101H66.0937C67.5203 101 68.6875 99.8107 68.6875 98.3571V74.5714C68.6875 54.1388 52.4279 37.5714 32.375 37.5714ZM94.625 27C80.9754 27 69.109 34.6808 62.9002 46.0286C67.3906 51.017 70.7139 57.079 72.4646 63.8018C90.7344 61.8692 105 46.1442 105 27H94.625Z" fill="white"/></svg>

但是也是同样的问题,只有 Firefox 下可行,Chrome是静止不动的

怎么用SVG给favicon添加标识

到此,关于“怎么用SVG给favicon添加标识”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注亿速云网站,小编会继续努力为大家带来更多实用的文章!

文章标题:怎么用SVG给favicon添加标识,发布者:亿速云,转载请注明出处:https://worktile.com/kb/p/23674

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
亿速云的头像亿速云认证作者
上一篇 2022年9月8日 上午1:40
下一篇 2022年9月8日 上午1:41

相关推荐

  • node服务CPU过高如何解决

    帮同事看一个CPU过高的问题 CPU涨了后掉不下去,最终同事排查出来是 某个依赖升级大版本后下线了默认的公共 redis 配置,(项目较老,很久没人动过)但需要业务方代码里自己配置关闭 redis服务。业务方有信息gap,所以不知道要关闭redis,导致上线后,一直在重试连接redis(多一个请求就…

    2022年9月16日
    2.0K00
  • html5中使用哪个标签嵌入音频

    在html5中,可以使用audio标签嵌入音频;该标签的作用就是定义声音,比如音乐或者其他声音流,并且该标签仅支持MP3、Wav和Ogg三种声音格式,语法为“<audio src=”音频文件”>”。”。 本教程操作环境:windows10系统、html5版本、De…

    2022年9月15日
    71700
  • vue-router中children怎么使用

    关于children的使用 children的使用场景 比如页面左侧显示菜单,右侧显示不同菜单下的内容,类似如下element网站,那么右侧部分的内容就是当前页面的children 存在如下场景,点击导航一跳转至页面1,导航二跳转页面2,且页面1中存在子页面 路由js如下: const routes…

    2022年8月30日
    83300
  • tracert命令有什么作用

    tracert命令的作用: 答:tracert命令是一种路由跟踪实用程序, 主要用于确定ip数据包访问目标所采取的路径。 tracert的使用需要在其后面加一个“ip地址”或者“url”, tracert会根据相对应的域名来进行转换的。 当数据从你计算机中通过多个网关传送到目的地时, 可以用来跟踪数…

    2022年8月31日
    94300
  • id是html的属性吗

    id属于html。id是html中的一个全局属性,可以用来配置所有元素共有行为、可以用在任何一个元素身上。id属性用于赋予某个标签少数的名称(标识符),当使用CSS或者JavaScript来操作这个标签时,就可以通过id属性来找到这个标签。 本教程操作环境:windows7系统、CSS3&&…

    2022年9月24日
    90000
  • 如何实现Weblogic SSRF漏洞复现

    一、使用docker搭建环境 docker安装及搭建环境教程:https://www.freebuf.com/sectool/252257.html 访问7001端口 二、漏洞复现步骤 1、漏洞存在页面 /uddiexplorer/SearchPublicRegistries.jsp 2、检查一下I…

    2022年9月24日
    65900
  • 电脑thinkpad台式机如何设置u盘启动

    thinkpad台式机设置u盘启动的方法 1.大多数电脑是在开机时按F2,进入bios,因电脑型号原因, 也存在其他快捷键,进入bios主界面如图。 2.切换到boot,此时电脑的有限启动方式是通过硬盘启动 3.通过上下键,选择option #1,按enter,切换到UEFI 4.按下enter后,…

    2022年9月6日
    62800
  • Vue3中toRef和toRefs函数怎么使用

    toRef 函数使用 首先呢, toRef 函数有两个参数。 toRef(操作对象, 对象属性) 好,接下来我们使用 toRef 函数写一个案例,还是和以前一样,页面展示一个用户的名称和年纪。 <template> <div> <h2>toRef toRefs 函…

    2022年9月21日
    67800
  • 如何做好项目管理

    做好项目管理有两个必须具备的核心技能:1、SMART原则;2、PDCA循环;除此以外,在项目进行的过程中我们还有:明确且达成共识的项目目标、有效的规划控制、制定项目标准及流程、合理的资源管理、建立完善的交流管理体系、利用有效的管理手段、激励等8个必须注意的点。 一、做好项目管理必须具备的两大核心技能…

    2022年3月19日
    52000
  • 服务器系统什么样子

    是的,在选择服务器系统时,一定要考虑到几个关键因素:1、稳定性和可靠性;2、安全性;3、支持的硬件和软件是否广泛;4、性能;5、兼容性。 对于绝大多数企业来说,稳定性和可靠性是首要考虑的因素,因为服务器的任何故障都可能导致业务中断,给企业带来严重的损失。选择拥有良好性能记录和业界认可的系统是非常关键…

    2024年4月23日
    3100
注册PingCode 在线客服
站长微信
站长微信
电话联系

400-800-1024

工作日9:30-21:00在线

分享本页
返回顶部