uni-app项目支付宝端Input不受控

前情

最近又接手一个全新多端项目,包括抖音/快手/微信/支付宝,其中就有支付宝端,需要实现一个SKU选择,同时需要控制选择的商品数量,如下图:

坑位

既然是选择商品数量,那就不能让它出现小于等于0的数,我的想法是通过表单的input事件触发限制方法,限制它的值只允许在外面传进来的minmax之间的值,我这里设置的是199,也就是它的值只能为1~99

关键代码如下:

jsx 复制代码
<template>
    <input
      v-model="inputValue"
        controlled
      type="number"
      class="stepper-input"
      @input="handleInput"
    />
</template>

<script setup>
     // ...
    const inputValue = ref(1);
    // 处理输入框输入
    const handleInput = (e) => {
        const value = e.detail.value;
        // 其中props.min/max是从外面传进来的
        const value = Math.max(props.min, Math.min(props.max, newValue));
        inputValue.value = Number(value);
    };
    // ...
</script>

理想很丰满,现实很骨感,发现在支付宝表单可以输入任何数字,不受控制,但是我在handleInput里打印了日志,事件是有触发的

解决方案

给input加上controlled,让它变成受控组件,此时你修改inputValue的值是可以同步更新的

关键代码如下:

jsx 复制代码
<template>
    <input
      v-model="inputValue"
        controlled
      type="number"
      class="stepper-input"
      @input="handleInput"
    />
</template>

文挡说明如下,文挡地址:input 输入框 - 支付宝文档中心

总结

个人猜测支付宝小程序开发者应该是受React的影响,才会出现受控和非受控,因为这二个概念是React框架里的 对于这种一端可以另一端不行的问题,一般就是平台的差异兼容问题,可以去对应平台的官方文挡看一下,也许能找到端倪,当然直接搜索引擎搜索也是可以的,对于做技术的我们每天都是在踩坑的路上,但我真心希望所有人都一路生花,少踩坑,也坚信坑坑难爬,坑坑过

相关推荐
lbh35 分钟前
当我开始像写代码一样和AI对话,一切都变了
前端·openai·ai编程
We་ct1 小时前
LeetCode 918. 环形子数组的最大和:两种解法详解
前端·数据结构·算法·leetcode·typescript·动态规划·取反
wefly20172 小时前
m3u8live.cn 在线M3U8播放器,免安装高效验流排错
前端·后端·python·音视频·前端开发工具
C澒2 小时前
微前端容器标准化 —— 公共能力篇:通用打印
前端·架构
德育处主任Pro3 小时前
前端元素转图片,dom-to-image-more入门教程
前端·javascript·vue.js
木斯佳3 小时前
前端八股文面经大全:小红书前端一二面OC(下)·(2026-03-17)·面经深度解析
前端·vue3·proxy·八股·响应式
陈天伟教授3 小时前
人工智能应用- 预测新冠病毒传染性:04. 中国:强力措施遏制疫情
前端·人工智能·安全·xss·csrf
zayzy3 小时前
前端八股总结
开发语言·前端·javascript
今天减肥吗3 小时前
前端面试题
开发语言·前端·javascript
Rabbit_QL4 小时前
【前端UI行话】前端 UI 术语速查表
前端·ui·状态模式