Table des matières
1. Comment obtenir un favicon
二、利用 canvas 进行绘制
三、利用 SVG 进行图片合成
四、一些局限性
Maison interface Web tutoriel CSS Explication détaillée de l'utilisation de SVG pour ajouter un logo au favicon

Explication détaillée de l'utilisation de SVG pour ajouter un logo au favicon

Sep 07, 2022 am 10:30 AM
css css3 前端 svg

Comment ajouter un logo à un favicon en utilisant SVG ? L'article suivant vous présentera comment utiliser SVG pour générer un favicon avec logo. J'espère qu'il vous sera utile !

J'ai déjà créé un plug-in Chrome, qui peut générer différentes icônes en fonction de différentes adresses. Cela permet de distinguer facilement différents environnements de développement. L'effet est le suivant

Le processus de mise en œuvre principal n'est en fait pas compliqué. . Tout d'abord, obtenez le favicon du site Web, puis ajoutez un logo au favicon, redessinez-le et générez-le

Parmi eux, l'icône ici est générée via SVG. [Apprentissage recommandé : Tutoriel vidéo CSS]

1. Comment obtenir un favicon

Si vous voulez savoir comment l'obtenir, vous pouvez d'abord comprendre la méthode de paramétrage.

Il existe généralement deux façons de définir le favicon du site Web. favicon

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

<link>
Copier après la connexion

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

- 网站目录
    index.html
    favicon.ico
Copier après la connexion

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

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

const link = document.querySelector('link[rel~="icon"]');
Copier après la connexion

如果找不到,可以请求/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
    }
}
Copier après la connexion

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

二、利用 canvas 进行绘制

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

const canvas = document.createElement('canvas'),
ctx = canvas.getContext('2d'),
Explication détaillée de lutilisation de SVG pour ajouter un logo au favicon = new Image();
Explication détaillée de lutilisation de SVG pour ajouter un logo au favicon.crossOrigin = 'anonymous';
Explication détaillée de lutilisation de SVG pour ajouter un logo au favicon.onload = () => {
    canvas.height = Explication détaillée de lutilisation de SVG pour ajouter un logo au favicon.height;
    canvas.width = Explication détaillée de lutilisation de SVG pour ajouter un logo au favicon.width;
    ctx.drawImage(Explication détaillée de lutilisation de SVG pour ajouter un logo au favicon, 0, 0, canvas.width, canvas.height);
    let dataURL = canvas.toDataURL("image/png");
    resolve(dataURL);
    canvas = null;
};
Explication détaillée de lutilisation de SVG pour ajouter un logo au favicon.src = url;
Copier après la connexion

由于存在/favicon.ico没有设置的情况,所以需要在 Explication détaillée de lutilisation de SVG pour ajouter un logo au favicon 加载失败的时候给一张默认图

Explication détaillée de lutilisation de SVG pour ajouter un logo au favicon.onerror = () => {
    resolve("默认图base64");
}
Copier après la connexion

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

三、利用 SVG 进行图片合成

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

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

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

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

  <strong>local</strong>
  <explication d de lutilisation svg pour ajouter un logo au favicon>
</explication>
Copier après la connexion

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

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;
}
Copier après la connexion

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

具体实现如下

