Heim  >  Artikel  >  Web-Frontend  >  Ausführliche Erklärung der Verwendung von SVG zum Hinzufügen eines Logos zum Favicon

Ausführliche Erklärung der Verwendung von SVG zum Hinzufügen eines Logos zum Favicon

青灯夜游
青灯夜游nach vorne
2022-09-07 10:30:161703Durchsuche

Wie füge ich mit SVG ein Logo zum Favicon hinzu? Im folgenden Artikel erfahren Sie, wie Sie mit SVG ein Favicon mit Logo erstellen.

Ich habe zuvor ein Chrome-Plug-in erstellt, das je nach Adresse unterschiedliche Symbole generieren kann. Der Effekt ist wie folgt:

Der Hauptimplementierungsprozess ist eigentlich nicht kompliziert Holen Sie sich zuerst das Website-Favicon, fügen Sie dann ein Logo zum Favicon hinzu, zeichnen Sie es neu und generieren Sie es. Unter anderem wird das Symbol hier über SVG generiert. [Empfohlenes Lernen:

CSS-Video-Tutorial

]

1. So erhalten Sie das Favicon

Wenn Sie wissen möchten, wie Sie es erhalten, können Sie zunächst die Einstellungsmethode verstehen.

Es gibt im Allgemeinen zwei Möglichkeiten, das Favicon der Website festzulegen.

Die erste Möglichkeit wird über das Tag link festgelegt (benötigt das Attribut rel="icon").

<link>
Die zweite Möglichkeit besteht darin, ein Foto direkt im

​​zu platzieren Website-Stammverzeichnisfavicon

第一种,通过 link 标签设置(需要rel="icon"属性)

- 网站目录
    index.html
    favicon.ico

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

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

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

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

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
    }
}

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

const canvas = document.createElement('canvas'),
ctx = canvas.getContext('2d'),
Ausführliche Erklärung der Verwendung von SVG zum Hinzufügen eines Logos zum Favicon = new Image();
Ausführliche Erklärung der Verwendung von SVG zum Hinzufügen eines Logos zum Favicon.crossOrigin = 'anonymous';
Ausführliche Erklärung der Verwendung von SVG zum Hinzufügen eines Logos zum Favicon.onload = () => {
    canvas.height = Ausführliche Erklärung der Verwendung von SVG zum Hinzufügen eines Logos zum Favicon.height;
    canvas.width = Ausführliche Erklärung der Verwendung von SVG zum Hinzufügen eines Logos zum Favicon.width;
    ctx.drawImage(Ausführliche Erklärung der Verwendung von SVG zum Hinzufügen eines Logos zum Favicon, 0, 0, canvas.width, canvas.height);
    let dataURL = canvas.toDataURL("image/png");
    resolve(dataURL);
    canvas = null;
};
Ausführliche Erklärung der Verwendung von SVG zum Hinzufügen eines Logos zum Favicon.src = url;

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

二、利用 canvas 进行绘制

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

Ausführliche Erklärung der Verwendung von SVG zum Hinzufügen eines Logos zum Favicon.onerror = () => {
    resolve("默认图base64");
}

由于存在/favicon.ico没有设置的情况,所以需要在 Ausführliche Erklärung der Verwendung von SVG zum Hinzufügen eines Logos zum Favicon 加载失败的时候给一张默认图

  <strong>local</strong>
  <ausf erkl der verwendung von svg zum hinzuf eines logos favicon>
</ausf>

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

三、利用 SVG 进行图片合成

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

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

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

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

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;
}

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

