支付输入框自动设置“合适金额”

背景

零售中,允许用户使用多种方式合并支付一个订单,但是当用户选择一种方式的时候,还是期望有一个合适的金额,来减少其交互使用的成本。

获得焦点时的金额

合适的金额,默认设置为用户想设置的金额。什么是用户想设置的金额呢?

分为3种情况:

1 用户还未选择任何一种方式时,默认为订单金额

2 已经选择一种支付方式,但是还未付款完成,默认是剩余金额

3 选择了其他方式,并且已经完整了整单金额,默认是0

稍微简化一些,其实上面那种,都是订单剩余支付金额。

但是,仅仅是这样是不严谨的,因为每种方式的可付金额还受到其他限制,比如该种方式的用户可用余额,该方式订单最大支持使用的额度,该方式平台支持的最大额。

所以最后默认的金额应该是:

ini 复制代码
let defaultMoney = Math.min(orderRestMoney,userMoney,checkMoney);

输入修改金额时

用户是否能设置超过剩余金额呢?理论可以,实际也可以。

所以修改金额的时候,只要限制不超过userMoney,checkMoney即可。

这里注意一个问题,这里可能会导致总收金额大于应付金额。所以:

1 要判断下,此时产品是否需要自动校准减小其他方式的金额

2 不符合条件时,要让提交订单的操作交互上不可用

离开焦点时

因为获得焦点和修改的时候,都校验了数字的有效性,所以这里主要验证金额非空并大于0即可。

相关推荐
前端付豪7 分钟前
实现必要的流式输出(Streaming)
前端·后端·agent
张元清9 分钟前
useMediaQuery:React 响应式设计完全指南
前端·javascript·面试
小金鱼Y10 分钟前
一文吃透 JavaScript 防抖:从原理到实战,让你的页面不再 “手抖”
前端·javascript·面试
Z兽兽13 分钟前
React 18 开发环境下useEffect 会执行两次,原因分析及解决方案
前端·react.js·前端框架
紫_龙15 分钟前
最新版vue3+TypeScript开发入门到实战教程之Vue3详解props
前端·vue.js·typescript
树上有只程序猿21 分钟前
这波低代码热,能维持多久
前端
姓王名礼27 分钟前
这是一个完整的全栈交付包,包含Vue3 前端交互界面(集成数字人视频流、ECharts 图表、语音对话)和Docker Compose 一键部署脚本。
前端·docker·echarts
嵌入式-老费30 分钟前
vivado hls的应用(axis接口)
前端·webpack·node.js
孟陬37 分钟前
国外技术周刊第 2 期 — 本周热门 🔥 YouTube 视频 TED 演讲 AI 如何能够拯救(而非摧毁)教育
前端·后端·程序员
小飞大王6661 小时前
从零手写 React:深度解析 Fiber 架构与 Hooks 实现
前端·react.js·架构