返回顶部
首页 > 资讯 > 前端开发 > JavaScript >webpack如何自动生成网站图标详解
  • 197
分享到

webpack如何自动生成网站图标详解

2024-04-02 19:04:59 197人浏览 八月长安
摘要

目录介绍准备使用兼容结语介绍 我们在自己搭建项目的时候,有时候主管给你一张loGo图片,让你自己想办法变成网站图标,有时候项目需求里不仅仅是多种尺寸的favicon.ico,还有安卓

介绍

我们在自己搭建项目的时候,有时候主管给你一张loGo图片,让你自己想办法变成网站图标,有时候项目需求里不仅仅是多种尺寸的favicon.ico,还有安卓和iOS在apple-touch-icon这类私有属性的各种尺寸需要icon,其实到是有些在线工具或者本地软件让你去使用,但是就是有点烦躁,有没有考虑过完全无视这个任务,让项目构建打包之后自己生成,不用再去费心了。本期我们就给大家介绍这样一个自动将图片处理成网站图标的插件 —— html-webpack-plugin。他可以自动帮我们把需要各种格式各种尺寸自动生成,就是这么方便省心。

准备

先准备要生成图标的原图,可以是jpg,png,也可以是svg。我们为了演示就一样来一份吧。

然后在 WEBpack.config.js 写个基础结构,如下:

// webpack.config.js
const HtmlWebpackPlugin = require("html-webpack-plugin");
const { CleanWebpackPlugin } = require('clean-webpack-plugin');
const plugins = [
  new CleanWebpackPlugin(),
  new HtmlWebpackPlugin({
    filename: "index.html",
    template: path.resolve(__dirname, "public/index.html")
  })
]
module.exports = {
  // ...
  plugins
}

后面,我们就要在plugins这个数组里搞事情了。

使用

我们先来安装一下

# NPM
npm i -D favicons favicons-webpack-plugin
# YARN
yarn add -D favicons favicons-webpack-plugin

我们要安装两个东西一个是favicons-webpack-plugin也就是插件主体,而另一个就是favicons,它是用于生成网站图标及其相关文件的 node.js 模块。其实favicons-webpack-plugin本身就是一次对favicons的借用。

let faviconsWebpackPlugin = new FaviconsWebpackPlugin({
  logo : './public/static/src/logo.svg', // 目标图标路径
  cache : true,  // 启用缓存并可选择指定存储缓存数据的路径,禁用缓存可能会增加构建时间
  prefix : 'assets/logo/' ,   // 生成资产的前缀路径
  mode : 'webapp' ,  // 打包模式,默认为auto,可选webapp/light/auto 
  devMode : 'light', // 生产模式,默认为light,可选webapp/light 
})
plugins.push(faviconsWebpackPlugin)

十分的简单,我们先要配置好要生成的那图片的路径,还有生成图片后的位置,至于mode和devMode分别是打包和生产的两种模式。webapp与light顾名思义就是构建之后的图片是否完全满足生成需要,一般生产环境下为了更快打开调试页面都会选用light,这样他就会生成一个图标,以最快速度去构建。而webapp则会生成一堆图标。

言归正传,我们刚写的代码,执行打包先康康会发生什么变化吧:

图片目录下已经生成了格式各样的图标。

index.html里也自动给引用了这些图片。

我们再运行一下,康康网站图标是否有啥变化吧。

还记得刚才是做了三种格式的图片吗,刚都测了一下,都可以很好的展示出来。

但是,你可能会想,我用不了这么多图标啊,我就想生成网站的favicon.ico,这可如何是好?

别急,刚才说了这个插件就是对favicons的借用,那么favicons有的这里也可以有。

上面是favicons一部分源码,这部分说了能生成什么图标的开关,接下来,我们就在刚才的基础上改动一下吧。

