# Button 按钮 ### 引入 ```js import Vue from 'vue'; import { Button } from 'vant'; Vue.use(Button); ``` ## 代码演示 ### 按钮类型 支持`default`、`primary`、`info`、`warning`、`danger`五种类型,默认为`default` ```html 默认按钮 主要按钮 信息按钮 警告按钮 危险按钮 ``` ### 朴素按钮 通过`plain`属性将按钮设置为朴素按钮,朴素按钮的文字为按钮颜色,背景为白色。 ```html 朴素按钮 朴素按钮 ``` ### 细边框 设置`hairline`属性可以开启 0.5px 边框,基于伪类实现 ```html 细边框按钮 细边框按钮 ``` ### 禁用状态 通过`disabled`属性来禁用按钮,禁用状态下按钮不可点击 ```html 禁用状态 禁用状态 ``` ### 加载状态 通过`loading`属性设置按钮为加载状态,加载状态下默认会隐藏按钮文字,可以通过`loading-text`设置加载状态下的文字 ```html ``` ### 按钮形状 通过`square`设置方形按钮,通过`round`设置圆形按钮 ```html 方形按钮 圆形按钮 ``` ### 图标按钮 通过`icon`属性设置按钮图标,支持 Icon 组件里的所有图标,也可以传入图标 URL ```html 按钮 按钮 ``` ### 按钮尺寸 支持`large`、`normal`、`small`、`mini`四种尺寸,默认为`normal` ```html 大号按钮 普通按钮 小型按钮 迷你按钮 ``` ### 块级元素 按钮在默认情况下为行内块级元素,通过`block`属性可以将按钮的元素类型设置为块级元素 ```html 块级元素 ``` ### 页面导航 可以通过`url`属性进行 URL 跳转,或通过`to`属性进行路由跳转 ```html URL 跳转 路由跳转 ``` ### 自定义颜色 通过`color`属性可以自定义按钮的颜色 ```html 单色按钮 单色按钮 渐变色按钮 ``` ## API ### Props | 参数 | 说明 | 类型 | 默认值 | | --- | --- | --- | --- | | type | 类型,可选值为 `primary` `info` `warning` `danger` | _string_ | `default` | | size | 尺寸,可选值为 `large` `small` `mini` | _string_ | `normal` | | text | 按钮文字 | _string_ | - | | color `v2.1.8` | 按钮颜色,支持传入`linear-gradient`渐变色 | _string_ | - | | icon | 左侧[图标名称](#/zh-CN/icon)或图片链接 | _string_ | - | | icon-prefix `v2.6.0` | 图标类名前缀,同 Icon 组件的 [class-prefix 属性](#/zh-CN/icon#props) | _string_ | `van-icon` | | tag | 根节点的 HTML 标签 | _string_ | `button` | | native-type | 原生 button 标签的 type 属性 | _string_ | - | | block | 是否为块级元素 | _boolean_ | `false` | | plain | 是否为朴素按钮 | _boolean_ | `false` | | square | 是否为方形按钮 | _boolean_ | `false` | | round | 是否为圆形按钮 | _boolean_ | `false` | | disabled | 是否禁用按钮 | _boolean_ | `false` | | hairline | 是否使用 0.5px 边框 | _boolean_ | `false` | | loading | 是否显示为加载状态 | _boolean_ | `false` | | loading-text | 加载状态提示文字 | _string_ | - | | loading-type | [加载图标类型](#/zh-CN/loading),可选值为`spinner` | _string_ | `circular` | | loading-size | 加载图标大小 | _string_ | `20px` | | url | 点击后跳转的链接地址 | _string_ | - | | to | 点击后跳转的目标路由对象,同 vue-router 的 [to 属性](https://router.vuejs.org/zh/api/#to) | _string \| object_ | - | | replace | 是否在跳转时替换当前页面历史 | _boolean_ | `false` | ### Events | 事件名 | 说明 | 回调参数 | | ---------- | ---------------------------------------- | ------------------- | | click | 点击按钮,且按钮状态不为加载或禁用时触发 | _event: Event_ | | touchstart | 开始触摸按钮时触发 | _event: TouchEvent_ |