iis服务器助手广告
返回顶部
首页 > 资讯 > 前端开发 > node.js >怎么用SVG给favicon添加标识
  • 476
分享到

怎么用SVG给favicon添加标识

2024-04-02 19:04:59 476人浏览 薄情痞子
摘要

这篇文章主要介绍“怎么用SVG给favicon添加标识”,在日常操作中,相信很多人在怎么用SVG给favicon添加标识问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”怎么用S

这篇文章主要介绍“怎么用SVG给favicon添加标识”,在日常操作中,相信很多人在怎么用SVG给favicon添加标识问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”怎么用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添加标识”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注编程网网站,小编会继续努力为大家带来更多实用的文章!

--结束END--

本文标题: 怎么用SVG给favicon添加标识

本文链接: https://www.lsjlt.com/news/98715.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 怎么用SVG给favicon添加标识
    这篇文章主要介绍“怎么用SVG给favicon添加标识”,在日常操作中,相信很多人在怎么用SVG给favicon添加标识问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”怎么用S...
    99+
    2024-04-02
  • k8s怎么给node添加标签
    这篇文章主要介绍“k8s怎么给node添加标签”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“k8s怎么给node添加标签”文章能帮助大家解决问题。一、为什么需要标签?k8s集群如果由大量节点组成,可...
    99+
    2023-07-05
  • 浅谈怎么给Python添加类型标注
    Python 添加类型标注 Python 如此简洁,书写者在声明变量时甚至无需考虑类型。 但是简洁与复杂间,是存在一个平衡点的。当我们书写较为复杂的项目时,还是希望可以拥有「静态类型...
    99+
    2024-04-02
  • 使用R语言怎么给直方图添加标签
    这篇文章给大家介绍使用R语言怎么给直方图添加标签,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。hist(data$MEDV,col="grey")#可以看到目标数据的总体分布legend(35,17...
    99+
    2023-06-14
  • Python中怎么使用matplotlib给柱状图添加数据标签bar_label()
    本篇内容主要讲解“Python中怎么使用matplotlib给柱状图添加数据标签bar_label()”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Python中怎么使用matplotlib给柱...
    99+
    2023-06-29
  • jquery怎么给类添加事件
    这篇文章主要介绍了jquery怎么给类添加事件的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇jquery怎么给类添加事件文章都会有所收获,下面我们一起来看看吧。   jque...
    99+
    2024-04-02
  • navicat怎么给表添加备注
    在 navicat 中为表添加备注的方法:1. 打开表定义;2. 切换到备注选项卡;3. 输入备注;4. 应用更改,完成备注添加。 如何使用 Navicat 为表添加备注 在 Navi...
    99+
    2024-04-23
    navicat
  • mysql怎么给表添加分区
    要给表添加分区,可以使用ALTER TABLE语句来实现。以下是一个示例: ALTER TABLE table_name PARTI...
    99+
    2024-04-09
    mysql
  • qt怎么给widget添加图片
    要给Qt的widget添加图片,可以使用QPixmap类来加载图片,并将其设置为widget的背景或者在widget上绘制。以下是一...
    99+
    2024-04-02
  • mysql怎么给表添加备注
    mysql表可通过alter table或create table语句添加备注,提供表及其列的目的信息。查询表备注可使用select table_comment from in...
    99+
    2024-04-22
    mysql
  • mysql怎么给表添加字段
    非常抱歉,由于您没有提供文章标题,我无法为您生成一篇高质量的文章。请您提供文章标题,我将尽快为您生成一篇优质的文章。...
    99+
    2024-05-21
  • JS怎么给dropDownList()添加事件
    在JS中给dropDownList添加事件可以使用addEventListener()方法,具体步骤如下:1. 获取到dropDow...
    99+
    2023-08-18
    JS
  • java怎么给list添加对象
    Java中可以使用`add()`方法向List中添加对象。假设有一个名为`Person`的类,我们可以先创建一个`Person`对象...
    99+
    2023-08-15
    java list
  • XP系统下怎么给浏览器标题添加文字
    这篇文章主要讲解了“XP系统下怎么给浏览器标题添加文字”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“XP系统下怎么给浏览器标题添加文字”吧!  具体如下:  1、点击开始菜单,选择“运行”,...
    99+
    2023-06-13
  • vue3怎么使用svg图标
    今天小编给大家分享一下vue3怎么使用svg图标的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。方式1使用在线链接访问在ico...
    99+
    2023-07-05
  • 怎么用Java给PDF文档添加页码
    这篇文章主要介绍“怎么用Java给PDF文档添加页码”,在日常操作中,相信很多人在怎么用Java给PDF文档添加页码问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”怎么用Java给PDF文档添加页码”的疑惑有所...
    99+
    2023-06-02
  • Swift怎么给应用添加3D Touch菜单
    要给Swift应用添加3D Touch菜单,可以按照以下步骤进行操作: 在你的应用的 Info.plist 文件中添加一个新的键值...
    99+
    2023-10-22
    Swift
  • 利用JAVA怎么给图片添加水印
    这期内容当中小编将会给大家带来有关利用JAVA怎么给图片添加水印,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。印的类型:单文字水印单图片水印多文字水印多图片水印水印的开发流程:创建图片缓存对象创建Java...
    99+
    2023-05-31
    java ava
  • 怎么用java给文件行添加序号
    使用Java可以通过以下几个步骤给文件行添加序号:1. 打开文件并读取内容。2. 创建一个输出流,用于写入添加序号后的内容。3. 使...
    99+
    2023-10-18
    java
  • css怎么给图片添加蒙版
    这篇文章主要介绍“css怎么给图片添加蒙版”,在日常操作中,相信很多人在css怎么给图片添加蒙版问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”css怎么给图片添加蒙版”的疑惑有所帮助!接下来,请跟着小编一起来...
    99+
    2023-06-20
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作