时间:2021-05-26
主要原理是利用webpack插件webpack-theme-color-replacer提取相关颜色css然后根据配置动态生成替换的css
具体实现步骤如下:
1.添加webpack插件,新建文件webpack/themePlugin.js
const ThemeColorReplacer = require('webpack-theme-color-replacer')const forElementUI = require('webpack-theme-color-replacer/forElementUI')const config = require('../src/config/appConfig')module.exports = new ThemeColorReplacer({ fileName: 'css/theme-colors.[contenthash:8].css', matchColors: [ ...forElementUI.getElementUISeries(config.themeColor), //element-ui主色系列 // '#0cdd3a', //自定义颜色 ], changeSelector: forElementUI.changeSelector, isJsUgly: process.env.NODE_ENV !== 'development', // injectCss: false, // resolveCss(resultCss) { // optional. Resolve result css code as you wish. // return resultCss + youCssCode // }})matchColors数组中可配置多个自定义要替换的主题色
2.在vue.config.js中添加这个插件
const themePlugin=require('./webpack/themePlugin');module.exports = { configureWebpack: { plugins: [ themePlugin ] } }3.新建文件themeColorClient.js
import client from 'webpack-theme-color-replacer/client'import forElementUI from 'webpack-theme-color-replacer/forElementUI'import appConfig from '@/config/appConfig'export let curColor = appConfig.themeColor// 动态切换主题色export function changeThemeColor(newColor) { var options = { newColors: [...forElementUI.getElementUISeries(newColor)], } return client.changer.changeColor(options, Promise) .then(() => { curColor = newColor localStorage.setItem('theme_color', curColor) });}export function initThemeColor() { const savedColor = localStorage.getItem('theme_color') if (savedColor) { curColor = savedColor changeThemeColor(savedColor) }}4.在需要的时候调用 initThemeColor初始化颜色 changeThemeColor改变主题颜色
import { initThemeColor,changeThemeColor } from './utils/themeColorClient'initThemeColor()changeThemeColor('#F56C6C')//传入颜色格式应该为十六进制颜色值,'red'类似颜色暂不支持具体细节请参考https://github.com/hzsrc/vue-element-ui-scaffold-webpack4
到此这篇关于vue在线动态切换主题色方案的文章就介绍到这了,更多相关vue 动态切换主题内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
最近公司做的项目得到一个网站换肤的需求,也就是切换主题。那么如何切换主题色呢?切换主题色其实就是切换CSS,然而在项目中不仅只有CSS需要换肤,图标和图片也需要
根据预设的配色方案,在前端实现动态切换系统主题颜色。大概的思路就是给html根标签设置一个data-theme属性,然后通过js切换data-theme的属性值
在vue中,实现Tab切换主要有三种方式:使用动态组件,使用vue-router路由,使用第三方插件。因为这次完成的功能只是简单切换组件,再则觉得使用路由切换需
本文实例讲述了javascript实现Table间隔色以及选择高亮(和动态切换数据)的方法。分享给大家供大家参考。具体实现方法如下:
环境vue项目,页面有搜索、筛选项等。需求页面跳转,切换或者刷新,希望可以记住用户在页面的筛选状态方案v1vue有提供一种缓存组件的解决方案—keep-aliv