vue+webpack更换主题的方法是什么


这篇文章主要介绍“vue+webpack更换主题的方法是什么”,在日常操作中,相信很多人在vue+webpack更换主题的方法是什么问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”vue+webpack更换主题的方法是什么”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!需求:由于业务需要,我们需要做多套皮肤调研了下当前行业的实现方案,五花八门良莠不齐,在此总结下各种方案有优劣及复杂度,供大家快速定位到符合自己业务的方案,以vue 单页应用为业务场景方式一:class切换方式
实现:
在每个需要更换的页面定义多个class,根据运行时标识动态的切换class名称实现加载不同的样式,这种方式较为简单优点:不需要修改构建工具相关业务开发过程可以实现,没有限制支持动态切换缺点:逻辑分散耦合在各个页面,一旦需要修改,涉及修改的页面较多代码需要预先内置,不支持动态颜色修改方式二:Eleme 香港云主机ntUI的实现
实现:
对主题涉及的颜色使用特殊值
如:UI需要白色#ffffff色值的时候使用一个相近的特征值颜色 如:#fffffe
在代码运行时动态获取到需要修改的颜色值
如: 需要修改#fffffe =》 #ff00ff
查找页面所有style标签将其色值#fffffe正则匹配出来,替换为 #ff00ff
在页面新加标签style覆盖默认值
优点:支持动态切换支持动态色值不需要内置多份样式缺点:业务开发过程中需要对ui给出的色值重定义,业务开发需要有一定的规则无法修改背景图片无法对懒加载的样式做处理,需要初始化加载全局所有样式无法动态修改背景图片方式三:编译时多主题全量构建
实现:定义多套样式构建时将多套样式主题作为独立构建入口,构建出主题静态文件css文件业务运行时动态加载不同的主题文件优点:支持动态切换主题业务开发样式分离编译时构建性能较好 缺点:构建工具配置较为复杂,适用单入口应用,对多入口的支持不友好需要定义全局 less 文件,在入口引入业务需要额外操作配合 rel=”alternate stylesheet” 可预加载备选主题样式方式四: 编译时选择性构建
实现:内置多套皮肤构建时传入参数,根据不同的构建参数加载不同的主题样式文件优点:构建工具配置较为简单,不需要业务做额外操作多入口应用支持度好缺点:不支持动态切换多个项目需要构建多次,需要构建系统支持方式五:less动态变量
实现:
修改构建脚本,将所有页面less文件抽到同一个文件中不编译less,页面直接加载less文件使用less.js 在客户端编译less 文件优点:支持动态切换支持动态色值缺点:客户端编译较耗性能/耗时需要额外加载less.js mini文件size: 131KB方式六:css变量
实现:
在需要变化的css属性定义变量
在运行时动态的修改变量
优点:浏览器原生支持,无需额外操作支持动态色值缺点:低版本兼容性不好ios Safari 9.3、 android 5、 chrome forAndroid 76UC、QQ、Baidu 等国内浏览器支持度较差方式七: import动态加载
实现:
业务中预定义多套主题运行时根据变量动态加载对应主题优点:支持动态切换实现简单缺点:不支持动态色值需要全局定义多套样式表全局定义 class 无法定义变量在 vue style 中引用变量注:动态切换:是否支持在运行时切换皮肤动态设置:是否支持在运行时动态设置皮肤颜色支持变量:是否可以再全局定义变量 less 文件,然后在不同的页面引用 less,依赖其中的变量,还是需要在全局 less 文件里面定义全局 class实现复杂度: 需要修改的代码量包括构建工具和业务代码兼容性: 主流浏览器支持程度性能:包括代码的首屏加载的 size、切换的速度、切换的时候会不会有闪动到此,关于“vue+webpack更换主题的方法是什么”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注开发云网站,小编会继续努力为大家带来更多实用的文章!

相关推荐: Vue中怎么使用异步组件

这篇文章主要介绍“Vue中怎么使用异步组件”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷 香港云主机,实用性强,希望这篇“Vue中怎么使用异步组件”文章能帮助大家解决问题。1、前置要求建议使用webpack;Browserify在默认情况下…

免责声明:本站发布的图片视频文字,以转载和分享为主,文章观点不代表本站立场,本站不承担相关法律责任;如果涉及侵权请联系邮箱:360163164@qq.com举报,并提供相关证据,经查实将立刻删除涉嫌侵权内容。

Like (0)
Donate 微信扫一扫 微信扫一扫
Previous 07/18 23:07
Next 07/18 23:07

相关推荐