微信小程序引入Vant Weapp修改样式不起作用,使用外部样式类进行覆盖

一、引入Vant Weapp后样式问题

在项目中使用第三方组件修改css样式时,总是出现各种各样问题,修改的css样式不起作用,没有效果,效果不符合预期等。

  • 栗子(引入一个搜索框组件)
  • 实现效果: 左侧有一个搜索文字背景为蓝色,接着跟一个搜索框

wxml

java 复制代码
<view class="container">
  <view class="search">
    <view slot="action" bind:tap="onSearch" class="title">搜索</view>
    <van-search value="{{ value }}" placeholder="请输入搜索关键词" use-action-slot="true" bind:search="onSearch" class="input">
    </van-search>
  </view>
</view>

wxss

java 复制代码
.container {
  width: 750rpx;
  height: 150rpx;
  background-color: bisque;
  display: flex;
  align-items: center;
}

.search {
  width: 680rpx;
  height: 64rpx;
  background: #03C5B0;
  border-radius: 68rpx 68rpx 68rpx 68rpx;
  display: flex;
  flex-direction: row;
  margin-top: 24rpx;
  margin-left: 32rpx;
}

.title {
  width: 80rpx;
  height: 64rpx;
  font-size: 28rpx;
  font-family: HarmonyOS Sans SC, HarmonyOS Sans SC;
  font-weight: 500;
  color: #FFFFFF;
  line-height: 33rpx;
  display: flex;
  align-items: center;
  justify-content: center;
}

.input {
  width: 600rpx;
  height: 64rpx;
}

emmm...明明我们css都写了,这出现的是什么鬼

审查一下页面布局看看,这个我也没看懂,应该是组件自带的样式跟我们写的冲突了.(只是猜测)

二、样式覆盖

2.1 使用外部样式类

那么我们要怎样覆盖掉原有的样式呢?

官方也有说明:

外部样式类的相关知识背景请查阅微信小程序文档

Vant Weapp 开放了大量的外部样式类供开发者使用,具体的样式类名称可查阅对应组件的"外部样式类"部分。

需要注意的是普通样式类和外部样式类的优先级是未定义的,因此使用时请添加**!important**以保证外部样式类的优先级。

2.2 实现

wxml

java 复制代码
<view class="container">
  <view class="searchCopy">
    <view slot="action" bind:tap="onSearch" class="titleCopy">搜索</view>
    <van-search value="{{ value }}" placeholder="请输入搜索关键词" use-action-slot="true" bind:search="onSearch" custom-class="inputCopy">
    </van-search>
  </view>
</view>

wxss

java 复制代码
/* 样式覆盖 */
.container {
  width: 750rpx;
  height: 150rpx;
  background-color: bisque;
  display: flex;
  align-items: center;
}

.searchCopy {
  width: 680rpx;
  height: 64rpx;
  background: #03C5B0;
  border-radius: 68rpx 68rpx 68rpx 68rpx;
  display: flex;
  flex-direction: row;
  margin-top: 24rpx;
  margin-left: 32rpx;
}

.titleCopy {
  width: 80rpx;
  height: 64rpx;
  font-size: 28rpx;
  font-family: HarmonyOS Sans SC, HarmonyOS Sans SC;
  font-weight: 500;
  color: #FFFFFF;
  line-height: 33rpx;
  display: flex;
  align-items: center;
  justify-content: center;
}

.inputCopy {
  width: 600rpx !important;
  height: 64rpx !important;
}

两种方式实现对比,效果立竿见影,看起来顺眼多了

:定义外部样式类css后一定要写**!important**

2.3 查看外部样式类

每个组件最下方都表明了可覆盖的外部样式类

相关推荐
说私域9 小时前
社群裂变+2+1链动新纪元:S2B2C小程序如何重塑企业客户管理版图?
大数据·人工智能·小程序·开源
寰宇软件10 小时前
PHP CRM售后系统小程序
微信小程序·小程序·vue·php·uniapp
浩宇软件开发15 小时前
微信小程序实现自定义日历功能
微信小程序·小程序
Q_274378510915 小时前
springboot基于微信小程序的健康管理系统
spring boot·后端·微信小程序
V+zmm1013418 小时前
教育培训微信小程序ssm+论文源码调试讲解
java·数据库·微信小程序·小程序·毕业设计
樊南19 小时前
【esp32-uniapp小程序】uniapp小程序篇02——Hbuilder利用git连接远程仓库
git·小程序·gitee·uni-app·hbuilder·torisegit
寰宇软件20 小时前
PHP校园助手系统小程序
小程序·vue·php·uniapp
陈钇钇21 小时前
持续升级《在线写python》小程序的功能,文章页增加一键复制功能,并自动去掉html标签
python·小程序·html
计算机-秋大田21 小时前
基于SSM的家庭记账本小程序设计与实现(LW+源码+讲解)
java·前端·后端·微信小程序·小程序·课程设计
大叔_爱编程21 小时前
wx036基于springboot+vue+uniapp的校园快递平台小程序
vue.js·spring boot·小程序·uni-app·毕业设计·源码·课程设计