位置: 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?(你要和我一起爬山吗)

  • 小米手环6nfc怎么绑定公交卡(小米手环6nfc怎么看微信消息)

    小米手环6nfc怎么绑定公交卡(小米手环6nfc怎么看微信消息)

  • 抖音群怎么建(抖音群怎么建500人)

    抖音群怎么建(抖音群怎么建500人)

  • k歌签约有什么坏处(k歌签约有什么好处)

    k歌签约有什么坏处(k歌签约有什么好处)

  • 文字编码属于表示媒体吗(文字编码属于表示媒体)

    文字编码属于表示媒体吗(文字编码属于表示媒体)

  • 华为手机拍照颜色苍白(华为手机拍照颜色失真怎么调)

    华为手机拍照颜色苍白(华为手机拍照颜色失真怎么调)

  • 芯片卡泡水了还能用吗(芯片卡泡水了还可以用吗)

    芯片卡泡水了还能用吗(芯片卡泡水了还可以用吗)

  • 微信怎么设置不接受视频语音聊天(微信怎么设置不让别人通过手机号加我)

    微信怎么设置不接受视频语音聊天(微信怎么设置不让别人通过手机号加我)

  • 家里手机能连上但没网(家庭网络手机能连电脑连不上)

    家里手机能连上但没网(家庭网络手机能连电脑连不上)

  • 抖音上的呼啦是什么软件(抖音上的呼啦是什么意思)

    抖音上的呼啦是什么软件(抖音上的呼啦是什么意思)

  • 为什么个人热点连上后上不了网(为什么个人热点开不了)

    为什么个人热点连上后上不了网(为什么个人热点开不了)

  • 10gbps是多少兆(10mbps等于多少兆)

    10gbps是多少兆(10mbps等于多少兆)

  • 抖音mcn是什么意思(抖音mcn是什么意思无忧传媒)

    抖音mcn是什么意思(抖音mcn是什么意思无忧传媒)

  • 在微信里面买的电影票可以退吗(在微信里面买的电影票怎么退)

    在微信里面买的电影票可以退吗(在微信里面买的电影票怎么退)

  • 苹果手机放歌没声音怎么回事(苹果手机放歌没声音喇叭那里有个剪刀是什么意思)

    苹果手机放歌没声音怎么回事(苹果手机放歌没声音喇叭那里有个剪刀是什么意思)

  • iqoo低配有液冷散热吗(iqoo8液冷)

    iqoo低配有液冷散热吗(iqoo8液冷)

  • ios13降级通道关了咋办(iphone关闭降级通道)

    ios13降级通道关了咋办(iphone关闭降级通道)

  • 淘宝双11什么时候开始(淘宝双11什么时候结束)

    淘宝双11什么时候开始(淘宝双11什么时候结束)

  • 170怎么充话费(170的手机号怎么充话费)

    170怎么充话费(170的手机号怎么充话费)

  • 微博经常访问一直在吗(微博经常访问一个人有记录吗)

    微博经常访问一直在吗(微博经常访问一个人有记录吗)

  • 小米6x未知来源怎么设置(小米手机打开未知来源)

    小米6x未知来源怎么设置(小米手机打开未知来源)

  • 新版微信的支付中心在哪(新版微信的支付管理在哪里设置)

    新版微信的支付中心在哪(新版微信的支付管理在哪里设置)

  • 抖音说话配音在哪(抖音说话配音在哪里设置)

    抖音说话配音在哪(抖音说话配音在哪里设置)

  • 灵敏度上下抖动怎么调(灵敏度上下抖动跟左右晃怎么调)

    灵敏度上下抖动怎么调(灵敏度上下抖动跟左右晃怎么调)

  • 拼多多能上传视频吗(拼多多能上传视频赚钱吗)

    拼多多能上传视频吗(拼多多能上传视频赚钱吗)

  • 给员工发礼品发什么礼品最实惠
  • 税盘抵扣的会计分录
  • 工资薪金需要缴纳什么税种
  • 一次性就业补助金的领取条件
  • 混凝土开票的型号规格
  • 现金支出的一般程序
  • 多交附加税怎么做会计分录
  • 百望税控盘电子发票
  • 记账凭证一定要签字吗
  • 买入返售金融资产什么意思
  • 施工企业营改增税费有哪些
  • 金税盘怎么开红字发票流程
  • 增值税从哪一年开始征收的
  • 公益组织接受捐赠怎么开票
  • 建筑企业预收的工程款会计分录
  • 工程中材料超耗怎么处理
  • 亏损的递延所得税怎么理解
  • 用友u8计提企业所得税
  • 超市收取的返利的税收处理
  • 公共基础设施折旧年限表 20
  • 如何代开外籍人员个人所得税完税凭证?
  • 个人财产税是什么意思
  • 含税价什么意思?
  • 建筑企业自持商是指
  • 消防设施费用怎么入账
  • 个体公司转账给私人
  • macbookair邮件
  • 一般纳税人出售旧设备的税率
  • 佛洛勒斯岛在哪里
  • 增值税专票如何查询对方是否抵扣
  • 生产性生物资产折旧计入什么科目
  • 水资源税收费标准
  • 应付职工薪酬年末结转到哪个科目
  • php执行linux命令无效
  • 记录一次游戏
  • 技术knowhow
  • speedtest教程
  • lua命令库
  • 无形资产入股后如何处理
  • 外购无形资产账务处理
  • 股票收入需要交税
  • 购买员工宿舍用品报销
  • 数据库 元数据
  • 新成立的公司做广告如何写公司简介部分
  • 进项与销项区别
  • u8已经记账的凭证怎么修改
  • sqlserver常用命令
  • 汇兑损益在哪个表
  • 商场返现活动怎么入账
  • 财产转让收入属于什么收入
  • 银行抵债资产如何更快处置
  • 对于相关人员培训存在的问题
  • 母子公司间固定资产交换
  • 实缴增值税比计提增值税少怎么做账务处理
  • 股权转让的印花税税率是多少
  • 抵债资产处置账务实例
  • 资本公积转为实收资本会计科目
  • 项目过路费应该挂什么科目
  • 冲以前年度成本怎么做凭证
  • 营改增后建筑行业进项税能抵扣吗
  • 房地产开发企业增值税税率
  • 什么叫建账
  • mysql.sock在哪里
  • mysql常见报错
  • securedownload是什么意思
  • shell 日期运算
  • solaris删除文件夹命令
  • win10预览在哪里
  • linux命令大全详解
  • 微信付费使用是真的吗
  • 如何升级win
  • Linux>=2.6.39 Mempodipper本地提权分析和EXP利用(CVE-2012-0056)
  • windows mobile应用商店
  • win7电脑无法正常启动系统
  • 史上最全的领域学说
  • 用js自定义函数生成表格
  • 纸质发票怎么查电子发票
  • 河南省注册税务师协会电话
  • 北京市税务局的待遇怎么样
  • 安徽省国家税务局网
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设