You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					
					
						
							398 lines
						
					
					
						
							10 KiB
						
					
					
				
			
		
		
		
			
			
			
				
					
				
				
					
				
			
		
		
	
	
							398 lines
						
					
					
						
							10 KiB
						
					
					
				| <template> | |
| 	<view class="bg"> | |
| 		<view class="list-forms"> | |
| 			<view class="list-item"> | |
| 				<view class="list-item-title">姓名</view> | |
| 				<view class="list-item-input"><input type="text" v-model="username" placeholder="请输入姓名" /></view> | |
| 			</view> | |
| 			<view class="list-item"> | |
| 				<view class="list-item-title">手机号</view> | |
| 				<view class="list-item-input"><input type="number" v-model="mobile" placeholder="请输入手机号" maxlength="11" | |
| 						 /></view> | |
| 			</view> | |
| 			<view class="list-item" style="position: relative;"> | |
| 				<view class="list-item-title">选择地区</view> | |
| 				<view class="list-item-input3" style="flex: 1;"> | |
| 					<picker mode="multiSelector" :range="newProvinceDataList" range-key="name" @change="changeArea" @columnchange="pickerColumnchange" | |
| 					style="position: relative;z-index: 2;"> | |
| 						<input type="text" readonly style="font-size: 35rpx;position: relative;z-index: -1;" | |
| 								v-model="citySeld" disabled="true" placeholder="请选择地区"/> | |
| 					</picker> | |
| 				</view> | |
| 			</view> | |
| 			<view class="list-item"> | |
| 				<view class="list-item-title">详细地址</view> | |
| 				<view class="list-item-input"><input type="text" v-model="detailAddr" placeholder="请输入详细地址" /></view> | |
| 			</view> | |
| 			<view class="list-item" style="border-bottom: 0;"> | |
| 				<view class="list-item-title">设为默认</view> | |
| 				<view class="list-item-switch"> | |
| 					<switch :checked="idDefault" @change="switchChange" color="#74A5AA"/> | |
| 				</view> | |
| 			</view> | |
| 			<!-- <view class="list-item-btn"> | |
| 				<view class="list-item-post" @click="postSave()">保存</view> | |
| 			</view> --> | |
| 		</view> | |
| 	</view> | |
| </template> | |
| 
 | |
