更新记录
v1.0.2(2022-03-08) 下载此版本
修改了二次点击某一类不滚动的问题
v1.0.1(2022-03-05) 下载此版本
修改了同步数据时,弹框不显示的问题
v1.0.0(2022-03-05) 下载此版本
新添加
查看更多平台兼容性
Vue2 | Vue3 |
---|---|
√ | √ |
App | 快应用 | 微信小程序 | 支付宝小程序 | 百度小程序 | 字节小程序 | QQ小程序 |
---|---|---|---|---|---|---|
× | × | √ | × | × | × | × |
钉钉小程序 | 快手小程序 | 飞书小程序 | 京东小程序 |
---|---|---|---|
× | × | × | × |
H5-Safari | Android Browser | 微信浏览器(Android) | QQ浏览器(Android) | Chrome | IE | Edge | Firefox | PC-Safari |
---|---|---|---|---|---|---|---|---|
√ | √ | √ | √ | √ | √ | √ | √ | √ |
基于 uni-popup的双联动组件
组件名:uni-popup-linkage
关联组件:
uni-popup
、uni-transition
代码块:
uiPopupLinkage
基于uni-popup的双联动tab弹框,实现了双向联动、可自动滚动至所选项,支持用户自定义传入数据的keyname,H5端做了去滚动条处理, 组件实现简单
注意:本组件基于 uni-popup、uni-transition实现弹框与滚动效果,使用前请先确保这两个组件已下载,否则无法执行
基本用法
示例
<ui-popup-linkage :propsData="propsData" @result="getResult"></ui-popup-linkage>
export default {
data() {
return {
// 源数据,必传
propsData: [
{
"id":78,
"name":"管理岗",
"sub":[
{ "id":80, "name":"总经理" },
{"id":81,"name":"总裁" }
]
},
{
"id":75,
"name":"其他",
"sub":[
{"id":76,"name":"其他"}
]
}
],
resultData: {}
},
methods:{
// 获取返回的数据
getResult(data){
console.log('get result from component:', data)
this.resultData = data
}
}
}
自定义触发器以及数据格式
示例
<ui-popup-linkage :propsData="propsData" :initData="initData" :objType="objType" navHeight="400" @result="getResult">
<view class="result-box">
<text class="placeHolder" v-if="!(initData.subItem && initData.subItem.value)">请选择</text>
<text v-else>{{ initData.item.value + '-' + initData.subItem.value }}</text>
</view>
</ui-popup-linkage>
export default {
data() {
return {
// 初始化数据,若不需要初始化,则该参数可以不传
initData: {
item: {
code: '78',
value: '管理岗'
},
subItem: {
code: '81',
value: '总裁'
}
},
/* 定义数据格式,要求大类数据与子类数据中对应的keyname相同(比如都为id、name或者都为code、value)。
默认值:idType为"id",nameType为"name","subType"为"sub"。哪个不同修改哪个,如下:
1,因为示例数据中idType为"code",则修改"idType"的值为"code"
2,因为示例数据中nameType为"value",则修改"idType"的值为"value"
3,subType的值与默认值相同,则无需修改,可以不传
注意:只需要修改与默认值不同的keyname即可,相同的可以不传,若都相同,则该参数可以不传
*/
objType: {
idType: "code",
nameType: "value"
},
// 源数据,必传
propsData: [
{
"code":78,
"value":"管理岗",
"sub":[
{ "code":80, "value":"总经理" },
{"code":81,"value":"总裁" }
]
},
{
"code":75,
"value":"其他",
"sub":[
{"code":76,"value":"其他"}
]
}
],
},
methods:{
// 获取返回的数据
getResult(data){
console.log('get result from component:', data)
this.initData = data
}
}
}
<style lang="scss" scoped>
.result-box{
display: block;
width: 100vw;
height: 30px;
line-height: 30px;
text-align: center;
background-color: #eeeeee;
.placeHolder{
color: gray;
}
}
</style>
API
linkage Props
属性名 | 类型 | 默认值 | 是否必传 | 说明 |
---|---|---|---|---|
propsData | Array | [] | 是 | 源数据,大类与子类必须具备相同的id、name |
initData | Object | {} | 否 | 需要定义默认选中项时传值 |
objType | Object | {idType:id,nameType:name,subType:sub} | 否 | 当propsData中对应的keyname(id、name、sub)与默认值不同时传值 |
navHeight | Number | 300 | 否 | 当需要改变展示区高度时传值 |
initData props
属性名 | 说明 |
---|---|
item | 初始化选中大类的信息,包含idType,nameType,默认为id、name |
subItem | 初始化选中子数据的信息,包含idType,nameType,默认为id、name |
注意:initData使用时,其格式与result返回格式一样,故可以将result返回的值直接赋值给initData,用来做结果显示
linkage Events
事件称名 | 说明 | 返回值 | 备注 |
---|---|---|---|
result | 组件返回的值 | e={item: Object, subItem: Object} | result返回格式与initData的格式一致 |
result 返回值
属性名 | 说明 |
---|---|
item | 选中大类的信息,包含idType,nameType,默认为id、name |
subItem | 选中子数据的信息,包含idType,nameType,默认为id、name |