文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

Vant主题定制怎么修改颜色样式

2023-06-30 10:13

关注

这篇文章主要讲解了“Vant主题定制怎么修改颜色样式”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Vant主题定制怎么修改颜色样式”吧!

Vant主题定制修改颜色

使用场景

需要修改vant组件的颜色或其他的样式时,可以用以下方法进行自定义修改。

Vant主题定制怎么修改颜色样式

一个简单的效果:

Vant主题定制怎么修改颜色样式

第一种:完全替换主题色或其他样式

用Vant官方提供的方法进行定制:

main.js引入样式原文件

// 引入全部样式import 'vant/lib/index.less';// 引入单个组件样式import 'vant/lib/button/style/less';

创建less文件

Vant主题定制怎么修改颜色样式

修改配置

用vue-cli搭建的可以直接在vue.config.js中更改配置:

const path = require("path");//less文件的路径const myTheme = path.resolve(__dirname, "./src/assets/less/vantChange.less");module.exports = {    css: {        loaderOptions: {            less: {                modifyVars: {                    hack: `true; @import "${myTheme}";`                }            },        }    },}

修改样式

参考官网提供的样式变量

Vant主题定制怎么修改颜色样式

Vant主题定制怎么修改颜色样式

第二种:直接覆盖样式

找到class类名

在控制台选中元素,获取class类名,双击选中复制

Vant主题定制怎么修改颜色样式

修改样式

<style lang="less" scoped>.van-sidebar-item--select::before{  background-color:#CCCCFF;}.van-sidebar-item--select, .van-sidebar-item--select:active{  background-color:#FFCCCC;  color:white;}</style>

Vant自定义主题颜色

先看效果图

修改前:

Vant主题定制怎么修改颜色样式

修改后

// less文件代码 @white: #000;

Vant主题定制怎么修改颜色样式

步骤方法

在main.js 中引入

import 'vant/lib/index.less';

新建less 文件,用来覆盖修改 框架里的颜色

Vant主题定制怎么修改颜色样式

安装less和 less-loader, less-loader徐、需安装5.0.0版本

npm install less --save-devnpm install less less-loader@5.0.0 --save-dev

在vue.config.js 文件中添加以代码

// 需要放在module.exports对象里  chainWebpack: config => {    const types = ['vue-modules', 'vue', 'normal-modules', 'normal']    types.forEach(type => addStyleResource(config.module.rule('less').oneOf(type)))  },// 此函数为方法体,需放在对象的外面function addStyleResource(rule) {  rule.use('style-resource')    .loader('style-resources-loader')    .options({      patterns: [        path.resolve(__dirname, './src/assets/less/vant.less'), // 需要全局导入的less      ],    })}

完整的代码为:

function addStyleResource(rule) {  rule.use('style-resource')    .loader('style-resources-loader')    .options({      patterns: [        path.resolve(__dirname, './src/assets/less/vant.less'), // 需要全局导入的less      ],    })}  module.exports = {    css: {    extract: IS_PROD, // 是否将组件中的 CSS 提取至一个独立的 CSS 文件中 (而不是动态注入到 JavaScript 中的 inline 代码)。    sourceMap: false,    loaderOptions: {      // less加载器      less: {        javascriptEnabled: true,        modifyVars: {          // 直接覆盖变量          // 'text-color': 'red',          // 或者可以通过 less 文件覆盖(文件路径为绝对路径)          'hack': `true; @import "${resolve('./src/assets/less/vant.less')}";`        }      },      scss: {        // 向全局sass样式传入共享的全局变量, $src可以配置图片cdn前缀        // 详情: https://cli.vuejs.org/guide/css.html#passing-options-to-pre-processor-loaders        // prependData: `        //   @import "assets/css/mixin.scss";        //   @import "assets/css/variables.scss";        //   $cdn: "${defaultSettings.$cdn}";        //   `      }    }  },  // 对象参数  chainWebpack: config => {    const types = ['vue-modules', 'vue', 'normal-modules', 'normal']    types.forEach(type => addStyleResource(config.module.rule('less').oneOf(type)))  }}

感谢各位的阅读,以上就是“Vant主题定制怎么修改颜色样式”的内容了,经过本文的学习后,相信大家对Vant主题定制怎么修改颜色样式这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是编程网,小编将为大家推送更多相关知识点的文章,欢迎关注!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