解决vant title-active-color与title-inactive-color不生效问题


Posted in Javascript onNovember 03, 2020

1、创建vue项目

2、使用vant组件

npm install vant --S

全局引用时在main.js引入

import Vant from 'vant';
import 'vant/lib/index.css';
Vue.use(Vant);

假如你引入之后发现页面的样式和组件都挂载了,但是console控制台会报错,说xxxx组件没有register,这个时候很有可能是你的vant插件版本有问题,重新下载一个最新的vant就可以了,现在是2.6.0版本

好,接下来继续

在需要使用下拉框的地方使用下拉框组件

<van-dropdown-menu>
 <van-dropdown-item
  v-model="value"
 :options="developList"
 />
</van-dropdown-menu>
 
data () {
 return {
 value: ''
 developList: [
  {
  value: '1',
  text: '我是第一个'
  },
 {
  value: '2',
  text: '我是第二个'
  },
 ]
 }
}

假如是这样的话那么下拉框就会默认显示第一个字眼“wishing第一个”,然后你在点击下拉框选择第二个时也会改变成“我是第二个”

如果你不想有默认选中,并且一开始就显示请选择这样的提示字眼,那么我们可以去看看vant的api文档,发现有一个title的字眼,这个title就是下拉框的显示文字,一开始很多人以为这个下拉框的title只是用来显示然后点击下拉框的item之后会自动绑定过的,但其实是错误的,以下就是一个很好的例子

<van-dropdown-menu>
 <van-dropdown-item
 title="请选择"
 v-model="value"
 :disabled="disabled"
 :options="developList"
 />
</van-dropdown-menu>
 
data () {
 return {
 value: ''
 developList: [
  {
  value: '1',
  text: '我是第一个'
  },
 {
  value: '2',
  text: '我是第二个'
  },
 ]
 }
}

你会发现请选择的自然从来没变过,无论你选择了第一个还是第二个,那么你就会想title是不是绑定,接下来就有以下操作

<van-dropdown-menu>
 <van-dropdown-item
 :title="title"
 v-model="value"
 :disabled="disabled"
 :options="developList"
 />
</van-dropdown-menu>
 
data () {
 return {
 value: ''
 title:''请选择,
 developList: [
  {
  value: '1',
  text: '我是第一个'
  },
 {
  value: '2',
  text: '我是第二个'
  },
 ]
 }
}

加下来发现还是没有改动啊,那是不是绑定的值没有发生改变了,好像是的,因为你值定义了这个title,这个title就是下拉框选择的显示,只是你没有title的时候vant把你选择的text文字映射到title上去了,

一旦你自己使用title进行绑定,那么每次修改时就要修改title,查看vant api可以发现有change事件,接下来就可以操作了

<van-dropdown-menu>
 <van-dropdown-item
 :title="title"
 v-model="value"
 :options="developList"
 @change="changeDevelop"
 />
</van-dropdown-menu>
 
data () {
 return {
 value: ''
 title:''请选择,
 developList: [
  {
  value: '1',
  text: '我是第一个'
  },
 {
  value: '2',
  text: '我是第二个'
  },
 ]
 }
},
 
methods: {
 changeDevelop (i) {
 this.title = this.developList[i-1].text
 },
}

这就没问题啦!

补充知识:简单粗暴修改vant组件nav-bar的title(标题的字体颜色)

最近我有人问我关于vant组件的nav-bar的标题颜色需要改但是不会,我去网上找了一下,发现都很复杂

然后我发现通过深度选择器可以修改nav-bar的标题的字体颜色

代码:

<template>
 <view>
 <demo-block title="基础用法" class="reset">
 <van-nav-bar title="标题" left-text="返回" right-text="按钮" left-arrow @clickLeft="onClickLeft" @clickRight="onClickRight" id="reset"/>
 </demo-block>

 <demo-block title="高级用法">
 <van-nav-bar title="标题" left-text="返回" left-arrow>
 <van-icon name="search" slot="right" custom-class="icon" />
 </van-nav-bar>
 </demo-block>

 </view>
</template>

<script>
 import Page from '../../common/page';

 export default {
 data() {
 return {

 }
 },
 onLoad() {},
 methods: {
 onClickLeft() {
 console.log("11");//TODO 进不来
 uni.showToast({
  title: '点击返回',
  icon: 'none'
 });
 },

 onClickRight() {
 uni.showToast({
  title: '点击按钮',
  icon: 'none'
 });
 }
 }
 }
</script>

<style>
 .icon {
 color: #1989fa;
 } 
 #reset /deep/ .van-ellipsis{
 color: red !important;
 }
