::: tip 组件名:uni-data-picker > 代码块: `uDataPicker` > 关联组件:`uni-data-pickerview`、`uni-load-more`。 [点击下载&安装](https://ext.dcloud.net.cn/plugin?name=uni-data-picker) ::: `` 是一个选择类[datacom组件](https://uniapp.dcloud.net.cn/component/datacom)。 支持单列、和多列级联选择。列数没有限制,如果屏幕显示不全,顶部tab区域会左右滚动。 候选数据支持一次性加载完毕,也支持懒加载,比如示例图中,选择了“北京”后,动态加载北京的区县数据。 `` 组件尤其适用于地址选择、分类选择等选择类。 `` 支持本地数据、云端静态数据(json),uniCloud云数据库数据。 `` 可以通过JQL直连uniCloud云数据库,配套[DB Schema](https://doc.dcloud.net.cn/uniCloud/schema),可在schema2code中自动生成前端页面,还支持服务器端校验。 在uniCloud数据表中新建表“uni-id-address”和“opendb-city-china”,这2个表的schema自带foreignKey关联。在“uni-id-address”表的表结构页面使用schema2code生成前端页面,会自动生成地址管理的维护页面,自动从“opendb-city-china”表包含的中国所有省市区信息里选择地址。 ## 介绍 ::: warning 注意事项 > 为了避免错误使用,给大家带来不好的开发体验,请在使用组件前仔细阅读下面的注意事项,可以帮你避免一些错误。 - 组件需要依赖 `sass` 插件 ,请自行手动安装 - `` 内部包含了弹出层组件 `` 外层的布局可能会影响弹出层,[详情](https://developer.mozilla.org/zh-CN/docs/Web/CSS/Common_CSS_Questions) - 云端数据需要关联服务空间 - 下面示例中使用的表 `opendb-city-china`(中国城市省市区数据,含港澳台), 在[uniCloud控制台](https://unicloud.dcloud.net.cn/)使用opendb创建,[详情](https://gitee.com/dcloud/opendb) ::: ### 云端数据 ```vue ``` ### 本地数据 ```vue ``` ### 自定义 Solt ```html {{error}} {{item.text}} 请选择 ``` > **注意事项** > `localdata` 和 `collection` 同时配置时,`localdata` 优先 ## API ### DataPicker Props |属性名| 类型|可选值|默认值| 说明| |:-:| :-:|:-:| :-:| :-: | |v-model|String/ Number | -|-|绑定数据| |spaceInfo|Object|-|-|服务空间配置,[详情](https://doc.dcloud.net.cn/uniCloud/init)| |localdata|Array|-|-|数据,[详情](https://gitee.com/dcloud/datacom)| |preload|Boolean| true/false |false|预加载数据| |readonly|Boolean| true/false | false|是否禁用| |clear-icon|Boolean| true/false |true|是否显示清除按钮| |ellipsis|Boolean| true/false | true|是否隐藏 tab 标签过长的文本| |step-searh|Boolean| true/false |true|分步查询时,点击节点请求数据| |step-search-url|String|-|-|分步查询时,动态加载云端数据url格式,`https://xxx.com/{parentValue}`(当前版本暂不支持,下版支持)| |self-field|String|-|-|分步查询时当前字段名称| |parent-field|String|-|-|分步查询时父字段名称| |collection|String|-|-|表名。支持输入多个表名,用 `,` 分割| |field|String|-|-|查询字段,多个字段用 `,` 分割| |where|String|-|-|查询条件,内容较多,另见jql文档:[详情](https://doc.dcloud.net.cn/uniCloud/uni-clientDB?id=jsquery)| |orderby|String|-|-|排序字段及正序倒叙设置| |popup-title|String|||弹出层标题| |map|Object|-|{text:'text',value:'value'}|字段映射,将text/value映射到数据中的其他字段| ::: warning 注意 `collection/where/orderby` 和 `` 的用法一致,[详情](https://doc.dcloud.net.cn/uniCloud/unicloud-db) ::: ### DataPicker Events |事件称名| 类型| 说明| |:-:| :-:| :-:| |@change|EventHandle|选择完成时触发 {detail: {value}}| |@nodeclick|EventHandle| 节点被点击时触发| |@stepsearch|EventHandle| 动态加载节点数据前触发(当前版本暂不支持,下版支持) | |@popupopened|EventHandle| 弹出层弹出时触发| |@popupclosed|EventHandle| 弹出层关闭时触发| ### DataPicker Methods |方法称名 |说明|参数| |:-:|:-:|:-:| |show|打开弹出层|-| |hide|关闭弹出层|-| |clear|清除已选项|-| **使用方法:** ```js this.$refs.picker.show() // `picker` 为组件的 ref 名称 ``` ### DataPicker Slots |名称|说明| |:-:|:-:| |default|覆盖显示框内容| ## 示例 ::: warning 注意 示例依赖了 `uni-card` `uni-section` `uni-scss` 等多个组件,直接拷贝示例代码将无法正常运行 。 请到 [组件下载页面](https://ext.dcloud.net.cn/plugin?name=uni-data-picker) ,在页面右侧选择 `使用 HBuilderX导入示例项目` ,体验完整组件示例。 ::: ::: preview https://hellouniapp.dcloud.net.cn/pages/extUI/data-picker/data-picker > Template ``` vue ``` > Script ``` vue ``` > Style ``` vue ``` ::: [完整示例演示](https://hellouniapp.dcloud.net.cn/pages/extUI/data-picker/data-picker)