| <script> | |
| 	import District from 'ydui-district/dist/jd_province_city_area_id'; | |
| 	export default { | |
| 		data() { | |
| 			return { | |
| 				username: '', | |
| 				mobile: '', | |
| 				citySeld: '', | |
| 				detailAddr: '', | |
| 				idDefault: false, | |
| 				title: '新增收货地址', | |
| 				show: false, | |
| 				district: District, //数据 | |
| 				ready: false, | |
| 				province: null, | |
| 				city: null, | |
| 				area: '', | |
| 				provinceId: null, | |
| 				cityId: null, | |
| 				areaId: null, | |
| 				columns: [], | |
| 				id: '', | |
| 				newProvinceDataList:[ | |
| 					[],[],[] | |
| 				], | |
| 				multiIndex: [0, 0, 0], | |
| 			} | |
| 		}, | |
| 		onLoad(option){ | |
| 			 | |
| 		}, | |
| 		methods: { | |
| 			init(option) { | |
| 				this.id = null | |
| 				this.username = '' | |
| 				this.mobile = '' | |
| 				this.citySeld = '' | |
| 				this.detailAddr = '' | |
| 				this.idDefault = false | |
| 				this.province = null | |
| 				this.city = null | |
| 				this.area = '' | |
| 				this.provinceId = null | |
| 				this.cityId = null | |
| 				this.areaId = null | |
| 				this.multiIndex = [0, 0, 0] | |
| 				this.id = option.id | |
| 				 | |
| 				 | |
| 				if (option.id > 0) { | |
| 				  this.title = '编辑收货地址' | |
| 				  this.getDetail() | |
| 				} | |
| 				else { | |
| 				  this.getSeldCityList() | |
| 				} | |
| 			}, | |
| 			 | |
| 			switchChange(e){ | |
| 				this.idDefault = e.detail.value | |
| 			}, | |
| 			changeArea(e){ | |
| 				// 数组内的下标 | |
| 				this.multiIndex = e.detail.value; | |
| 				this.citySeld = this.newProvinceDataList[0][this.multiIndex[0]].name + this.newProvinceDataList[1][this.multiIndex[1]].name + this.newProvinceDataList[2][this.multiIndex[2]].name | |
| 				this.provinceId = this.newProvinceDataList[0][this.multiIndex[0]].id | |
| 				this.cityId = this.newProvinceDataList[1][this.multiIndex[1]].id | |
| 				this.areaId = this.newProvinceDataList[2][this.multiIndex[2]].id | |
| 			}, | |
| 			getSeldCityList() { | |
| 				if (this.columns.length>0) { | |
| 					return | |
| 				} | |
| 				 | |
| 				let that = this | |
| 				that.Post({}, '/api/areas/getAll').then(res => { | |
| 					if (res.code === 200) { | |
| 						var data = res.data; | |
| 						var result = {}; | |
| 						for (var i = 0; i < data.length; i++) { | |
| 							var item = data[i]; | |
| 							if (item.parent_id == 0) { | |
| 								continue; | |
| 							} | |
| 							//获取省 | |
| 							if (item.parent_id == "1") { | |
| 								result[item.id.toString()] = {}; | |
| 								result[item.id.toString()].children = [] | |
| 								result[item.id.toString()].name = item.name; | |
| 								result[item.id.toString()].id = item.id; | |
| 							} else if (result[item.parent_id.toString()]) { | |
| 								//填充市 | |
| 								var t = { | |
| 									id: item.id, | |
| 									name: item.name, | |
| 									children: [] | |
| 								} | |
| 								result[item.parent_id.toString()].children.push(t) | |
| 							} else { | |
| 								//填充区 | |
| 								var k = { | |
| 									id: item.id, | |
| 									name: item.name | |
| 								} | |
| 								for (var j = 0; j < result[item.parent_id.toString().substr(0, 2) + "0000"].children | |
| 									.length; j++) { | |
| 									if (result[item.parent_id.toString().substr(0, 2) + "0000"].children[j].id == item | |
| 										.parent_id) { | |
| 										result[item.parent_id.toString().substr(0, 2) + "0000"].children[j].children.push(k) | |
| 									} | |
| 								} | |
| 							} | |
| 						} | |
| 						var r = []; | |
| 						//将Object转为Array | |
| 						for (var i in result) { | |
| 							r.push(result[i]); | |
| 						} | |
| 						//将数据赋值给省市区联动选择器 | |
| 						that.district = r; | |
| 						let arr = [] | |
| 						let	arr1 = [] | |
| 						let arr2 = [] | |
| 						that.district.forEach(item => { | |
| 							arr.push(item) | |
| 						}) | |
| 						that.district[0].children.forEach(item => { | |
| 							arr1.push(item) | |
| 						}) | |
| 						that.district[0].children[0].children.forEach(item => { | |
| 							arr2.push(item) | |
| 						}) | |
| 						that.columns = arr | |
| 						//控制异步数据 | |
| 						that.ready = true; | |
| 						console.log(this.columns) | |
| 						for(let i=0; i<this.columns.length; i++){ | |
| 							this.newProvinceDataList[0].push({name:this.columns[i].name,id:this.columns[i].id}); | |
| 						} | |
| 						console.log(this.columns[0].children) | |
| 						for(let i=0; i<this.columns[0].children.length; i++){ | |
| 							this.newProvinceDataList[1].push({name:this.columns[0].children[i].name,id:this.columns[0].children[i].id}); | |
| 						} | |
| 						for(let i=0; i<this.columns[0].children[0].children.length; i++){ | |
| 							this.newProvinceDataList[2].push({name:this.columns[0].children[0].children[i].name,id:this.columns[0].children[0].children[i].id}); | |
| 						} | |
| 					} | |
| 				}) | |
| 			}, | |
| 			// 滑动 | |
| 			pickerColumnchange(e){ | |
| 				// 第几列滑动 | |
| 				// console.log(e.detail.column); | |
| 				// 第几列滑动的下标 | |
| 				// console.log(e.detail.value) | |
| 				// 第一列滑动 | |
| 				if(e.detail.column === 0){ | |
| 					this.multiIndex[0] =  e.detail.value | |
| 					// console.log('第一列滑动'); | |
| 					// this.newProvinceDataList[1] = []; | |
| 					this.newProvinceDataList[1] = this.columns[this.multiIndex[0]].children.map((item,index)=>{ | |
| 						// console.log(item) | |
| 						return item | |
| 					}) | |
| 					// console.log(this.multiIndex) | |
| 					if(this.columns[this.multiIndex[0]].children.length === 1){ | |
| 						this.newProvinceDataList[2] = this.columns[this.multiIndex[0]].children[0].children.map((item,index)=>{ | |
| 							// console.log(item) | |
| 							return item | |
| 						}) | |
| 					}else{ | |
| 						this.newProvinceDataList[2] = this.columns[this.multiIndex[0]].children[this.multiIndex[1]].children.map((item,index)=>{ | |
| 							// console.log(item) | |
| 							return item | |
| 						}) | |
| 					} | |
| 					// 第一列滑动  第二列 和第三列 都变为第一个 | |
| 					this.multiIndex.splice(1, 1, 0) | |
| 					this.multiIndex.splice(2, 1, 0) | |
| 				} | |
| 				// 第二列滑动 | |
| 				if(e.detail.column === 1){ | |
| 					this.multiIndex[1] =  e.detail.value | |
| 					// console.log('第二列滑动'); | |
| 					// console.log(this.multiIndex) | |
| 					this.newProvinceDataList[2] = this.columns[this.multiIndex[0]].children[this.multiIndex[1]].children.map((item,index)=>{ | |
| 						// console.log(item) | |
| 						return item | |
| 					}) | |
| 					// 第二列 滑动 第三列 变成第一个 | |
| 					this.multiIndex.splice(2, 1, 0) | |
| 				} | |
| 				// 第三列滑动 | |
| 				if(e.detail.column === 2){ | |
| 					this.multiIndex[2] =  e.detail.value | |
| 					// console.log('第三列滑动') | |
| 					// console.log(this.multiIndex) | |
| 				} | |
| 			}, | |
| 			getDetail() { | |
| 				this.Post({ | |
| 					id: this.id | |
| 				}, "/api/user/contactDetail").then(res => { | |
| 					res = res.data; | |
| 					if (res && res.id > 0) { | |
| 						this.username = res.name | |
| 						this.mobile = res.tel | |
| 						this.idDefault = res.is_default == 1 ? true : false | |
| 						this.provinceId = res.province_id | |
| 						this.cityId = res.city_id | |
| 						this.areaId = res.district_id | |
| 						this.citySeld = res.province_text + '' + res.city_text + '' + res.district_text | |
| 						this.detailAddr = res.detail_addr; | |
| 						this.getSeldCityList(); | |
| 					} | |
| 				}) | |
| 			}, | |
| 			async postSave() { | |
| 				this.username = this.username.trim() | |
| 				this.mobile = this.mobile.trim() | |
| 				this.detailAddr = this.detailAddr.trim() | |
| 				if (this.username.length < 1) { | |
| 					uni.showToast({ | |
| 						title: '请输入姓名', | |
| 						icon: 'none' | |
| 					}) | |
| 					return | |
| 				} | |
| 				if (this.username.length > 6) { | |
| 					uni.showToast({ | |
| 						title: '姓名最多6个字', | |
| 						icon: 'none' | |
| 					}) | |
| 					return | |
| 				} | |
| 				if (!this.IsTel(this.mobile)) { | |
| 					uni.showToast({ | |
| 						title: '请输入正确的手机号', | |
| 						icon: 'none' | |
| 					}) | |
| 					return | |
| 				} | |
| 				if (this.citySeld.length < 1) { | |
| 					uni.showToast({ | |
| 						title: '请选择地区', | |
| 						icon: 'none' | |
| 					}) | |
| 					return | |
| 				} | |
| 				if (this.detailAddr.length < 2) { | |
| 					uni.showToast({ | |
| 						title: '请输入具体地址', | |
| 						icon: 'none' | |
| 					}) | |
| 					return | |
| 				} | |
| 				let res = await this.Post({ | |
| 					name: this.username, | |
| 					tel: this.mobile, | |
| 					is_default: this.idDefault ? '1' : '0', | |
| 					province_id: this.provinceId, | |
| 					city_id: this.cityId, | |
| 					district_id: this.areaId, | |
| 					detail_addr: this.detailAddr, | |
| 					id: this.id || null | |
| 				},'/api/user/' + (this.id > 0 ? 'edit' : 'add') + 'Consignee') | |
| 				 | |
| 				if(res.code == '1'){ | |
| 					// uni.setStorageSync('addressNow',JSON.stringify(res.data)) | |
| 					uni.showModal({ | |
| 						title: '提示', | |
| 						content: this.id>0?'编辑成功':'添加成功', | |
| 						showCancel: false, | |
| 					}) | |
| 				}else{ | |
| 					uni.showModal({ | |
| 						title: '提示', | |
| 						content: res.msg, | |
| 						showCancel: false, | |
| 					}) | |
| 				} | |
| 				 | |
| 				return {...res,data: {id: this.id}} | |
| 			} | |
| 		} | |
| 	} | |
| </script> | |
| 
 | |
