vue官网编辑器主题(vue实现主题切换的多种思路分享)
vue官网编辑器主题
vue实现主题切换的多种思路分享目录
- 动态改变主题
- 第一种办法:动态组件
- 第二种办法,路由隔离
- 总结
- 额外补充基于css的两种方法
- 方法一 多套css
- 方法二 scss动态切换变量
首先需要解决的是如何知道你需要显示哪个主题,并且可以动态切换。我选择的方法是queryString。
我们打开url的时候,可以在后面缀上?theme=xx,读取这个xx储存起来即可。
第一种办法:动态组件当主题的路由并没有发生变化,仅是组件内部的样式,功能发生了变化,我们可以将一个组件复制一遍,修改完后,通过懒加载和动态组件实现。
// 页面组件 <template> <li> <component :is="themeName" /> </li> </template> <script> export default{ name: 'Home', components:{ theme1:()=>import('@/theme/theme1/a'), theme2:()=>import('@/theme/theme2/a'), }, computed:{ themeName(){ retun `theme${this.$store.state.themeId}` } } } </script>
在组件中,我将script部分抽离出来,因为大部分组件其实在逻辑上是相同。哪怕有一些不同,我们也可以直接在主题2的组件中更改,减少对主题1的影响。
//action.js export default{ name:'Theme1', .... } <template> <li class="theme1"></li> </template> <script> import action from '../componentAction/action' action.name='Theme1' export default action </script> <style scoped> </style>
这样实现的有点是可以通过子组件的style scoped实现样式隔离,同时功能数据上都会隔离,例如两个子组件中的swiper不会相互影响。 同时,懒加载也减小了首页的加载时体积。 后面再增加新增的主题也只是照猫画虎而已。
第二种办法,路由隔离路由隔离其实就是简单的theme1写一个路由的数组,theme2写一套路由。
// router.js { path:'/theme3', name:'theme3Index', component: () => import('../views/theme3/Index.vue'), children:[ { path: '/theme3/entry', name: 'theme3Entry', component: () => import('../views/theme3/entry.vue'), } ] }
这种办法其实是下下之策,我使用这个主要是因为路由变化了,比如之前是直接进入a.vue,但是现在前面多加了一层entry页面,所以只能改变路由。 这种办法也实现了比较好的隔离。
总结以上两种思路是我针对于我们当前业务的思考,仅供参考。
其实这两种方法都有一个共同的问题,就是代码冗余。每个组件都避不可免的带有一部分之前主题的代码,虽然,大部分逻辑代码可以抽离出来,但是css和template却无法抽离。
如果每次一个主题增加一个dom,一个功能块,如果每次都用v-if,那么其实代码以后会更加难以维护。因此,我选择了按照主题去划分代码。
额外补充基于css的两种方法方法一 多套css
<!-- 中心 --> <template> 动态获取父级class名称,进行一个父级class的多次定义 <li :class="className"> <li class="switch" v-on:click="chang()"> {{ className == "box" ? "开灯" : "关灯" }} </li> </li> </template> <script> export default { name: "Centre", data() { return { className: "box" }; }, methods: { // 改变class chang() { this.className === "box" ? (this.className = "boxs") : (this.className = "box"); } }, }; </script> <style lang="scss"> 当class为box 使用witch的css @import "./style/witch.scss"; 当class为boxs 使用black的css @import "./style/black.scss"; .switch { position: fixed; top: 4px; right: 10px; z-index: 50; width: 60px; height: 60px; background: #fff; line-height: 60px; border-radius: 20%; } </style>
每个css文件样式大致相同,只是最外层的父级不一样,分别为.box 和.boxs
方法二 scss动态切换变量
我自己是分为了2个主要文件来做的
- _variable.scss 变量管理文件
- var()为css3中提出的声明样式变量的方法
- var(属性名,属性值)注意属性值不能是字符串
// 主题切换 $bgColor:var(--backgroundColor,rgb(255,255,255)); $fontColor:var(--fonntColor,rgb(0,0,0)); $bgmColor:var(--backgroundMColor,rgb(238,238,238)); $tableColor:var(--tableColor,rgb(218,218,218)); $borderColor:var(--borderColor,rgb(238,238,238)); $tablesColor:var(--tablesColor,rgb(255,255,255)); $inputColor:var(--inputColor,rgb(255,255,255))
创建的_variable.scss 文件我在vue.config.js进行了一个全局的配置,没有在组件中引入
css: { loaderOptions: { // 此文件为主题切换文件 sass: { prependData: `@import "./src/styles/_variable.scss";`, }, }, },
publicStyle.js
这个方法可以去修改var定义的变量
document.getElementsByTagName("body")[0].style.setProperty("属性名", "替换的属性值f");
// 主题切换 const cut = (cutcheack) => { document.getElementsByTagName("body")[0].style.setProperty("--backgroundColor", cutcheack ? "#121212" : "#fff"); document.getElementsByTagName("body")[0].style.setProperty("--fonntColor", cutcheack ? "#cecece" : "#333"); document.getElementsByTagName("body")[0].style.setProperty("--backgroundMColor", cutcheack ? "#333" : "#eee"); document.getElementsByTagName("body")[0].style.setProperty("--tableColor", cutcheack ? "#000" : "#d8d8d8"); document.getElementsByTagName("body")[0].style.setProperty("--tablesColor", cutcheack ? "#222" : "#fff"); document.getElementsByTagName("body")[0].style.setProperty("--inputColor", cutcheack ? "#666" : "#fff"); document.getElementsByTagName("body")[0].style.setProperty("--borderColor", cutcheack ? "#666" : "#fff"); }; export default cut;
组件中使用
<!-- 首页 --> <template> <li class='home'> <el-switch v-model="cutcheack" active-color="#333" inactive-color="#13ce66" active-text="主题" @change="switchs"></el-switch> </li> </template> <script> import cut from "../../utils/publicStyle.js"; export default { name: "Home", data() { return { cutcheack: false, //主题切换 }; }, methods: { // 左侧导航隐藏或显示 // 切换主题 switchs() { cut(this.cutcheack); }, }, }; </script> <style lang='scss' scope> .home { height: 100%; width: 100%; background:$bgColor; .el-container { height: 100%; color:$fontColor; } } </style>
以上就是vue实现主题切换的多种思路分享的详细内容,更多关于vue 主题切换的资料请关注开心学习网其它相关文章!
- vue怎么引入axios(如何用vue封装axios请求)
- vue左右联动列表(vue+iview的菜单与页签的联动方式)
- vue 为什么要使用key(详解vue中v-for的key唯一性)
- vue图片切换软件(Vue实现简单图片切换效果)
- vue编程加入购物车(vuex实现简单的购物车功能)
- vue 富文本图片上传(vue.js云存储实现图片上传功能)
- vue手动清除keepalive缓存(vue中keep-alive组件的用法示例)
- vue点击导航进行内容切换(vue实现顶部左右滑动导航)
- vue过滤器filters怎么用(如何使用vue过滤器filter)
- vue动态路由实现权限控制(vue2/vue3路由权限管理的方法实例)
- vue 设置头部可以左右滑动(vue实现左右滑动效果实例代码)
- vue文件上传进度处理(Vue 大文件上传和断点续传的实现)
- vue动态生成的下拉框如何获取值(Vue 级联下拉框的设计与实现)
- vue3.0全家桶教程elementui学习(vite+vue3.0+ts+element-plus快速搭建项目的实现)
- vue3组件通讯消息(Vue3实现Message消息组件示例)
- vueelementui三级菜单(vue+element ui实现锚点定位)
- 男人犯的错,为什么要女人来承担(为什么要女人来承担)
- 心理学 四个金蟾,哪个最招财 测你今生的运势有多棒(心理学四个金蟾)
- 吉善缘《聚宝金蟾》金蟾招财摆件 三足全铜蟾蜍客厅店铺开业礼品(吉善缘聚宝金蟾金蟾招财摆件)
- 招财化煞神兽,金蟾变了(招财化煞神兽金蟾变了)
- 26岁杨紫的白素贞遇上24岁鞠婧祎,哪个最美(26岁杨紫的白素贞遇上24岁鞠婧祎)
- 鞠婧祎和杨紫两种风格的女生,你心里谁比较美(鞠婧祎和杨紫两种风格的女生)
热门推荐
- django后台运行命令(Django框架实现的普通登录案例使用POST方法)
- javascript学习参数(详解JavaScript堆栈与拷贝)
- sqlserver2012登录出现报错18456(SQL Server 2012 sa用户登录错误18456的解决方法)
- js回调函数
- MySQL主从状态检查的实现(MySQL主从状态检查的实现)
- typescript获取属性名(TypeScript 中如何限制对象键名的取值范围)
- sqlserver附加数据库时出错(SQL Server数据库附加失败的解决办法)
- php数组写法(php文件操作之文件写入字符串、数组的方法分析)
- 目前主流的web服务器有哪些(什么是WEB服务器? 常用的WEB服务器有哪些?)
- jenkins回滚docker容器(关于docker部署的jenkins跑git上的程序的问题)
排行榜
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9