IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> vue 文本输入自动计算求和实现 -> 正文阅读

[JavaScript知识库]vue 文本输入自动计算求和实现

写在前面

一般实现多个文本输入计算求和的方法是通过el-input 的change事件或者keyup.native 事件实现,

但是一般通过这两种方法实现计算求和,一般都需要点击页面某一处后,才会调用方法实现求和,实现不了实时自动求和

此时考虑使用 computed和watch;关于computed和watch 参考
https://cn.vuejs.org/v2/api/#computed
https://cn.vuejs.org/v2/api/#watch

代码实现示例?

使用computed和watch实现多数据求和示例

<template>
<div>
   <el-form :inline="true" :rules="rules" ref="ruleForm1" :model="formInline"	id="form_table" label-width="170px">
     <el-row type="flex" class="row-bg edit_form">
             <el-col :span="12">
				<el-form-item label="总支出:" >
					<el-input v-model="formInline.totalMoney"  disabled>
					</el-input>
				</el-form-item>
			</el-col>
		/el-row>
   </el-form>
</div>
<div style="float:right"><el-button type="primary" size="small" @click="addData()">添加</el-button></div>
  <div>
              <el-form :model="formInline" ref="outputForm">
                <el-table :data="formInline.monthData" border  :header-cell-style="headerStyle" :cell-style="headerCellStyle">
                  <el-table-column type="index" label="序号"  width="80"></el-table-column>
                  <el-table-column label="月份">
                    <template slot-scope="scope">
                      <el-form-item :prop="'dayPlanOutputs.'+scope.$index+'.month'" :rules="rules.month">
                         <el-date-picker   v-model="scope.row.month"	type="month" format="yyyy-MM"  value-format="yyyy-MM"  placeholder="选择月份"
                          style="width:95%">
                        </el-date-picker>                        
                      </el-form-item>
                    </template>
                  </el-table-column>
                    <el-table-column label="支出(元)" width="150">
                      <template slot-scope="scope">
                        <el-form-item :prop="'dayPlanOutputs.'+scope.$index+'.money'" :rules="rules.decimal">
                          <el-input  v-model="scope.row.money">
                          </el-input>
                        </el-form-item>
                    </template>
                    </el-table-column>
                    <el-table-column label="操作" width="80">
                      <template slot-scope="scope">
                        <el-button style="color: #6a9dca" icon="el-icon-delete" type="text" size="small" @click="delData(scope.$index)">
                          删除
                        </el-button>
                      </template>
                    </el-table-column>
                </el-table>
              </el-form>
            </div>
</template>
<script>
import Cookies from "js-cookie";
import moment from "moment";
export default {
  data() {
    return {
      reload: true,
      tabIndex: "0",
      contentStyleObj: {
        height: "670px",
      },
      rules: {
        month:[{
            required: true,
            message: "请选择月份",
            trigger: "change",
          }
        ],
        decimal: [
          {
            message: "只能为最多两位小数数字",
            trigger: "change",
            pattern: /(^$)|^[0-9]+(.?[0-9]{1,2})?$/,
          },
        ]
      },
      formInline: {
        totalMoney:0,
        monthData:[]
      }
    };
  },
  computed: {
    monthDatas() {
      return this.formInline.monthData;
    }
  },
   watch: {
    monthDatas: {
      deep: true,  // 深度监听
      handler(newVal,oldVal) {
         this.calculateSum();
      }
    }
  },
  mounted() {
  },
  methods: {
    //添加数据行
    addData(){
      var newTunnelRow={
        month:"",
        money:0
       };
      this.$forceUpdate(this.formInline.monthData.push(newTunnelRow));
    },
    //删除数据航
    delData(rowIndex){
      this.$forceUpdate(this.formInline.monthData.splice(rowIndex, 1));
    },
    //计算求和
    calculateSum(){
      let total=0;
      this.formInline.monthData.forEach((item)=>{
        let money=(item.money)&&!isNaN(item.money)?Number(item.money):0;
        total=total+money;
      });
      this.$set(this.formInline,"totalMoney",total);
    }
  }
};
</script>

  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2022-04-28 11:44:26  更:2022-04-28 11:46:29 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/11 4:03:25-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码