3w# Button 按钮 ### 引入 在`app.json`或`index.json`中引入组件,详细介绍见[快速上手](#/quickstart#yin-ru-zu-jian) ```json "usingComponents": { "van-button": "path/to/@vant/weapp/dist/button/index" } ``` ## 代码演示 ### 按钮类型 支持`default`、`primary`、`info`、`warning`、`danger`五种类型,默认为`default` ```html 默认按钮 主要按钮 信息按钮 警告按钮 危险按钮 ``` ### 朴素按钮 通过`plain`属性将按钮设置为朴素按钮,朴素按钮的文字为按钮颜色,背景为白色 ```html 朴素按钮 朴素按钮 ``` ### 细边框 设置`hairline`属性可以开启 0.5px 边框,基于伪类实现 ```html 细边框按钮 细边框按钮 ``` ### 禁用状态 通过`disabled`属性来禁用按钮,此时按钮不可点击 ```html 禁用状态 禁用状态 ``` ### 加载状态 ```html ``` ### 图标按钮 通过`icon`属性设置按钮图标,支持 Icon 组件里的所有图标,也可以传入图标 URL ```html 按钮 按钮 ``` ### 按钮形状 ```html 方形按钮 圆形按钮 ``` ### 按钮尺寸 支持`large`、`normal`、`small`、`mini`四种尺寸,默认为`normal` ```html 大号按钮 普通按钮 小型按钮 迷你按钮 ``` ### 自定义颜色 通过`color`属性可以自定义按钮的颜色 ```html 单色按钮 单色按钮 渐变色按钮 ``` ### 块级元素 通过`block`属性可以将按钮的元素类型设置为块级元素 ```html 块级元素 ``` ## API ### Props | 参数 | 说明 | 类型 | 默认值 | 版本 | |-----------|-----------|-----------|-------------|-------------| | id | 标识符 | *string* | - | - | | type | 按钮类型,可选值为 `primary` `info` `warning` `danger` | *string* | `default` | - | | size | 按钮尺寸,可选值为 `normal` `large` `small` `mini` | *string* | `normal` | - | | color | 按钮颜色,支持传入`linear-gradient`渐变色 | *string* | - | 1.0.0 | | icon | 左侧图标名称或图片链接,可选值见 [Icon 组件](#/icon) | *string* | - | - | | plain | 是否为朴素按钮 | *boolean* | `false` | - | | block | 是否为块级元素 | *boolean* | `false` | - | | round | 是否为圆形按钮 | *boolean* | `false` | - | | square | 是否为方形按钮 | *boolean* | `false` | - | | disabled | 是否禁用按钮 | *boolean* | `false` | - | | hairline | 是否使用 0.5px 边框 | *boolean* | `false` | - | | loading | 是否显示为加载状态 | *boolean* | `false` | - | | loading-text | 加载状态提示文字 | *string* | - | - | | loading-type | 加载状态图标类型,可选值为 `spinner` | *string* | `circular` | - | | loading-size | 加载图标大小 | *string* | `20px` | - | | custom-style | 自定义样式 | *string* | - | - | | open-type | 微信开放能力,具体支持可参考 [微信官方文档](https://mp.weixin.qq.com/debug/wxadoc/dev/component/button.html) | *string* | - | - | | app-parameter | 打开 APP 时,向 APP 传递的参数 | *string* | - | - | | lang | 指定返回用户信息的语言,zh_CN 简体中文,
zh_TW 繁体中文,en 英文 | *string* | `en` | - | - | | session-from | 会话来源 | *string* | - | - | | business-id | 客服消息子商户 id | *number* | - | - | | send-message-title | 会话内消息卡片标题 | *string* | 当前标题 | - | | send-message-path | 会话内消息卡片点击跳转小程序路径 | *string* | 当前分享路径 | - | | send-message-img | sendMessageImg | *string* | 截图 | - | | show-message-card | 显示会话内消息卡片 | *string* | `false` | - | ### Events | 事件名 | 说明 | 参数 | |-----------|-----------|-----------| | bind:click | 点击按钮,且按钮状态不为加载或禁用时触发 | - | | bind:getuserinfo | 用户点击该按钮时,会返回获取到的用户信息,
从返回参数的 detail 中获取到的值同 wx.getUserInfo | - | | bind:contact | 客服消息回调 | - | | bind:getphonenumber | 获取用户手机号回调 | - | | bind:error | 当使用开放能力时,发生错误的回调 | - | | bind:opensetting | 在打开授权设置页后回调 | - | > Button 提供的是 click 事件而不是原生 tap 事件,按钮禁用时,click 事件不会触发,tap 事件依然会触发。 ### 外部样式类 | 类名 | 说明 | |-----------|-----------| | custom-class | 根节点样式类 | | loading-class | 加载图标样式类 |