当前位置: 首页 > wzjs >正文

上海建设项目环保验收公示网站策划书模板

上海建设项目环保验收公示网站,策划书模板,做一个网站如何赚钱,自贡做响应式网站开发公司问题现象 &#x1f4a5; 在实现动态增减的单价输入表单时&#xff08;基于uv-form组件&#xff09;&#xff0c;遇到以下诡异现象&#xff1a; <uv-input>的v-model绑定初始值为数字类型时&#xff0c;required规则失效 ❌数字类型与字符串类型校验表现不一致 &#x1…

问题现象 💥

在实现动态增减的单价输入表单时(基于uv-form组件),遇到以下诡异现象:

  • <uv-input>的v-model绑定初始值为数字类型时,required规则失效 ❌
  • 数字类型与字符串类型校验表现不一致 🔢

技术栈背景 🛠️

  • 框架:Vue3 + uni-app
  • UI库:uv-ui
  • 校验方案:计算属性动态生成规则

示意图 🔍

在这里插入图片描述

解决方案 🚀

1.优先使用字符串类型做表单绑定
2.添加自定义校验规则(validator)解决初始值问题

<template><view class="form-box"><uv-form ref="refForm" :model="formvalue" labelWidth="100px" :rules="rules"><view class="form-list-item" v-for="(item, index) in formvalue.detailList" :key="index"><uv-form-item borderBottom label="单价" :prop="`detailList.${index}.amount`" required><uv-input inputAlign="right" type="digit" v-model="item.amount" placeholder="请输入单价" border="none"><template v-slot:suffix></template></uv-input></uv-form-item><view class="mt24" v-if="formvalue.detailList.length != 1"><uv-button plain text="移除"@click.stop="handleDel(index)" :customStyle="{ height: '60rpx' }"></uv-button></view></view></uv-form><view class="page-footer"><uv-button plain text="新增" @click.stop="handleAdd()"></uv-button><uv-button type="primary" shape="circle" text="提交" @click="onSubmit"></uv-button></view></view>
</template>
<script setup>
import { ref, reactive, computed } from 'vue';
import { onLoad } from '@dcloudio/uni-app';
import { deepClone, isEmpty } from '@/utils';
const refForm = ref(null);
const formvalue = reactive({detailList: [],
});
const billRules = computed(() => {let rules = {};formvalue.detailList.forEach((item, index) => {rules[`detailList.${index}.amount`] = [{required: true,message: '请输入有效的单价',trigger: ['blur', 'change'],validator: (rule, value) => {// 强制转换为字符串校验if (isEmpty(value?.toString())) return false; const numValue = Number(value);return !isNaN(numValue) && numValue > 0;}}];})return rules
});
const rules = computed(() => {return {...billRules.value}
});
const detailObj = {amount: 10,
}
const handleAdd = () => {formvalue.detailList.push(deepClone(detailObj))
}
const handleDel = (index) => {formvalue.detailList.splice(index, 1)
}
onLoad(async () => {handleAdd()
})
const onSubmit = async () => {refForm.value.validate().then(async () => {})
}   
</script>
<style lang="scss" scoped>
.form-box {margin-top: 180rpx;
}.page-footer {position: fixed;width: 100%;height: 120rpx;bottom: 0;background-color: #fff;padding: 65rpx 32rpx 80rpx 32rpx;display: flex;justify-content: space-between;align-items: center;.uv-button-box {flex: 1;margin: 0 12rpx;}
}
</style>
http://www.dtcms.com/wzjs/468122.html

相关文章:

  • 网站建设带后台云盘搜索
  • 做网上招聘哪个网站好网络营销师证
  • 游戏代理好做吗seo二级目录
  • 酒店网站建设 源码上海aso苹果关键词优化
  • 江苏建设管理信息网站广告推广怎么找客户
  • 北京装饰公司名录互联网关键词优化
  • tomcat做网站什么平台可以免费发广告
  • 福建两学一做网站株洲网页设计
  • 做网站(信科网络)百度搜索推广怎么做
  • 做中介开什么网站专注于品牌营销服务
  • 养老院微网站建设方案网站推广方案策划书2000
  • 做微信商城网站建设百度seo排名优化公司
  • 网站开发建设计入什么科目淘宝seo优化
  • 手机自适应网站建设维护市场推广渠道有哪些
  • 株洲网站建设技术公司百度链接提交收录入口
  • 洛阳微信平台网站建设seo博客教程
  • 济南做网站哪家好商业软文案例
  • dedecms网站安装网站运营指标
  • 遵义网站建设哪家强互联网营销模式有哪些
  • 网站建设有几块百度售后客服电话24小时
  • 免费的oa办公系统排名aso优化方案
  • 公司做免费网站培训心得简短50字
  • 项目招商网站大全西安seo关键词查询
  • 网站的分享按键搜索引擎优化的技巧
  • 万网网站建设教程新媒体运营主要做什么
  • 自己做网站前端开发外贸推广渠道有哪些
  • 郑州网站seo分析网络营销战略的内容
  • 个人或主题网站建设 实验体会苏州搜索引擎排名优化商家
  • 商丘做网站推广的公司网站改版公司哪家好
  • 网站改版做301重定向网络营销策划书范文模板