# Button 按钮 ### 介绍 按钮用于触发一个操作,如提交表单。 ### 安装 ``` javascript import { Button } from '@nutui/nutui-react-taro'; ``` ## 代码演示 ### 设置 open-type :::demo ```tsx import React from "react"; import { Button } from '@nutui/nutui-react-taro'; const App = () => { return ( <> ); }; export default App; ``` ::: ### 按钮类型 按钮支持 `default`、`primary`、`info`、`warning`、`danger`、`success` 六种类型,默认为 `default`。 :::demo ```tsx import React from "react"; import { Button } from '@nutui/nutui-react-taro'; const App = () => { return ( <> ); }; export default App; ``` ::: ### 填充模式 :::demo ```tsx import React from "react"; import { Button } from '@nutui/nutui-react-taro'; const App = () => { return ( <> ); }; export default App; ``` ::: ### 禁用状态 通过 `disabled` 属性来禁用按钮,禁用状态下按钮不可点击。 :::demo ```tsx import React from "react"; import { Button } from '@nutui/nutui-react-taro'; const App = () => { return ( <> ); }; export default App; ``` ::: ### 按钮形状 通过 `shape` 属性设置按钮形状,支持圆形、方形按钮,默认为圆形。 :::demo ```tsx import React from "react"; import { Button } from '@nutui/nutui-react-taro'; const App = () => { return ( <> ); }; export default App; ``` ::: ### 加载状态 :::demo ```tsx import React ,{useState} from "react"; import { Button } from '@nutui/nutui-react-taro'; const App = () => { const [loading,setLoading] = useState(false) return ( <> ); }; export default App; ``` ::: ### 图标按钮 :::demo ```tsx import React from "react"; import { Button } from '@nutui/nutui-react-taro'; const App = () => { return ( <> ); }; export default App; ``` ::: ### 按钮尺寸 支持 `large`、`normal`、`small` 三种尺寸,默认为 `normal`。 :::demo ```tsx import React from "react"; import { Button } from '@nutui/nutui-react-taro'; const App = () => { return ( <> ); }; export default App; ``` ::: ### 块级元素 按钮在默认情况下为行内块级元素,通过 `block` 属性可以将按钮的元素类型设置为块级元素,常用来实现通栏按钮。 :::demo ```tsx import React from "react"; import { Button } from '@nutui/nutui-react-taro'; const App = () => { return ( <> ); }; export default App; ``` ::: ### 自定义颜色 通过 color 属性可以自定义按钮的颜色。 :::demo ```tsx import React from "react"; import { Button } from '@nutui/nutui-react-taro'; const App = () => { return ( <> ); }; export default App; ``` ::: ## API ### Props | 参数 | 说明 | 类型 | 默认值 | |----------|-------------------------------|-------------|----------| | type | 按钮的样式 | `'default' \| 'primary' \| 'info' \| 'warning' \| 'danger' \| 'success'` | `'default'` | | size | 按钮的尺寸 | `'normal' \| 'large' \| 'small'` | `'normal'` | | shape | 按钮的形状 | `'square' \| 'round'` | `'round'` | | color | 按钮颜色,支持传入 linear-gradient 渐变色 | `string` | - | | fill | 填充模式 | `'solid' \| 'ouline' \| 'none'` | `'solid'` | | disabled | 是否禁用按钮 | `boolean` | `false` | | block | 是否为块级元素 | `boolean` | `false` | | icon | 按钮图标 | `ReactNode` | - | | loading | 按钮loading状态 | `boolean` | `false` | ### Events | 事件名 | 说明 | 回调参数 | |---------------|----------------|--------------| | onClick | 点击按钮时触发 | `event: MouseEvent` | ### 支持小程序API能力 目前1.3.11版本以前不支持原生小程序API, 如果你是需要使用原生小程序button组件能力的用户,请尽快升级至1.3.11版本,关于原生小程序button组件的详细API请前往[查阅更多文档](https://taro-docs.jd.com/docs/components/forms/button) ## 主题定制 ### 样式变量 组件提供了下列 CSS 变量,可用于自定义样式,使用方法请参考 [ConfigProvider 组件](#/zh-CN/component/configprovider)。 | 名称 | 默认值 | | --- | --- | | --nutui-button-border-radius | `25px` | | --nutui-button-border-width | `1px` | | --nutui-button-default-bg-color | `$white` | | --nutui-button-default-border-color | `rgba(204, 204, 204, 1)` | | --nutui-button-default-color | `$gray1` | | --nutui-button-plain-color`v1.4.8` | `$gray2` | | --nutui-button-default-padding | `0 18px` | | --nutui-button-mini-padding | `0 12px` | | --nutui-button-small-padding | `0 12px` | | --nutui-button-small-height | `28px` | | --nutui-button-mini-height | `24px` | | --nutui-button-default-height | `38px` | | --nutui-button-large-height | `48px` | | --nutui-button-large-line-height | `46px` | | --nutui-button-small-line-height | `26px` | | --nutui-button-block-height | `48px` | | --nutui-button-default-line-height | `36px` | | --nutui-button-block-line-height | `46px` | | --nutui-button-default-font-size | `$font-size-2` | | --nutui-button-large-font-size | `$button-default-font-size` | | --nutui-button-small-font-size | `$font-size-1` | | --nutui-button-mini-font-size | `$font-size-1` | | --nutui-button-mini-line-height | `1.2` | | --nutui-button-text-icon-width | `5px` | | --nutui-button-text-icon--large-width | `10px` | | --nutui-button-text-icon-small-width | `2px` | | --nutui-button-text-icon-mini-width | `1px` | | --nutui-button-disabled-opacity | `0.68` | | --nutui-button-primary-color | `$white` | | --nutui-button-primary-border-color | `$primary-color` | | --nutui-button-info-color | `$white` | | --nutui-button-info-border-color | `#496af2` | | --nutui-button-success-color | `$white` | | --nutui-button-success-border-color | `rgba(38, 191, 38, 1)` | | --nutui-button-danger-color | `$white` | | --nutui-button-danger-border-color | `rgba(250, 44, 25, 1)` | | --nutui-button-danger-background-color | `rgba(250, 44, 25, 1)` | | --nutui-button-warning-color | `$white` | | --nutui-button-warning-border-color | `rgba(255, 158, 13, 1)` | | --nutui-button-plain-background-color | `$white` | | --nutui-button-small-round-border-radius | `$button-border-radius` |