const link = getLink();
const icon = await Ausführliche Erklärung der Verwendung von SVG zum Hinzufügen eines Logos zum Favicon2Base64(link.href);
const favicon = `data:image/svg+xml;charset=utf-8,<svg><foreignobject>
  <style>
    html,body{
      height: 100%;
      margin: 0;
      text-align: center;
    }
    Ausführliche Erklärung der Verwendung von SVG zum Hinzufügen eines Logos zum Favicon{
      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>
  <ausf erkl der verwendung von svg zum hinzuf eines logos favicon></ausf>ührliche Erklärung der Verwendung von SVG zum Hinzufügen eines Logos zum Favicon>
  </foreignobject></svg>`.replace(/\n/g, '').replace(/\t/g, '').replace(/#/g, '%23')

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

具体实现如下

link.href= favicon;

这里需要注意几点

  • Ausführliche Erklärung der Verwendung von SVG zum Hinzufügen eines Logos zum Favicon 标签在 svg 中需要写成<ausf erkl der verwendung von svg zum hinzuf eines logos favicon></ausf>ührliche Erklärung der Verwendung von SVG zum Hinzufügen eines Logos zum Favicon> favicon.ico (muss dieser Name sein, der Browser-Standard), es ist nicht nötig, etwas in HTML festzulegen

    <link>
    <link>
  • Wenn keines der oben genannten festgelegt ist, liegt ein Hoch vor Wahrscheinlichkeit, dass Ihnen der folgende Fehler angezeigt wird:
  • „Ausführliche Erklärung der Verwendung von SVG zum Hinzufügen eines Logos zum Favicon“ title="Ausführliche Erklärung der Verwendung von SVG zum Hinzufügen eines Logos zum Favicon" wird geladen ="lazy"/>

  • Dabei ist es einfach, es über link zu erhalten, solange rel enthält <code>icon und es wird in Ordnung sein
  • <svg>
      <foreignobject>
          
            <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>
          
        </foreignobject>
    </svg>

    Wenn Sie es nicht finden können, können Sie /favicon.ico anfordern und einen Link direkt hier

    <svg>
        <style>
            path {
                fill: #fff;
            }
            rect {
                fill: #B09AFE;
            }
            @media (prefers-color-scheme: dark) {
                path {
                    fill: #B09AFE;
                }
                rect {
                    fill: #fff;
                }
            }
        </style>
        <rect></rect>
        <path></path>
    </svg>
  • Der auf diese Weise erhaltene link existiert garantiert und zeichnet dann
  • Zweitens verwenden Sie die Leinwand zum Zeichnen

Da das Bild synthetisiert werden muss, muss das Das Originalbild muss zuerst gezeichnet werden. Wenn es um das Zeichnen von Bildern geht, können Sie an das Zeichnen auf Leinwand denken, und nur ein wenig Grundwissen über Leinwand reicht aus. Die konkrete Implementierung lautet wie folgt

rrreee

Da es eine Situation gibt, in der /favicon.ico nicht festgelegt ist, muss ein Standardbild angegeben werden, wenn das Bild nicht geladen werden kannrrreee

Auf diese Weise , die Bildinformationen des Favicons können abgerufen werden

3. Verwenden Sie SVG für die Bildsynthese

🎜🎜Auf der Grundlage des oben Gesagten können Sie tatsächlich weiterhin durch die Leinwand zeichnen, und es ist nicht schwierig, ein weiteres Etikett zu zeichnen. Hier kann jedoch SVG zum Zeichnen verwendet werden, was die folgenden Vorteile bietet🎜
    🎜🎜Geringere Kosten und einfacher zu verstehen als Leinwand🎜🎜🎜🎜Hohe Flexibilität, das können Sie Etwas Stilkontrolle durch CSS🎜🎜🎜🎜Zuallererst können wir ein solches Layout wie bei der normalen Webentwicklung frei zeichnen🎜🎜🎜rrre. e e🎜Wegen Die Breite ist begrenzt, daher muss der Text so umbrochen werden, dass er nicht ausgeblendet wird. Der Schlüsselstil lautet wie folgt: Fügen Sie dann dieses HTML-Stück in das Tag foreignObject ein Wenn Sie sich für ForeignObject interessieren, können Sie sich auf den Artikel von Lehrer Zhang Erreichen des Zwecks der Synthese von Bildern🎜🎜🎜🎜 Die spezifische Implementierung ist wie folgt🎜rrreee🎜Hier müssen einige Punkte beachtet werden🎜
      🎜🎜 Das Ausführliche Erklärung der Verwendung von SVG zum Hinzufügen eines Logos zum Favicon-Tag in SVG muss in der geschlossenen Form <ausf erkl der verwendung von svg zum hinzuf eines logos favicon></ausf>ührliche Erklärung der Verwendung von SVG zum Hinzufügen eines Logos zum Favicon> code> geschrieben werden, andernfalls wird davon ausgegangen, dass es einen Strukturfehler aufweist. 🎜🎜🎜🎜Ausführliche Erklärung der Verwendung von SVG zum Hinzufügen eines Logos zum Favicon kann nur Inline-Bilder verwenden. B. base64, weshalb das ursprüngliche Favicon gezeichnet wird🎜🎜🎜🎜Wenn Sie Inline-SVG verwenden, müssen Sie das SVG maskieren 🎜🎜🎜🎜Sie müssen auch auf die einfachen und doppelten Anführungszeichen in der Zeichenfolge achten🎜🎜 🎜🎜Dann setzen Sie das generierte SVG direkt auf das Favicon🎜rrreee🎜🎜🎜🎜Auf diese Weise kann es normal gerendert werden~🎜🎜Sie können sich auf das vollständige Implementierungsprojekt beziehen: https://github.com/XboxYan/auto -dev-favicon-chrome-plugin🎜

      四、一些局限性

      首先是兼容性。

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

      <link>
      <link>

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

      <svg>
        <foreignobject>
            
              <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>
            
          </foreignobject>
      </svg>

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

      但是,Chrome 上却不行,只有禁止的第一帧

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

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

      <svg>
          <style>
              path {
                  fill: #fff;
              }
              rect {
                  fill: #B09AFE;
              }
              @media (prefers-color-scheme: dark) {
                  path {
                      fill: #B09AFE;
                  }
                  rect {
                      fill: #fff;
                  }
              }
          </style>
          <rect></rect>
          <path></path>
      </svg>

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

      总的来说,SVG 在绘制方面提供了无限可能,不仅仅是本文中的案例,觉得 canvas 过于复杂的都可以考虑这一方案

      (学习视频分享:web前端

Das obige ist der detaillierte Inhalt vonAusführliche Erklärung der Verwendung von SVG zum Hinzufügen eines Logos zum Favicon. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Dieser Artikel ist reproduziert unter:segmentfault.com. Bei Verstößen wenden Sie sich bitte an admin@php.cn löschen