| <style scoped> | |
| 	.bg { | |
| 		width: 100%; | |
| 		height: 100%; | |
| 	} | |
| 
 | |
| 	.list-forms { | |
| 		display: flex; | |
| 		flex-direction: column; | |
| 		box-sizing: content-box | |
| 	} | |
| 
 | |
| 	.list-item { | |
| 		display: flex; | |
| 		border-bottom: 1rpx solid #D8D8D8; | |
| 		padding: 30rpx 0; | |
| 		height: 60rpx; | |
| 		align-items: center; | |
| 		box-sizing: content-box | |
| 	} | |
| 
 | |
| 	.list-item-title { | |
| 		width: 150rpx; | |
| 		font-size: 31rpx; | |
| 		margin-right: 20rpx; | |
| 	} | |
| 
 | |
| 	.list-item-input { | |
| 		flex: 1; | |
| 	} | |
| 
 | |
| 	.list-item-input input { | |
| 		width: 100%; | |
| 		height: 100%; | |
| 		padding: 0; | |
| 		margin: 0; | |
| 		border: 0; | |
| 		background-color: transparent; | |
| 		line-height: 31rpx; | |
| 		font-size: 31rpx; | |
| 	} | |
| 
 | |
| 	.list-item-input input::placeholder { | |
| 		font-size: 26rpx; | |
| 	} | |
| 
 | |
| 	.list-item-switch { | |
| 		display: flex; | |
| 		flex: 1; | |
| 		justify-content: flex-end; | |
| 	} | |
| 
 | |
| 	.list-item-btn { | |
| 		display: flex; | |
| 		justify-content: center; | |
| 		margin-top: 20rpx; | |
| 	} | |
| 
 | |
| 	.list-item-post { | |
| 		display: flex; | |
| 		color: #FFFFFF; | |
| 		font-size: 36rpx; | |
| 		width: 697rpx; | |
| 		height: 73rpx; | |
| 		background: linear-gradient(90deg, #F84A56, #FF9834); | |
| 		border-radius: 37rpx; | |
| 		justify-content: center; | |
| 		align-items: center; | |
| 		margin-top: 725rpx; | |
| 	} | |
| </style>
 | |
| 
 |