使用Vue cli开发前端时, 引入并修改Vant组件默认样式

本文介绍如何使用Less自定义Vant UI库的主题风格,包括安装Less及加载器、配置样式变量以及通过覆盖变量来修改组件样式。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >


本文初衷:
在引入外部组件的时候,想要修改默认样式,可以通过class修改,但一般会有权重不够等各种原因,官网其实列出了一套主题定制的方案,通过覆盖配置文件来修改样式,官网地址:主题定制

提示:以下是本篇文章正文内容,下面案例可供参考

一、Less


因为Vant 使用了 Less 对样式进行预处理,并内置了一些样式变量,可以通过替换样式变量即可定制你自己需要的主题。

给你的项目配置less:

npm install less --save-dev
npm install less-loader --save-dev



配置完先试一试less可不可以使用,如果报错,一般是因为版本高导致的。
可以试着降低版本

"less-loader": "^5.0.0",


二、引入你的组件


比如我这里引入的是Tab标签页组件

<van-tabs v-model="active">
  <van-tab title="标签 1">内容 1</van-tab>
  <van-tab title="标签 2">内容 2</van-tab>
  <van-tab title="标签 3">内容 3</van-tab>
  <van-tab title="标签 4">内容 4</van-tab>
</van-tabs>


export default {
  data() {
    return {
      active: 2,
    };
  },
};


它有默认样式,比如active的字体颜色,底部状态颜色等。


三、修改配置文件


第一步:直接引入less文件
在main.js里引入:

import 'vant/lib/index.less';



第二步:修改样式变量
找到你的vue.config.js文件,没有就在package.json同级新建一个配置文件,添加一下代码:

module.exports = {
  css: {
    loaderOptions: {
      less: {
        // 若 less-loader 版本小于 6.0,请移除 lessOptions 这一级,直接配置选项。
        lessOptions: {
          modifyVars: {
            // 直接覆盖变量
            'text-color': '#111',
            'border-color': '#eee',
            // 或者可以通过 less 文件覆盖(文件路径为绝对路径)
            hack: `true; @import "your-less-file-path.less";`,
          },
        },
      },
    },
  },
};



可以通过直接修改变量,也可以把清单列好成一个less文件引入,注意,如果less版本低的话,按照代码中的注释来。
再回到之前标签组件的使用文档,往下滑找的样式变量这一部分

那么它定义的一些关于组件的样式,你可以对着它的名字来修改你需要修改的样式,比如@tab-active-text-color这一个变量,应该就是表示active状态后字体的颜色,好,我现在需要将它修改为我想要的颜色,那么就在配置文件中修改一下

再重启下服务器,就可以看到组件的样式改变了。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值