【完整代码】uni-app原生picker实现地址选择器

Chrome运行效果如下:

QQ录屏20230505104210

父组件:

<template>
	<view>
		<address-picker @change="change">
			<view class="word">{
  {address}}</view>
			<view class="word" slot="province">{
  {list[0]==""?"未选择":list[0]}}</view>
			<view class="word" slot="city">{
  {list[1]==""?"未选择":list[1]}}</view>
			<view class="word" slot="area">{
  {list[2]==""?"未选择":list[2]}}</view>
		</address-picker>
	</view>
</template>

<script>
	import addressPicker from './components/addressPicker.vue'
	export default {
		components: {
			addressPicker
		},
		data() {
			return {
				address: "选择地址",
				list: ["", "", ""]
			}
		},
		onLoad() {

		},
		methods: {
			change(selectValue) {
				this.address = selectValue.join("")
				this.list = selectValue
			}
		}
	}
</script>

<style lang="scss" scoped>
	.word {
		width: 750rpx;
		height: 100rpx;
		display: flex;
		align-items: center;
		justify-content: center;
		font-weight: bold;
		font-size: 28rpx;
	}
</style>

子组件:

<template>
	<view>
		<picker @change="confirm" @columnchange="columnchange" :range="array" range-key="name" :value="value"
			mode="multiSelector">
			<slot></slot>
			<slot name="province"></slot>
			<slot name="city"></slot>
			<slot name="area"></slot>
		</picker>
	</view>
</template>

<script>
	import allAddress from '../js/address.js' //引入总数据库//
	export default {
		data() {
			return {
				array: [], //选择器的源数据//
				allarray: allAddress, //总数据库//
				value: [0, 0, 0], //索引值//
				selectValue: ["", "", ""] //选中的数据//
			}
		},
		created() {
			this.init()
		},
		methods: {
			//组件初始化//
			init() {
				this.updateArray()
					.updateSelectArray()
					.$forceUpdate() //强制刷新//
			},
			//更新源数据//
			updateArray() {
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
/** * 只显示省份一级 * provinceBlock : 回调省份 */ (instancetype)provincePickerViewWithProvinceBlock:(void(^)(NSString *province))provinceBlock; /** * 显示省份和市级 * cityBlock : 回调省份和城市 */ (instancetype)cityPickerViewWithCityBlock:(void(^)(NSString *province, NSString *city))cityBlock; /** * 显示省份和市级和区域 * areaBlock : 回调省份城市和区域 */ (instancetype)areaPickerViewWithAreaBlock:(void(^)(NSString *province, NSString *city, NSString *area))areaBlock; /** * 只显示省份一级 * province : 传入了省份自动滚动到省份,没有传或者找不到默认选中第一个 * provinceBlock : 回调省份 */ (instancetype)provincePickerViewWithProvince:(NSString *)province provinceBlock:(void(^)(NSString *province))provinceBlock; /** * 显示省份和市级 * province,city : 传入了省份和城市自动滚动到选中的,没有传或者找不到默认选中第一个 * cityBlock : 回调省份和城市 */ (instancetype)cityPickerViewWithProvince:(NSString *)province city:(NSString *)city cityBlock:(void(^)(NSString *province, NSString *city))cityBlock; /** * 显示省份和市级和区域 * province,city : 传入了省份和城市和区域自动滚动到选中的,没有传或者找不到默认选中第一个 * areaBlock : 回调省份城市和区域 */ (instancetype)areaPickerViewWithProvince:(NSString *)province city:(NSString *)city area:(NSString *)area areaBlock:(void(^)(NSString *province, NSString *city, NSString *area))areaBlock;

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值