vue--阶梯区间数据的监听--头尾数据实时同步

很早之前码的一个代码–记录一下。做阶梯区间的一个功能,发现做好容易,要增加客户的体验感有点不容易,前后上下input数据不能不一致。不能断层填写。截图说明:
在这里插入图片描述
如上图所示,比如两个2的input。我填写了上面的,那么下方的input就要同步改变,数据不同步改变就会导致区间不能连贯的闭合起来。这里用了input的实时触发事件,然后改变上(下)一层的数据(看思路就好,具体的数据不要深究):

//触发input事件---修改上一级的upStairs值
changeinputdown(event,index){
	this.frParts[index-1].upStairs = this.frParts[index].downStairs;
},
//触发input事件---修改下一级的downStairs值
changeinputup(event,index){
	if(this.frParts.length>1){
		this.frParts[index+1].downStairs = this.frParts[index].upStairs;
	}
},

上方的代码会实现区间的同步(上一层后input和下一层前input或者反之)。还有情况就是区间不正规,如下
在这里插入图片描述
这里使用watch监听同一层前后两个数据的大小即可。

frParts:{
	deep:true,
		handler:function (res){
			if(res.length !== 1){
				let num = 0;//记录frParts中的数据是否有不合理的
				res.forEach((item,index)=>{
					let {downStairs,upStairs} =item;
					//downStairs大于等于upStairs就是不合理的数据
					if(Number(downStairs) > Number(upStairs) ||Number(downStairs) === Number(upStairs)){
						num++;
					}
					if(num !== 0){
						this.isguifan = true;
					}else{
						this.isguifan = false;
					}
				})
			}
		}
	}

还有阶梯的添加一层–删除一层也要细细琢磨情况,阶梯的渲染根据数组中的对象进行v-for即可,上述代码中的frParts为渲染的数据,添加阶梯也要监听数组中的数据是否有空值,防止提交数据时为空。
附上frParts的初始代码

frParts: [{downStairs: "0", upStairs: '', rate: '', default: true}],  //阶梯分润数组

思路仅供参考,具体的实现还要根据实际情况来操作。

如对您有所帮助,点个赞再走吧~qaq

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

吴大大逛博客

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值