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

新增一个数组传递给后端

实现的效果:
在这里插入图片描述
页面

<div style="margin-bottom: 10px" v-if="totalPrice">
           <p style="font-weight: bolder;margin-bottom: 10px">
             支付计划
             <el-button type="text" size="small" @click="addPayInfo" icon="el-icon-plus">添加</el-button>
           </p>
           <ul v-for="(p,i) of payList" :key="i" class="pay-info">
            <li>
              <span>{{i+1}}笔支付金额:</span>
              <el-input v-model="p.price"
                        @input="handleInput($event,i,'pay');onCalculate(p,i,createParams.commodityList[0].price)"
                        :disabled="!mark && p.is_amend"
                        style="width: 200px;margin-right: 10px" size="small"></el-input>
            </li>
             <li>
               <el-switch
                 style="display: block"
                 v-model="p.is_pay"
                 :disabled="!mark && p.is_amend"
                 active-color="#13ce66"
                 inactive-color="#ff4949"
                 active-text="已支付"
                 inactive-text="未支付">
               </el-switch>
             </li>
             <li>
               <span style="vertical-align: top">备注:</span>
               <el-input type="textarea" v-model="p.desc" :disabled="!mark && p.is_amend" style="width: 200px;margin-right: 10px" size="small"></el-input>
             </li>
             <li>
               <el-button type="danger" size="mini" @click="deletePayInfo(i)" :disabled="!mark && p.is_amend" v-if="payList.length>1">删除</el-button>
             </li>
           </ul>
           <div>
             <span>需支付总价:{{totalPrice}}</span>
             <span style="margin-left: 20px;color:#67C23A ">已计划支付总价:{{payTotal}}</span>
             <span style="margin-left: 20px;color:#F56C6C " >未计划支付总价:
               <span style="color: #409EFF;cursor: pointer" @click="showUnPayTotal(unPayTotal)">{{unPayTotal}}</span></span>
           </div>
         </div>
data:{
  totalPrice : 300 //总金额
  payList : [
     {
          price: '',
          desc:'',
          is_pay: false
      }
       ] //传递给后端的数组
}

数组内增加数据

addPayInfo(){
      this.payList.push({
        price: '',
        desc:'',
        is_pay: false
      })
    },

数组内删除数据

deletePayInfo(i){
      this.payList.splice(i,1)
      let sum = this.payList.reduce(function(acc, obj) {
        return acc + Number(obj.price);
      }, 0);
      this.payTotal = sum>Number(totalPrice)?0:sum
      this.unPayTotal = Number(totalPrice) - this.payTotal
    },

剩余金额点击后直接赋值到未输入金额的输入框内

  showUnPayTotal(val){
      console.log(val)
      if(val>0 && this.payList.find(item=>item.price==='')){
        this.payList.find(item=>item.price==='').price = val
        this.unPayTotal = 0
      }
    },

输入框值改变后执行

    handleInput(val,index,type){
      let dat = ("" + val) // 第一步:转成字符串
          .replace(/[^\d^\.]+/g, "") // 第二步:把不是数字,不是小数点的过滤掉
          .replace(/^0+(\d)/, "$1") // 第三步:第一位0开头,0后面为数字,则过滤掉,取后面的数字
          .replace(/^\./, "0.") // 第四步:如果输入的第一位为小数点,则替换成 0. 实现自动补全
          .match(/^\d*(\.?\d{0,2})/g)[0] || "";
      if(type==='commodity'){
        this.totalPrice = dat
        this.unPayTotal = Number(dat) - this.payTotal
      }else if(type==='pay'){
        this.payList[index].price = dat
      }
    },

http://www.kler.cn/a/292276.html

相关文章:

  • 大数据新视界 -- 大数据大厂之 Impala 性能优化:基于数据特征的存储格式选择(上)(19/30)
  • 数据结构—栈和队列
  • 【Python进阶】Python中的数据库交互:使用SQLite进行本地数据存储
  • Kotlin中泛型的协变
  • 安全,服务器证书和SSL连接
  • layui的table组件中,对某一列的文字设置颜色为浅蓝怎么设置
  • C++基础知识(五)
  • 计算机网络(三) —— 简单Udp网络程序
  • 2024年西安交通大学软件工程专业考研915真题
  • 算法练习题14——leetcode84柱形图中最大的矩形(单调栈)
  • 深度解析Linux系统的基本概念及优缺点和原理
  • COD论文笔记 ECCV2024 Just a Hint: Point-Supervised Camouflaged Object Detection
  • 解决maven中阿里云镜像仓库无法下载源码的问题
  • 华为od统一考试B卷【密钥格式化】Java 实现
  • python多进程
  • 导入word模板的数据到DB,偏自学,可自改套用
  • eureka一
  • 如何给 Java 文件打成独立的 JAR 包
  • 最基本的SELECT...FROM结构
  • HTB-Funnel(ssh端口转发与Hydra爆破)
  • blast的快速安装使用-简易版
  • Python知识点:如何使用Slack与Python进行团队协作
  • C++的四种规范的类型转换
  • 广义回归神经网络(GRNN)
  • Facebook的AI进化:如何用智能技术提升内容推荐
  • DataAccessException产生原因及解决方案