</style>

效果:

解决vant title-active-color与title-inactive-color不生效问题

解释: 给组件定义个id,再通过这个深度选择器获取title的标签的类名,修改它的颜色即可.

以上这篇解决vant title-active-color与title-inactive-color不生效问题就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
对YUI扩展的Gird组件 Part-1
Mar 10 Javascript
用cssText批量修改样式
Aug 29 Javascript
动态加载script文件的两种方法
Aug 15 Javascript
jquery修改属性值实例代码(设置属性值)
Jan 06 Javascript
点击弹出层效果&amp;弹出窗口后网页背景变暗效果的实现代码
Feb 10 Javascript
JavaScript使用slice函数获取数组部分元素的方法
Apr 06 Javascript
使用jQuery的load方法设计动态加载及解决被加载页面js失效问题
Mar 01 Javascript
React 子组件向父组件传值的方法
Jul 24 Javascript
浅析vue给不同环境配置不同打包命令
Aug 17 Javascript
vue template中slot-scope/scope的使用方法
Sep 06 Javascript
使用JavaScript实现贪吃蛇游戏
Sep 29 Javascript
解决vant-UI库修改样式无效的问题
Nov 03 Javascript
如何在vue中使用百度地图添加自定义覆盖物(水波纹)
Nov 03 #Javascript
JavaScript语法约定和程序调试原理解析
Nov 03 #Javascript
解决vux 中popup 组件Mask 遮罩在最上层的问题
Nov 03 #Javascript
React Native登录之指纹登录篇的示例代码
Nov 03 #Javascript
解决VantUI popup 弹窗不弹出或无蒙层的问题
Nov 03 #Javascript
wepy--用vantUI 实现上弹列表并选择相应的值操作
Nov 03 #Javascript
使用vant的地域控件追加全部选项
Nov 03 #Javascript
You might like
收音机术语解释
2021/03/01 无线电
php魔术函数__call()用法实例分析
2015/02/13 PHP
CI框架实现框架前后端分离的方法详解
2016/12/30 PHP
老生常谈文本文件和二进制文件的区别
2017/02/27 PHP
PHP随机数函数rand()与mt_rand()的讲解
2019/03/25 PHP
Javascript模块化编程详解
2014/12/01 Javascript
js实现仿百度风云榜可重复多次调用的TAB切换选项卡效果
2015/08/31 Javascript
辨析JavaScript中的Undefined类型与null类型
2016/05/26 Javascript
JS中常用的输出方式(五种)
2016/06/12 Javascript
浅谈JQ中mouseover和mouseenter的区别
2016/09/13 Javascript
一步一步封装自己的HtmlHelper组件BootstrapHelper(三)
2016/09/14 Javascript
Mongoose实现虚拟字段查询的方法详解
2017/08/15 Javascript
Vue2.0基于vue-cli+webpack同级组件之间的通信教程(推荐)
2017/09/14 Javascript
如何阻止小程序遮罩层下方图层滚动
2019/09/05 Javascript
高性能js数组去重(12种方法,史上最全)
2019/12/21 Javascript
vue+echarts实现中国地图流动效果(步骤详解)
2021/01/27 Vue.js
浅谈python迭代器
2017/11/08 Python
对Python中9种生成新对象的方法总结
2018/05/23 Python
使用Python实现微信提醒备忘录功能
2018/12/04 Python
详解python校验SQL脚本命名规则
2019/03/22 Python
Python基础教程之if判断,while循环,循环嵌套
2019/04/25 Python
python pygame实现五子棋小游戏
2020/10/26 Python
详解Python中的正斜杠与反斜杠
2019/08/09 Python
flask框架url与重定向操作实例详解
2020/01/25 Python
Jupyter Notebook 文件默认目录的查看以及更改步骤
2020/04/14 Python
详解如何将 Canvas 绘制过程转为视频
2021/01/25 HTML / CSS
Nili Lotan官网:Nili Lotan同名品牌
2018/01/07 全球购物
DC Shoes俄罗斯官网:美国滑板鞋和服饰品牌
2020/08/19 全球购物
银行委托书范本
2014/09/28 职场文书
写给导师的自荐信
2015/03/06 职场文书
整改通知书
2015/04/20 职场文书
Python list去重且保持原顺序不变的方法
2021/04/03 Python
mysql的数据压缩性能对比详情
2021/11/07 MySQL
Python Flask搭建yolov3目标检测系统详解流程
2021/11/07 Python
JavaScript中MutationObServer监听DOM元素详情
2021/11/27 Javascript
pt-archiver 主键自增
2022/04/26 MySQL