SubmitBar 提交订单栏
介绍
用于展示订单金额与提交订单。
引入
js
import { createApp } from 'vue';
import { SubmitBar } from '@szhn/dh-design-mobile';
const app = createApp();
app.use(SubmitBar);代码演示
基础用法
基础用法展示订单总金额。
html
<van-submit-bar :price="3050" button-text="提交订单" @submit="onSubmit" />禁用状态
禁用状态下不可点击按钮,同时可以自定义禁用的提示文案。
html
<van-submit-bar
disabled
:price="3050"
button-text="提交订单"
tip="你的收货地址不支持配送"
tip-icon="info-o"
@submit="onSubmit"
/>加载状态
加载状态下不可点击按钮,同时按钮上会显示加载动画。
html
<van-submit-bar loading :price="3050" button-text="提交订单" @submit="onSubmit" />高级用法
通过插槽插入自定义内容。
html
<van-submit-bar :price="3050" button-text="提交订单" @submit="onSubmit">
<van-checkbox v-model="checked">全选</van-checkbox>
<template #tip>
你的收货地址不支持配送,<span @click="onClickLink">修改地址</span>
</template>
</van-submit-bar>API
Props
| 参数 | 说明 | 类型 | 默认值 |
|---|---|---|---|
| price | 金额(单位分) | number | - |
| decimal-length | 金额小数点位数 | number | string | 2 |
| label | 价格左侧文案 | string | 合计: |
| suffix-label | 价格右侧文案 | string | - |
| text-align | 价格文案对齐方向 | string | right |
| button-text | 按钮文字 | string | - |
| button-type | 按钮类型 | string | danger |
| button-color | 自定义按钮颜色 | string | - |
| tip | 在订单栏上方的提示文案 | string | - |
| tip-icon | 提示文案左侧的图标名称 | string | - |
| currency | 货币符号 | string | ¥ |
| disabled | 是否禁用按钮 | boolean | false |
| loading | 是否显示加载状态 | boolean | false |
| safe-area-inset-bottom | 是否开启底部安全区适配 | boolean | true |
| placeholder | 是否在标签位置生成一个等高的占位元素 | boolean | false |
Events
| 事件名 | 说明 | 回调参数 |
|---|---|---|
| submit | 按钮点击事件回调 | - |
Slots
| 名称 | 说明 |
|---|---|
| default | 自定义订单栏左侧内容 |
| button | 自定义按钮 |
| top | 自定义订单栏上方内容 |
| tip | 提示文案中的额外内容 |
主题定制
样式变量
组件提供了下列 CSS 变量,可用于自定义样式,使用方法请参考 ConfigProvider 组件。
| 名称 | 默认值 | 描述 |
|---|---|---|
| --van-submit-bar-height | 50px | 提交订单栏的高度 |
| --van-submit-bar-z-index | 100 | 提交订单栏的层级 |
| --van-submit-bar-background | var(--van-background-2) | 提交订单栏的背景色 |
| --van-submit-bar-button-width | 110px | 提交按钮的宽度 |
| --van-submit-bar-price-color | var(--van-danger-color) | 价格的文字颜色 |
| --van-submit-bar-price-font-size | var(--van-font-size-sm) | 价格的字体大小 |
| --van-submit-bar-price-integer-font-size | 20px | 价格整数部分的字体大小 |
| --van-submit-bar-price-font | var(--van-price-font) | 价格的字体 |
| --van-submit-bar-text-color | var(--van-text-color) | 文字颜色 |
| --van-submit-bar-text-font-size | var(--van-font-size-md) | 文字的字体大小 |
| --van-submit-bar-tip-padding | var(--van-padding-xs) var(--van-padding-sm) | 提示区域的内边距 |
| --van-submit-bar-tip-font-size | var(--van-font-size-sm) | 提示文字的字体大小 |
| --van-submit-bar-tip-line-height | 1.5 | 提示文字的行高 |
| --van-submit-bar-tip-color | var(--van-orange-dark) | 提示文字的颜色 |
| --van-submit-bar-tip-background | var(--van-orange-light) | 提示区域的背景色 |
| --van-submit-bar-tip-icon-size | 12px | 提示图标的大小 |
| --van-submit-bar-button-height | 40px | 提交按钮的高度 |
| --van-submit-bar-padding | 0 var(--van-padding-md) | 提交订单栏的内边距 |