const link = getLink();
const icon = await Explication détaillée de lutilisation de SVG pour ajouter un logo au favicon2Base64(link.href);
const favicon = `data:image/svg+xml;charset=utf-8,<svg><foreignobject>
  <style>
    html,body{
      height: 100%;
      margin: 0;
      text-align: center;
    }
    Explication détaillée de lutilisation de SVG pour ajouter un logo au 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>
  <explication d de lutilisation svg pour ajouter un logo au favicon></explication>détaillée de lutilisation de SVG pour ajouter un logo au favicon>
  </foreignobject></svg>`.replace(/\n/g, '').replace(/\t/g, '').replace(/#/g, '%23')
Copier après la connexion

这里需要注意几点

  • Explication détaillée de lutilisation de SVG pour ajouter un logo au favicon 标签在 svg 中需要写成<explication d de lutilisation svg pour ajouter un logo au favicon></explication>détaillée de lutilisation de SVG pour ajouter un logo au favicon>

    Le premier est défini via la balise link (nécessite l'attribut rel="icon")
link.href= favicon;
Copier après la connexion
  • Le second consiste à placer une photo directement dans le

    répertoire racine du site Web

    favicon.ico (doit être ce nom, celui par défaut du navigateur), il n'est pas nécessaire de définir quoi que ce soit en html
  • <link>
    <link>
    Copier après la connexion
    Copier après la connexion
  • Si aucun des éléments ci-dessus n'est défini, alors il y a un niveau élevé probabilité que vous voyiez l'erreur suivante

  • Comprendre ceux-ci, l'obtenir est simple. Obtenez-le d'abord via link, à condition de rel<.> contient une <code>icône et tout ira bien

    <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>
    Copier après la connexion
    Copier après la connexion
    Si vous ne le trouvez pas, vous pouvez demander /favicon.ico et ajouter un lien directement ici
  • <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>
    Copier après la connexion
    Copier après la connexion
    Le lien obtenu de cette manière est garanti d'exister, puis dessinez

    Deuxièmement, utilisez la toile pour dessiner

    Puisque l'image doit être synthétisée, le l'image originale doit d'abord être dessinée. Lorsqu'il s'agit de dessiner des images, vous pouvez penser au dessin sur toile, et seules quelques connaissances de base en toile suffisent. L'implémentation spécifique est la suivante

    rrreee

    Puisqu'il existe une situation où /favicon.ico n'est pas défini, il est nécessaire de donner une image par défaut lorsque l'Explication détaillée de lutilisation de SVG pour ajouter un logo au favicon ne parvient pas à se charger

    rrreee🎜De cette façon , les informations d'image du favicon peuvent être obtenues 🎜🎜🎜3. Utilisez SVG pour la synthèse d'image🎜🎜🎜Sur la base de ce qui précède, vous pouvez réellement continuer à dessiner sur le canevas, et il n'est pas difficile de dessiner une autre étiquette. Cependant, SVG peut être utilisé pour dessiner ici, ce qui présente les avantages suivants🎜
      🎜🎜Moins coûteux et plus facile à comprendre que Canvas🎜🎜🎜🎜Grande flexibilité, vous pouvez Un certain contrôle de style via CSS🎜🎜🎜🎜Tout d'abord, nous pouvons librement dessiner une telle mise en page en HTML comme un développement Web normal, je pense que ce n'est pas difficile🎜🎜🎜rrre ee 🎜En raison de La largeur est limitée, il est donc nécessaire de forcer le texte à s'enrouler au-delà du masquage. Le style clé est le suivant🎜rrreee🎜Ensuite, placez ce morceau de HTML dans la balise étrangerObject. ForeignObject, ceux qui sont intéressés peuvent se référer à l'article du professeur Zhang Xinxu. Cet article présente l'introduction de SVG, des captures d'écran et d'autres applications. Ici, vous pouvez simplement comprendre qu'il s'agit d'une balise qui peut contenir du HTML, et que SVG lui-même est aussi une sorte d'image, donc. atteindre l'objectif de synthèse d'images🎜🎜🎜🎜 L'implémentation spécifique est la suivante🎜rrreee🎜Quelques points doivent être notés ici🎜
        🎜🎜 La balise Explication détaillée de lutilisation de SVG pour ajouter un logo au favicon dans svg doit être écrite sous forme fermée <explication d de lutilisation svg pour ajouter un logo au favicon></explication>détaillée de lutilisation de SVG pour ajouter un logo au favicon> code>, sinon elle sera considérée comme ayant une erreur structurelle🎜🎜🎜🎜Explication détaillée de lutilisation de SVG pour ajouter un logo au favicon ne peut utiliser que des images en ligne, comme base64, c'est pourquoi le favicon original est dessiné🎜🎜🎜🎜Si vous utilisez un svg en ligne, vous devez échapper au svg 🎜🎜🎜🎜Vous devez également faire attention aux guillemets simples et doubles dans la chaîne🎜🎜 🎜🎜Ensuite, définissez le SVG généré directement sur le favicon🎜rrreee🎜🎜🎜🎜De cette façon, il peut être rendu normalement~🎜🎜Vous pouvez vous référer au projet d'implémentation complet : https://github.com/XboxYan/auto -dev-favicon-chrome-plugin🎜

        四、一些局限性

        首先是兼容性。

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

        <link>
        <link>
        Copier après la connexion
        Copier après la connexion

        另外,在 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>
        Copier après la connexion
        Copier après la connexion

        很简单的一个背景颜色动画。在 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>
        Copier après la connexion
        Copier après la connexion

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

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

        (学习视频分享:web前端

    Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

    Déclaration de ce site Web
    Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn

    Outils d'IA chauds

    Undresser.AI Undress

    Undresser.AI Undress

    Application basée sur l'IA pour créer des photos de nu réalistes

    AI Clothes Remover

    AI Clothes Remover

    Outil d'IA en ligne pour supprimer les vêtements des photos.

    Undress AI Tool

    Undress AI Tool

    Images de déshabillage gratuites

    Clothoff.io

    Clothoff.io

    Dissolvant de vêtements AI

    AI Hentai Generator

    AI Hentai Generator

    Générez AI Hentai gratuitement.

    Article chaud

    R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
    3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
    R.E.P.O. Meilleurs paramètres graphiques
    3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
    R.E.P.O. Comment réparer l'audio si vous n'entendez personne
    3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
    WWE 2K25: Comment déverrouiller tout dans Myrise
    4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌

    Outils chauds

    Bloc-notes++7.3.1

    Bloc-notes++7.3.1

    Éditeur de code facile à utiliser et gratuit

    SublimeText3 version chinoise

    SublimeText3 version chinoise

    Version chinoise, très simple à utiliser

    Envoyer Studio 13.0.1

    Envoyer Studio 13.0.1

    Puissant environnement de développement intégré PHP

    Dreamweaver CS6

    Dreamweaver CS6

    Outils de développement Web visuel

    SublimeText3 version Mac

    SublimeText3 version Mac

    Logiciel d'édition de code au niveau de Dieu (SublimeText3)

    Comment insérer des photos sur bootstrap Comment insérer des photos sur bootstrap Apr 07, 2025 pm 03:30 PM

    Il existe plusieurs façons d'insérer des images dans Bootstrap: insérer directement les images, en utilisant la balise HTML IMG. Avec le composant d'image bootstrap, vous pouvez fournir des images réactives et plus de styles. Définissez la taille de l'image, utilisez la classe IMG-FLUID pour rendre l'image adaptable. Réglez la bordure en utilisant la classe IMG-border. Réglez les coins arrondis et utilisez la classe Roundée IMG. Réglez l'ombre, utilisez la classe Shadow. Redimensionner et positionner l'image, en utilisant le style CSS. À l'aide de l'image d'arrière-plan, utilisez la propriété CSS d'image d'arrière-plan.

    Comment configurer le cadre de bootstrap Comment configurer le cadre de bootstrap Apr 07, 2025 pm 03:27 PM

    Pour configurer le framework Bootstrap, vous devez suivre ces étapes: 1. Référez le fichier bootstrap via CDN; 2. Téléchargez et hébergez le fichier sur votre propre serveur; 3. Incluez le fichier bootstrap dans HTML; 4. Compiler les sass / moins au besoin; 5. Importer un fichier personnalisé (facultatif). Une fois la configuration terminée, vous pouvez utiliser les systèmes, composants et styles de grille de Bootstrap pour créer des sites Web et des applications réactifs.

    Comment utiliser le bouton bootstrap Comment utiliser le bouton bootstrap Apr 07, 2025 pm 03:09 PM

    Comment utiliser le bouton bootstrap? Introduisez Bootstrap CSS pour créer des éléments de bouton et ajoutez la classe de bouton bootstrap pour ajouter du texte du bouton

    Comment écrire des lignes fendues sur bootstrap Comment écrire des lignes fendues sur bootstrap Apr 07, 2025 pm 03:12 PM

    Il existe deux façons de créer une ligne divisée bootstrap: en utilisant la balise, qui crée une ligne divisée horizontale. Utilisez la propriété CSS Border pour créer des lignes de fractionnement de style personnalisées.

    Comment redimensionner le bootstrap Comment redimensionner le bootstrap Apr 07, 2025 pm 03:18 PM

    Pour ajuster la taille des éléments dans Bootstrap, vous pouvez utiliser la classe de dimension, qui comprend: ajuster la largeur: .col-, .w-, .mw-ajustement Hauteur: .h-, .min-h-, .max-h-

    Comment afficher la date de bootstrap Comment afficher la date de bootstrap Apr 07, 2025 pm 03:03 PM

    Réponse: Vous pouvez utiliser le composant de sélecteur de date de bootstrap pour afficher les dates dans la page. Étapes: Présentez le framework bootstrap. Créez une boîte d'entrée de sélecteur de date dans HTML. Bootstrap ajoutera automatiquement des styles au sélecteur. Utilisez JavaScript pour obtenir la date sélectionnée.

    Les rôles de HTML, CSS et JavaScript: responsabilités de base Les rôles de HTML, CSS et JavaScript: responsabilités de base Apr 08, 2025 pm 07:05 PM

    HTML définit la structure Web, CSS est responsable du style et de la mise en page, et JavaScript donne une interaction dynamique. Les trois exercent leurs fonctions dans le développement Web et construisent conjointement un site Web coloré.

    Comment utiliser Bootstrap en Vue Comment utiliser Bootstrap en Vue Apr 07, 2025 pm 11:33 PM

    L'utilisation de bootstrap dans vue.js est divisée en cinq étapes: installer bootstrap. Importer un bootstrap dans main.js. Utilisez le composant bootstrap directement dans le modèle. Facultatif: style personnalisé. Facultatif: utilisez des plug-ins.

    See all articles