vue-head 插件设置浏览器顶部 favicon 图标 - 动态管理 html 文档头部标签内容

目录

  • 需求
  • 实现1
    • 1. 安装插件
    • 2. 项目内 main.js 引入
    • 3. vue页面使用
  • 实现2
  • 其他

需求

vue项目中浏览器页面顶部图标可配置

在这里插入图片描述

实现1

使用 vue-head 插件实现

  • vue-head 插件可实现 html 文档中 head 标签中的内容动态配置(npm 官网 vue-head 插件)

1. 安装插件

npm install vue-head --save

2. 项目内 main.js 引入

import VueHead from 'vue-head'
Vue.use(VueHead)

3. vue页面使用

我所有页面(所有路由)都用这个图标,因为 vue 项目是 SPA,只有一个页面,所以我在 APP.vue 使用
如果有不同路由展示不同图标的需求,则可在不同路由对应的 vue 文件中单独配置 head。

<script>
import { mapGetters } from "vuex";export default {name: "app",components: {},provide() {return {reload: this.reload};},data() {return {// ...};},computed: {...mapGetters(["theme", 'userInfo', 'sysConfigData']),// ...},methods: {// ...}, mounted() {// ...},// 【主要代码】head 中每一个属性其实代表的就是 head 标签中的 mete标签、link标签、script标签、style标签等等……head: {meta: [// { name: 'application-name', content: 'Name of my application' },// { name: 'description', content: 'A description of the page', id: 'desc' }, // id to replace intead of create element// // ...// // Twitter// { name: 'twitter:title', content: 'Content Title' },// // with shorthand// { n: 'twitter:description', c: 'Content description less than 200 characters'},// // ...// // Google+ / Schema.org// { itemprop: 'name', content: 'Content Title' },// { itemprop: 'description', content: 'Content Title' },// // ...// // Facebook / Open Graph// { property: 'fb:app_id', content: '123456789' },// { property: 'og:title', content: 'Content Title' },// // with shorthand// { p: 'og:image', c: 'https://example.com/image.jpg' },// // ...],// 【主要代码】不能使用 this 会报错 undefined// link: [//   { rel: 'icon', href: require('@/assets/favicon.png'), sizes: '16x16', type: 'image/png' }// ],// 【主要代码】使用thislink() {return [{ rel: 'icon', href: require(`@/assets/${this.sysConfigData['mon.sys.favicon']}.png`), sizes: '16x16', type: 'image/png' }]},script: [// { type: 'text/javascript', src: 'cdn/to/script.js', async: true, body: true}, // Insert in body// // with shorthand// { t: 'application/ld+json', i: '{ "@context": "http://schema.org" }' },// // ...],style: [// { type: 'text/css', inner: 'body { background-color: #000; color: #fff}', undo: false },// // ...]}
};
</script>

实现2

使用原生 js 给图标标签 link 的图片地址 href 重新赋值

<link rel="icon" href="<%= BASE_URL %>favicon.ico">
<!-- 或 -->
<link id="favicon" rel="icon" href="<%= BASE_URL %>favicon.ico">
// 新的图标地址 iconUrl
document.querySelectAll("link[rel*='icon']").forEach(item => {item.href = iconUrl; // 赋值新的图标地址 iconUrl
})// 或
const dom = document.getElementById("favicon")
dom && (dom.href = iconUrl) // 赋值新的图标地址 iconUrl

其他

npm 官网 vue-head

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/654185.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

promethues基础概念

promethues是一个开源的系统监控以及报警系统&#xff0c;整个zabbix的功能&#xff0c;系统&#xff0c;网络&#xff0c;设备 promethues可以兼容网络和设置被&#xff0c;容器监控&#xff0c;告警系统&#xff0c;因为他和k8s是一个项目基金开发的产品&#xff0c;天生匹配…

代码随想录算法训练营第34天 | 1005.K次取反后最大化的数组和 134.加油站 135.分发糖果

K次取反后最大化的数组和 贪心局部最优&#xff1a;将绝对值大的负数变为正数&#xff0c;当前和变为最大&#xff1b;全局最优&#xff1a;整体获得最大和。 如果负数都变成正数之后&#xff0c;k > 0&#xff0c;仍然需要继续翻转&#xff0c;贪心局部最优&#xff1a;将最…

14.STM32F4 LCD屏幕概念及源码下载(LCD之一)

一、LCD液晶显示屏介绍 1、常见的显示设备 在目前市面上&#xff0c;常见的显示设备种类有&#xff1a;LED、显示数码管、点阵LED显示屏、LCD液晶显示屏&#xff0c;这几种设备的特点是&#xff1a; &#xff08;1&#xff09;LED LED灯是最简单的显示设备&#xff0c;它只有两…

SpringBoot 基础概念:注册BeanDefinition

SpringBoot 基础概念&#xff1a;注册BeanDefinition 1. 前言2. BeanDefinitionReaderUtils#registerBeanDefinition3. DefaultListableBeanFactory#registerBeanDefinition 1. 前言 问题&#xff1a;为什么需要注册BeanDefinition&#xff1f; 为了后续实例化。Spring架构是将…

Vue中虚拟Dom技术,你学会了吗?

​总的来说&#xff0c;虚拟DOM是Vue中一项关键的技术&#xff0c;通过优化DOM操作&#xff0c;提高了性能&#xff0c;同时使开发者更专注于数据的变化而不用过多关心底层DOM操作。 在Vue中&#xff0c;虚拟DOM&#xff08;Virtual DOM&#xff09;是一项关键的技术&#xff…

JavaWeb,ES6的学习

概述 ECMAScript 6&#xff0c;简称ES6&#xff0c;是JavaScript语言的一次重大更新。它于2015年发布&#xff0c;是原来的ECMAScript标准的第六个版本。ES6带来了大量的新特性&#xff0c;包括箭头函数、模板字符串、let和const关键字、解构、默认参数值、模块系统等等&#…

随便封装一下BaseActivity 之 二

接着上回&#xff0c;菊花也稍微封装一下 老规矩&#xff0c;上码 一、定义一个菊花interface&#xff0c;真正实现菊花的接口类 open interface ILoading {/*** 获取加载服务*/fun getLoad(): Any?/*** 注册目标view*/fun register(target: Any)/*** 注册目标view*/fun re…

天拓四方:物联网网关在机械制造企业的应用

随着物联网技术的不断发展&#xff0c;越来越多的机械制造企业开始探索如何利用物联网技术提升生产效率、降低运营成本。物联网网关作为物联网架构中的关键设备&#xff0c;能够实现设备间的数据交互与远程控制&#xff0c;为机械制造企业带来了巨大的商业价值。它能够实现设备…

负载均衡是什么,负载均衡有什么作用

一、什么是负载均衡 负载均衡是一种在计算机网络和系统架构中使用的技术&#xff0c;用于均衡分发工作负载到多个资源&#xff0c;比如&#xff1a;服务器、计算节点或存储设备上&#xff0c;以提高系统的性能、可伸缩性。 在传统的单个服务器架构中&#xff0c;当请求量增加…

leetcode-反转链表

206. 反转链表 题解&#xff1a; 定义两个指针prev和cur,分别指向当前节点的前一个节点和当前节点&#xff0c;初始时&#xff0c;prev为None&#xff0c;cur为head&#xff0c;在遍历的过程中&#xff0c;我们需要创建一个临时指针用来指向cur.next&#xff0c;因为cur指向p…

漏洞原理XSS存贮型漏洞

漏洞原理XSS存贮型漏洞 XSS&#xff08;跨站脚本攻击&#xff09;是一种常见的Web安全漏洞&#xff0c;它允许攻击者将恶意代码注入到网页中&#xff0c;进而攻击用户的浏览器。存储型XSS漏洞是一种特定类型的XSS漏洞&#xff0c;它发生在Web应用程序中&#xff0c;其中用户输入…

小红叒战小紫

概率dp #include <iostream> #include <string> #include <stack> #include <vector> #include <queue> #include <deque> #include <set> #include <map> #include <unordered_map> #include <unordered_set> #…

在租户内启用SharePoint Embedded

要开启 SharePoint Embedded&#xff0c;你得是管理员&#xff0c;然后按照这些步骤操作&#xff1a; 登录到你的 SharePoint 管理中心。在左边的菜单里找到“设置”选项&#xff0c;点进去。 3. 在设置页面里找到“SharePoint Embedded 应用”。 4.如果这个功能还没开启&…

Android Settings 显示电池点亮百分比

如题&#xff0c;Android 原生 Settings 里有个 电池电量百分比 的选项&#xff0c;打开后电池电量百分比会显示在状态栏。 基于 Android 13 &#xff0c; 代码在 ./packages/apps/Settings/src/com/android/settings/display/BatteryPercentagePreferenceController.java &am…

【flutter项目类型】project type如何区分

通过项目中.metadata内容区分 如 # Used by Flutter tool to assess capabilities and perform upgrades etc. # # This file should be version controlled and should not be manually edited.version:revision: 85684f9300908116a78138ea4c6036c35c9a1236channel: stablep…

【大数据】Flink 架构(二):数据传输

《Flink 架构》系列&#xff08;已完结&#xff09;&#xff0c;共包含以下 6 篇文章&#xff1a; Flink 架构&#xff08;一&#xff09;&#xff1a;系统架构Flink 架构&#xff08;二&#xff09;&#xff1a;数据传输Flink 架构&#xff08;三&#xff09;&#xff1a;事件…

(Aliexpress)速卖通卖家通过自养号补单提高出单率

在跨境电商领域&#xff0c;有些卖家可能会遇到这样的问题&#xff1a;自己的速卖通店铺始终没有订单产生。那么&#xff0c;当速卖通店铺一直不出单时&#xff0c;我们应该如何进行补救呢&#xff1f;今天珑哥将围绕这个问题展开探讨&#xff0c;并分享一些提升速卖通店铺销量…

HCIP复习课(mpls实验)

1、IP配置&#xff1a; R1&#xff1a; R2&#xff1a; R3&#xff1a; R4&#xff1a; R5&#xff1a; R6&#xff1a; R7&#xff1a; R8&#xff1a; 2、rip&#xff0c;ospf配置&#xff1a; R2&#xff1a; R3&#xff1a; R4&#xff1a; R5&#xff1a; R6&#xff1a…

信创联盟--朗思科技加入证券基金行业信息技术应用创新联盟,共促金融信创发展

近期&#xff0c;证券基金行业信息技术应用创新联盟&#xff08;以下简称&#xff1a;信创联盟&#xff09;新一批成员单位名单公布&#xff0c;朗思科技LanSive凭借产品创新以及实践案例成功入选&#xff0c;正式成为信创联盟成员单位。 信创联盟由上交所联合行业券商倡议发起…

Threejs 展示——fbx 格式模型导入

文章目录 需求分析 需求 导入fbx 格式的模型数据 分析 需要准备 fbx 格式的数据&#xff0c;如下所示 <template><div id"three-canvas" /> </template> <script> // import { Color, MOUSE, PerspectiveCamera, Scene, WebGLRenderer } …