位置: IT常识 - 正文

使用vue-antd动态切换主题(vue 动态tab)

编辑:rootadmin
这篇文章主要介绍了使用vue-antd动态切换主题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教 目录

推荐整理分享使用vue-antd动态切换主题(vue 动态tab),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:ant design vue 动态菜单,antd-vue-pro,vue中如何实现动态组件,ant design vue 动态菜单,antd vue pro 动态路由,antd vue pro 动态路由,antd vue pro 动态路由,antd vue pro 动态路由,内容如对您有帮助,希望把文章链接给更多的朋友!

vue-antd动态切换主题安装依赖Vue3.0 + Antd,修改antd主题色,配置全局cssvue-antd动态切换主题安装依赖1 webpack-theme-color-replacer: yarn add webpack-theme-color-replacer@1.3.222 less: yarn add less@2.7.23 less-loader: yarn add less-loader@7.0.2

在vue.config.js中加入配置

const createThemeColorReplacerPlugin = require("./plugin.config");const vueConfig = {  css: {    loaderOptions: {      less: {        lessOptions: {          modifyVars: {             //注意:此处不能给默认值,否则会导致主题色动态配置失败            // less vars,customize ant design theme            //'primary-color': '#2f54eb',            //'link-color': '#2f54eb',            //'border-radius-base': '4px'          },          // DO NOT REMOVE THIS LINE          javascriptEnabled: true,        },      },    },  },  configureWebpack: {    plugins: [createThemeColorReplacerPlugin()],  },  assetsDir: "static",};module.exports = vueConfig;

添加主题色更改方法,新建util文件夹创建plugin.config.js

const ThemeColorReplacer = require('webpack-theme-color-replacer')const generate = require('@ant-design/colors/lib/generate').defaultconst getAntdSerials = (color) => {  // 淡化(即less的tint)  const lightens = new Array(9).fill().map((t, i) => {    return ThemeColorReplacer.varyColor.lighten(color, i / 10)  })  const colorPalettes = generate(color)  const rgb = ThemeColorReplacer.varyColor.toNum3(color.replace('#', '')).join(',')  return lightens.concat(colorPalettes).concat(rgb)}const themePluginOption = {  fileName: 'css/theme-colors-[contenthash:8].css',  matchColors: getAntdSerials('#1890ff'), // 主色系列  // 改变样式选择器,解决样式覆盖问题  changeSelector (selector) {    switch (selector) {      case '.ant-calendar-today .ant-calendar-date':        return ':not(.ant-calendar-selected-date):not(.ant-calendar-selected-day)' + selector      case '.ant-btn:focus,.ant-btn:hover':        return '.ant-btn:focus:not(.ant-btn-primary):not(.ant-btn-danger),.ant-btn:hover:not(.ant-btn-primary):not(.ant-btn-danger)'      case '.ant-btn.active,.ant-btn:active':        return '.ant-btn.active:not(.ant-btn-primary):not(.ant-btn-danger),.ant-btn:active:not(.ant-btn-primary):not(.ant-btn-danger)'      case '.ant-steps-item-process .ant-steps-item-icon > .ant-steps-icon':      case '.ant-steps-item-process .ant-steps-item-icon>.ant-steps-icon':        return ':not(.ant-steps-item-process)' + selector      case '.ant-menu-horizontal>.ant-menu-item-active,.ant-menu-horizontal>.ant-menu-item-open,.ant-menu-horizontal>.ant-menu-item-selected,.ant-menu-horizontal>.ant-menu-item:hover,.ant-menu-horizontal>.ant-menu-submenu-active,.ant-menu-horizontal>.ant-menu-submenu-open,.ant-menu-horizontal>.ant-menu-submenu-selected,.ant-menu-horizontal>.ant-menu-submenu:hover':      case '.ant-menu-horizontal > .ant-menu-item-active,.ant-menu-horizontal > .ant-menu-item-open,.ant-menu-horizontal > .ant-menu-item-selected,.ant-menu-horizontal > .ant-menu-item:hover,.ant-menu-horizontal > .ant-menu-submenu-active,.ant-menu-horizontal > .ant-menu-submenu-open,.ant-menu-horizontal > .ant-menu-submenu-selected,.ant-menu-horizontal > .ant-menu-submenu:hover':        return '.ant-menu-horizontal > .ant-menu-item-active,.ant-menu-horizontal > .ant-menu-item-open,.ant-menu-horizontal > .ant-menu-item-selected,.ant-menu-horizontal:not(.ant-menu-dark) > .ant-menu-item:hover,.ant-menu-horizontal > .ant-menu-submenu-active,.ant-menu-horizontal > .ant-menu-submenu-open,.ant-menu-horizontal:not(.ant-menu-dark) > .ant-menu-submenu-selected,.ant-menu-horizontal:not(.ant-menu-dark) > .ant-menu-submenu:hover'      case '.ant-menu-horizontal > .ant-menu-item-selected > a':      case '.ant-menu-horizontal>.ant-menu-item-selected>a':        return '.ant-menu-horizontal:not(ant-menu-light):not(.ant-menu-dark) > .ant-menu-item-selected > a'      case '.ant-menu-horizontal > .ant-menu-item > a:hover':      case '.ant-menu-horizontal>.ant-menu-item>a:hover':        return '.ant-menu-horizontal:not(ant-menu-light):not(.ant-menu-dark) > .ant-menu-item > a:hover'      default :        return selector    }  }}const createThemeColorReplacerPlugin = () => new ThemeColorReplacer(themePluginOption)module.exports = createThemeColorReplacerPlugin

添加util.js文件

import client from "webpack-theme-color-replacer/client";import generate from "@ant-design/colors/lib/generate";function getAntdSerials(color) {  // 淡化(即less的tint)  const lightens = new Array(9).fill().map((t, i) => {    return client.varyColor.lighten(color, i / 10);  });  // colorPalette变换得到颜色值  const colorPalettes = generate(color);  const rgb = client.varyColor.toNum3(color.replace("#", "")).join(",");  return lightens.concat(colorPalettes).concat(rgb);}function changeColor(newColor) {  var options = {    newColors: getAntdSerials(newColor), // new colors array, one-to-one corresponde with `matchColors`    changeUrl(cssUrl) {      return `/${cssUrl}`; // while router is not `hash` mode, it needs absolute path    },  };  return client.changer.changeColor(options, Promise);}export default {  updateTheme(newPrimaryColor) {    const hideMessage = () => console.log("正在切换主题!", 0);    changeColor(newPrimaryColor).finally((t) => {      setTimeout(() => {        hideMessage();      });    });  },};

然后在main.js中引入为Vue原型prototype中的方法

import utils from "./utils"Vue.prototype.$u = utils//注意antd样式的引入必须由css改为less引入- import 'ant-design-vue/dist/antd.css';+ import 'ant-design-vue/dist/antd.less';

然后项目启动起来后调用Vm.$u.updateTheme方法即可动态改变主题色。

注意该方法传值必须传十六进制的颜色,如果传颜色对应的英文字符可能会出错.

使用vue-antd动态切换主题(vue 动态tab)

如果自定义组件或者元素也需要统一管理主题色,则在assets目录新建main.less

@import "~ant-design-vue/dist/antd.less";#home {  color: @primary-color;}

在main.less中引入antd的样式,然后antd的主题色是@primary-color, 直接使用即可

然后在main.js中直接引入main.less

- import 'ant-design-vue/dist/antd.less';+ import "./assets/css/main.less"Vue3.0 + Antd,修改antd主题色,配置全局css

1.在vue.config.js里修改配置

module.exports = {  css: {    loaderOptions: {      less: {        lessOptions: {          modifyVars: {            'primary-color': '#3d62ff',// 修改全局主题色          },          javascriptEnabled: true,        },      },    },    extract: true, // 解决开发模式,打包时未提取CSS的问题  }}

2.把main.ts中的import ‘ant-design-vue/dist/antd.css’;

修改为 import ‘ant-design-vue/dist/antd.less’;

修改css为less的时候,会报错 .bezierEasingMixin()

解决方法是:先卸载less-loader

npm uninstall -D less-loader

再安装less-loader@6.0.0

npm install -D less-loader@6.0.0

然后重新运行项目即可

以上为个人经验,希望能给大家一个参考,也希望大家多多支持本站。

本文链接地址:https://www.jiuchutong.com/zhishi/304790.html 转载请保留说明!

上一篇:phpcms上传不了图片怎么办(php实现上传图片功能)

下一篇:一起爬山吗?《隐秘的角落》为什么译成Cat's Cradle?(你要和我一起爬山吗)

  • 荣耀50se语音助手可以语音唤醒吗(荣耀50se语音助手)

    荣耀50se语音助手可以语音唤醒吗(荣耀50se语音助手)

  • opporeno4耳机怎么使用(opporeno4耳机怎么戴)

    opporeno4耳机怎么使用(opporeno4耳机怎么戴)

  • 腾讯视频用手机号码怎么登录(腾讯视频用手机号码充了会员)

    腾讯视频用手机号码怎么登录(腾讯视频用手机号码充了会员)

  • 苹果11抖音相册权限如何打开(苹果抖音相册权限被禁用怎么设置回来)

    苹果11抖音相册权限如何打开(苹果抖音相册权限被禁用怎么设置回来)

  • vivox27联系人设置在哪(vivox9联系人设置)

    vivox27联系人设置在哪(vivox9联系人设置)

  • 电脑双引号只能打一边(电脑上的双引号只能打一半是怎么回事)

    电脑双引号只能打一边(电脑上的双引号只能打一半是怎么回事)

  • 怎样固定手机屏幕不要让旋转(怎样固定手机屏,不让转动)

    怎样固定手机屏幕不要让旋转(怎样固定手机屏,不让转动)

  • 12306短信验证码已失效(12306短信验证码总是不对)

    12306短信验证码已失效(12306短信验证码总是不对)

  • cad 是什么什么意思(cad是什么术语)

    cad 是什么什么意思(cad是什么术语)

  • 苹果8手电筒不亮了怎么回事(苹果8手电筒不灵敏)

    苹果8手电筒不亮了怎么回事(苹果8手电筒不灵敏)

  • 主板电源8孔插4个行吗(主板电源8孔插4根线)

    主板电源8孔插4个行吗(主板电源8孔插4根线)

  • 荣耀play3支持快充吗(荣耀play3可以用)

    荣耀play3支持快充吗(荣耀play3可以用)

  • 数字移动电话机是全网通吗(数字移动电话机是什么意思)

    数字移动电话机是全网通吗(数字移动电话机是什么意思)

  • 手机卡换卡不换号码怎么办理(手机卡换卡不换号码可以异地办理吗)

    手机卡换卡不换号码怎么办理(手机卡换卡不换号码可以异地办理吗)

  • 荣耀9x接电话是滑动还是按(华为荣耀9x怎么打电话,对方显示来电)

    荣耀9x接电话是滑动还是按(华为荣耀9x怎么打电话,对方显示来电)

  • 手机上可以看春晚直播吗(手机上可以看春节电影吗)

    手机上可以看春晚直播吗(手机上可以看春节电影吗)

  • 手机保护膜分几种(手机膜的保护膜)

    手机保护膜分几种(手机膜的保护膜)

  • qq好友被对方删除 自己怎么知道(qq好友被对方删除 自己怎么恢复)

    qq好友被对方删除 自己怎么知道(qq好友被对方删除 自己怎么恢复)

  • 手机朋友圈如何定位(手机朋友圈如何点赞)

    手机朋友圈如何定位(手机朋友圈如何点赞)

  • 华为怎么打开受限应用(华为手机受信任设备怎么设置)

    华为怎么打开受限应用(华为手机受信任设备怎么设置)

  • 普通人怎么开淘宝直播(普通人怎么开淘宝)

    普通人怎么开淘宝直播(普通人怎么开淘宝)

  • 华为提醒功能(华为手机提醒功能在哪)

    华为提醒功能(华为手机提醒功能在哪)

  • 荣耀手环3接电话按哪里(荣耀手环接电话怎么接)

    荣耀手环3接电话按哪里(荣耀手环接电话怎么接)

  • 苹果6手机如何滚动截屏(苹果6手机如何升级系统版本)

    苹果6手机如何滚动截屏(苹果6手机如何升级系统版本)

  • 服务器是什么意思(服务器是什么意思呢)

    服务器是什么意思(服务器是什么意思呢)

  • 如何正确安装tenda无线网卡驱动(如何正确安装锯条)

    如何正确安装tenda无线网卡驱动(如何正确安装锯条)

  • 【朝夕教育】2023年03月 其他-运动控制和机器视觉面试题(34道)(朝夕教育怎么样)

    【朝夕教育】2023年03月 其他-运动控制和机器视觉面试题(34道)(朝夕教育怎么样)

  • 单独计税的年终奖怎么算
  • 研发设备定义
  • 没有发票先入账怎么办
  • 购买礼品送客户个人所得税
  • 金蝶软件数量金额式怎样输入数据
  • 企业所得税季度预缴怎么计算
  • 转账凭证有哪些内容
  • 劳务费做账是否需要发票
  • 公司车辆出售给个人怎么做账
  • 收到分包工程发票怎么做分录
  • 怎么分清楚待认识的人
  • 造价咨询公司在哪里备案
  • 增值税为什么申报不了
  • 资金与费用
  • 抵债资产处置的意义
  • 企业所得税申报表在哪里打印
  • 个税滞纳金如何调增所得税费用
  • 跨年度多计提的印花税怎么冲回
  • 环保税计入项目成本吗
  • 企业向个人借款支付的利息
  • 城市垃圾处理项目
  • 新政府会计制度科目表
  • mac电脑command+s
  • php代码生成器
  • Win10 21H2 Build 21354 ISO 太阳谷官方镜像预览版下载
  • exe都打不开
  • 自制原始凭证包括哪些凭证
  • 公积金可以支付二手房首付款吗
  • 土地投资入股是否缴纳土地增值税12366
  • 公积金的扣款怎么取消
  • 购销合同印花税税率表
  • 会计凭证出现的问题
  • ipad最长使用时间
  • 可供出售金融资产现在叫什么
  • 火灾烧毁物品如何取证
  • 固定资产与固定资产净值
  • php数独游戏代码
  • 出口退税抵减应计入哪里
  • 固定资产处置缴纳增值税政策依据
  • Testing Applications with WebTest¶
  • 不含税开发票吗
  • 报废车怎么处理最划算
  • 现金余额不对怎么处理
  • 固定资产停产需要计提折旧吗
  • 事业单位调整以前年度的费用
  • 厂房测量费怎么做账
  • 土地使用税怎么征收标准
  • 内部招待所管理规定
  • 营业收入和利润的区别
  • 无发票的费用怎么处理
  • 资产负债率怎么调整到50%以下
  • mysql中的where子句
  • Windows Server 2008禁止模块安装提升网络性能
  • macbook air语音功能
  • window msconfig
  • 电脑界面显示windows
  • ps1是什么文件
  • win10系统开机蓝屏,重启就好
  • linux命令删除指定目录
  • win8.1系统怎么激活
  • opengl教程48讲
  • data.table
  • jquery技巧
  • shell脚本通过expect实现自动单边无密登录功能
  • [置顶]马粥街残酷史
  • 深入解读我本是高山
  • unity3d动画系统
  • angularjs4
  • python语言文件
  • python xlim
  • html应用css
  • js实现类
  • 教育培训行业的发展前景
  • 税务上的工会经费是必须交的吗?
  • 怎么知道自己的城乡属性
  • 地税局上班时间是几点
  • 税务延期申报最长多久
  • 党员走访群众问题汇总
  • 季度申报成功与否怎么查询
  • 广州哪里有餐饮费发票
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设