vue3输入单号和张数如何自动生成连号的单号

 更新时间:2024年02月29日 10:49:32   作者:小端-吃瓜  
最近遇到这样的需求输入连号事件,需要在表格中输入物流单号,物流号码,生成的数量,名称,点击确定自动生成固定数量的连号物流单号,本文重点介绍vue3输入单号和张数,自动生成连号的单号,感兴趣的朋友一起看看吧

需求: 输入连号事件,需要在表格中输入物流单号,物流号码,生成的数量,名称,点击确定自动生成固定数量的连号物流单号

1.页面布局

<div><el-button type="primary" size="default" @click="handleDialog">输入连号</el-button></div>
	<br/><br/>
	<el-table
	  :data="tableData"
	  style="width: 80vw; margin-bottom: 20px"
	  border
	>
		<el-table-column prop="code" label="快递代码" width="200"></el-table-column>
		<el-table-column prop="no" label="快递单号"></el-table-column>
		<el-table-column prop="name" label="名称"></el-table-column>
		<!-- <el-table-column prop="optes" label="操作"></el-table-column> -->
	</el-table>

弹出层代码:

<el-dialog v-model="showDialog">
		<el-table
		  :data="tableDataDialog"
		  style="width: 80vw; margin-bottom: 20px"
		  border
		>
			<el-table-column prop="code" label="快递代码" width="200">
				<template #default="{row}">
					<el-input v-model="row.code" maxlength="10">
					</el-input>
				</template>
			</el-table-column>
			<el-table-column prop="no" label="快递单号">
				<template #default="{row}">
					<el-input v-model="row.no" maxlength="8">
					</el-input>
				</template>
			</el-table-column>
			<el-table-column prop="name" label="名称">
				<template #default="{row}">
					<el-input v-model="row.name">
					</el-input>
				</template>
			</el-table-column>
			<el-table-column prop="num" label="张数">
				<template #default="{row}">
					<el-input v-model="row.num" minlength="1">
					</el-input>
				</template>
			</el-table-column>
		</el-table>
		<el-button type="info" size="default" @click="save">确定</el-button>
	</el-dialog>

定义变量:

const tableData = reactive([])//生成之后的table表格
const tableDataDialog = ref([])//弹出层的表格
const showDialog = ref(false)//控制弹出层显隐

点击输入连号自动先插入一条空数据,用于输入相应地内容

const handleDialog = ()=>{
	showDialog.value = true
	let obj = {
		code: '',
		no: '',
		name: '',
		num: ''
	}
	tableDataDialog.value.push(obj)
}

点击保存时,将弹出层输入的单号,号码,和数量进行数据组装,然后放入到tableData中,关闭弹出层

const save = ()=>{
		let length = tableDataDialog.value.length
		let size = new Set(tableDataDialog.value.map(item=>item.code)).size
		if(size !== length){
			ElMessage('物流号码不能重复')
			return
		}
		let obj = {}
		let len = tableDataDialog.value[0].code.toString().length
	tableData.value = []
	tableDataDialog.value.forEach((item)=>{
		for(var i=0;i<item.num;i++){
			obj = {
				code: item.code,
				no: item.no,
				name: item.name
			}
			item.no++
			item.no = item.no.toString()
			for(var j=0;j<len;j++){
				let noLen = item.no.toString().length
				if(noLen < len){
					item.no = '0' + item.no//如果输入的为带00xx前缀的号码,自动生成要做补0操作,不然会把0自动去掉
					noLen++
				}
			}
			tableData.push(obj)
			showDialog.value = false
		}
	})
}

到此这篇关于vue3输入单号和张数,自动生成连号的单号的文章就介绍到这了,更多相关vue自动生成连号的单号内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Vue项目中ESLint配置超全指南(VScode)

    Vue项目中ESLint配置超全指南(VScode)

    ESLint是一个代码检查工具,用来检查你的代码是否符合指定的规范,下面这篇文章主要给大家介绍了关于Vue项目中ESLint配置(VScode)的相关资料,文中通过实例代码介绍的非常详细,需要的朋友可以参考下
    2023-04-04
  • vue项目打包后请求地址错误/打包后跨域操作

    vue项目打包后请求地址错误/打包后跨域操作

    这篇文章主要介绍了vue项目打包后请求地址错误/打包后跨域操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-11-11
  • 详解vue的双向绑定原理及实现

    详解vue的双向绑定原理及实现

    这篇文章主要介绍了vue双向绑定原理及实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-05-05
  • vue 内联样式style中的background用法说明

    vue 内联样式style中的background用法说明

    这篇文章主要介绍了vue 内联样式style中的background用法说明,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-08-08
  • vue请求后端数据和跨域问题解决

    vue请求后端数据和跨域问题解决

    这篇文章主要介绍了vue请求后端数据和跨域问题,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2023-05-05
  • vue中给el-radio添加tooltip并实现点击跳转方式

    vue中给el-radio添加tooltip并实现点击跳转方式

    这篇文章主要介绍了vue中给el-radio添加tooltip并实现点击跳转方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-04-04
  • elementui弹窗页按钮重复提交问题解决方法

    elementui弹窗页按钮重复提交问题解决方法

    本文主要介绍了elementui弹窗页按钮重复提交问题解决方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-08-08
  • 在vue中使用Echarts利用watch做动态数据渲染操作

    在vue中使用Echarts利用watch做动态数据渲染操作

    这篇文章主要介绍了在vue中使用Echarts利用watch做动态数据渲染操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-07-07
  • Vue3中引入SCSS和LESS依赖的基本步骤和注意事项

    Vue3中引入SCSS和LESS依赖的基本步骤和注意事项

    我们项目开发中经常遇到样式里面会使用less和scss写法, less,scss和stylus都是css的预处理器,这篇文章主要给大家介绍了关于Vue3中引入SCSS和LESS依赖的基本步骤和注意事项,需要的朋友可以参考下
    2024-05-05
  • Vue重要修饰符.sync对比v-model的区别及使用详解

    Vue重要修饰符.sync对比v-model的区别及使用详解

    这篇文章主要为大家介绍了Vue中重要修饰符.sync与v-model的区别对比及使用详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-07-07

最新评论