let faviconsWebpackPlugin = new FaviconsWebpackPlugin({
  // ...
  favicons: {
    appName: "",
    appDescription: "",
    developerName: "",
    developerURL: null,
    background: '#fff',
    theme_color: '#666',
    icons: {
      firefox:false,           // Firefox OS 图标
      windows:false,           // Windows 8 图标
      coast: false,            // Opera 图标
      Android : false ,        // Android 主屏幕图标
      appleIcon : false,       // Apple 触摸图标
      appleStartup : false,    // Apple 启动图像
      favicons : true ,        // 网站图标
      yandex : false,          // Yandex 图标
    }
  }

除了可以有设置图标种类开关外,还可以设置一些别的比如app名,app的描述,主体色,背景色等等,这里就不一一赘述了,主要都是看favicons 当中的配置。

这里,我们仅想要网站图标,那么就可以将其他的关闭掉,然后再去打包构建,就会发现图标仅剩下favicons的了。

兼容

因为favicons-webpack-plugin与html-webpack-plugin相关联的,所以一些特定版本提前一定要安装好,不要出现兼容问题。

  • favicons-webpack-plugin 2.x 与 html-webpack-plugin 3.x 兼容

  • favicons-webpack-plugin 3.x - 4.x 与 html-webpack-plugin 4.x 兼容

  • favicons-webpack-plugin 5.x与 html-webpack-plugin 5.x 兼容

结语

类似于favicons-webpack-plugin的插件还有很多但是基本配置和操作都大差不差。插件工具就是这样,好与坏就看你怎么用了,至少我们如果搭建项目时用了它,可以自动生成一系列的图标,省去一些苦恼,图一个方便省心罢了。

到此这篇关于webpack如何自动生成网站图标的文章就介绍到这了,更多相关webpack自动生成网站图标内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

--结束END--

本文标题: webpack如何自动生成网站图标详解

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

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

猜你喜欢
  • webpack如何自动生成网站图标详解
    目录介绍准备使用兼容结语介绍 我们在自己搭建项目的时候,有时候主管给你一张logo图片,让你自己想办法变成网站图标,有时候项目需求里不仅仅是多种尺寸的favicon.ico,还有安卓...
    99+
    2024-04-02
  • webpack怎么自动生成网站图标
    这篇文章主要介绍webpack怎么自动生成网站图标,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!介绍我们在自己搭建项目的时候,有时候主管给你一张logo图片,让你自己想办法变成网站图标,有时候项目需求里不仅仅是多种尺...
    99+
    2023-06-28
  • webpack如何自动生成html页面
    这篇文章主要为大家展示了“webpack如何自动生成html页面”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“webpack如何自动生成html页面”这篇文章吧...
    99+
    2024-04-02
  • SpringBoot如何自动生成API文档详解
    前言 在做项目的时候,如果项目是前后分离的,后端一定要和前端或者是移动端对接接口,那么问题来了,接口是不是要自己写给他们看,一般的会采用Excel或者Word来写,高级一点的就采用A...
    99+
    2024-04-02
  • 如何自动生成linux网卡配置
    这篇文章主要介绍“如何自动生成linux网卡配置”,在日常操作中,相信很多人在如何自动生成linux网卡配置问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”如何自动生成linux网卡配置”的疑惑有所帮助!接下来...
    99+
    2023-06-09
  • 详解nodejs的express如何自动生成项目框架
    本文主要介绍了nodejs的express如何自动生成项目框架,这里整理了详细的代码,有需要的小伙伴可以参考下。 nodejs版本为:4.X,express版本为4.X 1.全局安装2个模块 expres...
    99+
    2022-06-04
    自动生成 详解 框架
  • 如何添加网站图标Icon
    这篇文章将为大家详细讲解有关如何添加网站图标Icon,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。第一步,准备一个图标制作软件。 首先您必须了解所谓的图标(Icon)是一种特殊的图形文件格式,它是以.ic...
    99+
    2023-06-08
  • 如何设置网站ico图标
    这篇文章主要介绍“如何设置网站ico图标”,在日常操作中,相信很多人在如何设置网站ico图标问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”如何设置网站ico图标”的疑惑有所帮助!接下来,请跟着小编一起来学习吧...
    99+
    2023-06-08
  • pycharm如何自动生成导入
    小编给大家分享一下pycharm如何自动生成导入,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!自动生成导入您正在编写代码,想导入...
    99+
    2024-04-02
  • 如何利用Mybatis-Plus自动生成代码(超详细注解)
    如何利用Mybatis-Plus自动生成代码(超详细注解) 1、简介2、代码生成器3、详细使用教程3.1 两个mysql数据库:3.2 创建springboot项目3.3 添加依赖3.5 编辑...
    99+
    2023-08-31
    mybatis java mysql 数据库
  • WordPress网站如何生成静态HTML网页
    我们知道,Wordpress制作的网站是动态网站,所有链接都是动态链接,虽然我们可以设置伪静态,但仅仅是URL是静态的,实际并没有真实的HTML页面存在。 那么怎么让Wordpress网站生成HTML网页呢?其实通过一个插件就可以实现。这个...
    99+
    2023-09-03
    php 开发语言
  • SpringbootMybatisPlus自动生成工具类详解代码
    前言 代码生成器,也叫逆向工程,是根据数据库里的表结构,自动生成对应的实体类、映射文件和接口。 看到很多小伙伴在为数据库生成实体类发愁,现分享给大家,提高开发效率。 一、pom依赖 ...
    99+
    2024-04-02
  • Babel自动生成Attribute文档实现详解
    目录1. 前言2. 开发自动生成属性文档插件2.1 生成Babel插件模板:2.2 转换思路详解:2.3 单元测试用例:2.4 AST分析详解:2.5 插件开发过程:2.5.1 定义...
    99+
    2022-11-13
    Babel生成Attribute文档 Babel Attribute
  • Java实现动态生成GIF图像详解
    目录背景特点用途AnimatedGifEncoder简介GIF创作生成一、创建maven项目二、自定义生成三、自定义将多张图片合成话外题-怀念巨人总结背景 在互联网上有许多有趣的场景...
    99+
    2024-04-02
  • 动态网站地图生成:PHP递归函数的应用
    动态网站地图是一个非常有用的工具,可以帮助搜索引擎更好地索引网站的内容,提高网站的可访问性和可发现性。在生成动态网站地图时,我们通常...
    99+
    2024-04-26
    PHP
  • Node.js + imgcook如何自动生成依赖
    本篇内容介绍了“Node.js + imgcook如何自动生成依赖”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有...
    99+
    2024-04-02
  • mysql如何自动生成字符串
    mysql中实现自动生成随机字符串的方法sql代码如下:DROP FUNCTION IF EXISTS rand_string;DELIMITER $$CREATE FUNCTION rand_string(n INT)RETURNS VA...
    99+
    2024-04-02
  • 如何利用Python自动生成PPT
    今天小编给大家分享一下如何利用Python自动生成PPT的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。在日常工作中,PPT制...
    99+
    2023-07-02
  • IntelliJ IDEA中如何自动生成serialVersionUID
    这篇文章给大家分享的是有关IntelliJ IDEA中如何自动生成serialVersionUID的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。serialVersionUID介绍再编程过程中当涉及到对象的传输问...
    99+
    2023-05-30
    intellij idea serialversionuid
  • Mybatis如何自动生成sql语句
    目录Mybatis自动生成sql语句Mybatis的动态sql语句if标签的使用where标签的使用foreach标签的使用sql语句的简化编写Mybatis自动生成sql...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作