vue实战-换皮肤2(使用less实现)

本文介绍了在Vue项目中使用less语法实现动态换肤功能,通过动态加载样式文件和 vuex 存储当前皮肤信息,解决了仅能用css语法实现换肤的局限。在main.js中定义_getLess方法,结合vuex存储和更新皮肤信息,在页面created钩子中调用此方法,实现按需加载less样式。最后改进了换肤组件,但换肤后需刷新页面,期待优化方案。
摘要由CSDN通过智能技术生成

在上一节中我们通过动态切换html中css的引用路径实现了vue中的换皮肤功能。但是这种方法有一个缺陷,那就是只能用css的语法来实现。这个缺陷在某些变态的需求下会增加我们很多工作量,因此本节中将介绍vue中另一种换皮肤的实现思路,用less语法实现换肤。

上节中讲过,想要达到换皮肤的目的无非就是替换掉样式文件,而一般项目中使用less都会在style标签中import样式文件。但是现在我们想要达到动态加载样式文件的效果,因此就不能使用import了,而需要使用另一种引入样式文件的方法require。也就是说在每一个想要根据所选皮肤更改样式的页面都使用require来动态加载样式文件。

  • 在项目的main.js中的methods下新增_getLess方法用来根据当前所选皮肤获取样式文件,但是需要使用到mixin:
Vue.mixin({
    computed: {
		...mapGetters([
			'templates'
		]),
    },
    created() {
        var theme = localStorage.theme;
		if(theme) {
            this.templatesMu(theme);
		}
	},
    methods: {
        ...mapMutations([
			'templatesMu'
        ]),
        _getLess(filepath, filename) {
            console.log(this.templates)
			return require("./../static/template/" + this.templates + "/" + filepath + "/" 
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值