微信小程序-使用vant组件库

文章目录

微信小程序-使用vant组件库

概述

Vant Weapp 是有赞前端团队开源的小程序 UI 组件库,基于微信小程序的自定义组件开发,可用来快速搭建小程序项目。

官方文档

构建npm

目前小程序已经支持使用 npm 安装第三方包,但是这些 npm 包在小程序中不能够直接使用,必须得使用小程序开发者工具进行构建后才可以使用。

因为 node_modules 目录下的包,不会参与小程序项目的编译、上传和打包,因此。在小程序项目中要想使用 npm 包,必须走一遍 构建 npm 的过程。

在构建成功以后,默认会在小程序项目根目录,也就是 node_modules 同级目录下生成 miniprogram_npm目录,里面存放这构建打包后的 npm 包,也就是小程序运行过程中真正使用的包。

目录结构如下:

构建步骤

一、执行命令 npm init -y,生成 package.json 文件。

二、执行命令 npm i @vant/weapp,添加 vant 组件库。

如果遇到问题,可以先清理缓存,执行命令 npm cache clean --force.

三、点击微信开发者工具:菜单栏 -> 工具 -> 构建npm,会生成 minnprogram_npm 目录。

生成如下目录结构:

四、删除 app.json 文件中 style:v2 属性,小程序的新版基础组件强行加上了许多样式,难以覆盖,不关闭将造成部分组件样式混乱。

使用vant

注册

  • 全局注册:在 app.json 中注册,可以在任意组件中使用。

  • 局部注册:在 index.json 中注册,只能在当前组件中使用。

    // index.json
    "usingComponents": {
    "van-image": "@vant/weapp/image/index"
    }

    // app.json
    "usingComponents": {
    "van-image": "@vant/weapp/image/index"
    }

使用

html 复制代码
<van-button type="default">默认按钮</van-button>
<van-button type="primary">主要按钮</van-button>
<van-button type="info">信息按钮</van-button>
<van-button type="warning">警告按钮</van-button>
<van-button type="danger">危险按钮</van-button>
html 复制代码
<!-- 网络图片: -->
<van-image width="100" height="100" src="https://img.yzcdn.cn/vant/cat.jpeg" />
<!-- 本地图片: -->
<van-image width="100" height="100" src="/images/a.png" />
<!-- 圆形图片: -->
<van-image width="100" height="100" round src="/images/a.png" />

添加事件

事件名 说明 回调参数
bind:click 点击图片时触发 event: Event
bind:load 图片加载完毕时触发 event: Event
bind:error 图片加载失败时触发 event: Event
<van-image width="100" height="100" src="https://img.yzcdn.cn/vant/cat.jpeg" bind:click="handleClick" />

Page({
  handleClick() {
    console.log("点击了网络图片")
  },
})

使用插槽

名称 说明
loading 自定义加载中的提示内容
error 自定义加载失败时的提示内容
html 复制代码
<van-image width="100" height="100" src="https://img.yzcdn.cn/vant/cat.jpeg" use-loading-slot use-error-slot>
  <van-loading slot="loading" type="spinner" size="20" vertical />
  <text slot="error">加载失败</text>
</van-image>

样式覆盖

Vant Weapp 基于微信小程序的机制,为开发者提供了以下 3 种修改组件样式的方法:

  1. 解除样式隔离:在页面中使用 Vant Weapp 组件时,可直接在页面的样式文件中覆盖样式
  2. 使用外部样式类:需要注意普通样式类和外部样式类的优先级是未定义的,需要添加 !important 保证外部样式类的优先级
  3. 使用 CSS 变量:在页面或全局对多个组件的样式做批量修改以进行主题样式的定制

解除样式隔离

Vant Weapp 的所有组件都开启了addGlobalClass: true以接受外部样式的影响,因此我们可以通过审核元素的方式获取当前元素的类名,然后复制到组件的 .wxss 中进行修改。

<van-button type="danger">危险按钮</van-button>

.van-button--danger {
  background-color: blue !important;
  border: 10rpx solid yellow !important;
}

效果如下:

使用外部样式类

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

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

如下是 van-button 的外部样式类:

类名 说明
custom-class 根节点样式类
hover-class 指定按钮按下去的样式类
loading-class 加载图标样式类
<van-button type="info" custom-class="my-custom-class">信息按钮</van-button>

.my-custom-class {
  background-color: lightcoral !important;
  color: blue !important;
}

效果如下:

使用CSS变量

Vant Weapp 为部分 CSS 属性开放了基于 CSS 属性的定制方案。

相较于 解除样式隔离 和 使用外部样式类,这种方案支持在页面或应用级别对多个组件的样式做批量修改以进行主题样式的定制。

当然,用它来修改单个组件的部分样式也是绰绰有余的

一、声明自定义属性,属性名需要以两个减号(--)开始,属性值则可以是任何有效的 CSS 值

/* 声明全局变量 */
page {
  --main-bg-color: lightcoral;
}

二、使用全局变量,用 var() 函数包裹

/* 声明全局变量 */
page {
  --main-bg-color: lightcoral;
}

/* 声明局部变量 */
.container {
  --main-bg-color: lightseagreen;
}

三、使用

<van-button type="primary" custom-class="my-custom-class2">主要按钮</van-button>

.my-custom-class2 {
  background-color: var(--main-bg-color) !important;
  color: red !important;
}

四、也可以在按钮上直接添加类名:

<van-button type="default" class="my-button">默认按钮</van-button>

.my-button {
  --my-background-color: red;
  --my-border-color: blue;
}

.van-button--default {
  font-size: 28rpx !important;
  background-color: var(--my-background-color) !important;
  border: 1px solid var(--my-border-color) !important;
}

效果如下:

相关推荐
_Dream_C8 小时前
抓包小程序
安全·小程序·iot
李宥小哥8 小时前
微信小程序03-页面交互
微信小程序·交互·notepad++
少恭写代码11 小时前
使用duxapp开发 React Native App 事半功倍
react native·小程序·taro·duxapp
未来之窗软件服务13 小时前
医院伤员小程序点餐———未来之窗行业应用跨平台架构
前端·javascript·小程序·点餐小程序
郑州拽牛科技13 小时前
全方位洗衣洗鞋小程序系统,重塑干洗店服务新体验;
大数据·小程序·系统架构·开源软件
m0_7401904613 小时前
小程序-基础知识1
小程序
说私域13 小时前
公私域互通下的新商机探索:链动2+1模式、AI智能名片与S2B2C商城小程序的融合应用
人工智能·小程序
会写代码的青蛙13 小时前
Java律师法律咨询小程序
java·开发语言·小程序
我非夏日13 小时前
小程序开发设计-小程序的宿主环境:组件⑦
小程序
Minyy1113 小时前
小程序-生命周期与WXS脚本
开发语言·前端·javascript·小程序