UIAddressBook
来自于:AC模块工作室立即使用
open close hide show reloadData setSelected getSelectedSync setRect
概述
UIAddressBook 展示了一个联系人列表。开发者只需传入数据源,模块会自动将联系人排序,展示出来。列表右侧字母导航条会自动随联系人数量调整。
列表条目(cell)布局如下图所示:
open
打开列表
open({params}, callback(ret))
params
rect:
- 类型:JSON 对象
- 描述:(可选项)模块的位置及尺寸
- 内部字段:
{
x: 0, //(可选项)数字类型;模块左上角的 x 坐标(相对于所属的 Window 或 Frame);默认:0
y: 0, //(可选项)数字类型;模块左上角的 y 坐标(相对于所属的 Window 或 Frame);默认:0
w: 320, //(可选项)数字类型;模块的宽度;默认:所属的 Window 或 Frame 的宽度
h: 200 //(可选项)数字类型;模块的高度;默认:w * 2.0/3.0
}
contacts:
- 类型:数组对象
- 描述:列表数据源
- 内部字段:
[{
id:'123', //字符串类型;id
name: '小明', //字符串类型;条目的标题,不传则不显示
sex: 'male', //字符串类型;性别('male':男,'fmale':女,'ufo':'火星人')
img: 'widget://image/head.png' //字符串类型;头像地址,支持(http://,https://,fs://,widget://)
role: 1, //数字类型;是否为群主,默认为1,当role为0时,为群主
phones:[{'工作', '123123'},{'家庭', '12123133'},{'个人', '1123123'}], //JSON数组类型;联系人的手机号数组
defaultSel: false //(可选项)布尔类型;设置默认选中状态,仅当checkBox 为 true 时有效。本参数为 true 时只返回点击事件(eventType 为 defaultSel)而不改变该条目选中状态;默认:false,
tel1:'1234567890' //联系人手机号
userType:0 //数字类型;用户类型(0:进群,1:未进群),默认:0
}]
checkBox:
- 类型:布尔
- 描述:(可选项)是否显示复选框
- 默认:false
singleCheck:
- 类型:布尔
- 描述:(可选项)是否显示为单选
- 默认:false
bounces:
- 类型:布尔
- 描述:(可选项)列表是否有弹动效果
- 默认:false
coverInfo:
- 类型:布尔
- 描述:(可选项)是否遮盖部分信息,该状态时,遮盖姓,以及联系方式第三位以后,最多四位 字符
- 默认:false
manage:
- 类型:布尔
- 描述:(可选项)是否为成员管理,当为成员管理状态时,群主标志位于姓名之后,userType参 数为1时,在更多按钮前显示未进群标志
- 默认:false
moreIcon:
- 类型:字符串类型
- 描述:(可选项)更多按钮图标地址,仅支持本地路径(fs://和widget://)
fixedOn:
- 类型:字符串
- 描述:(可选项)模块视图添加到指定 frame 的名字(只指 frame,传 window 无效)
- 默认:模块依附于当前 window
callback(ret)
ret:
- 类型:JSON 对象
- 内部字段:
{
eventType: 'show', //字符串类型;交互事件类型,取值范围如下:
//show:模块打开,数据排序成功显示在屏幕事件
//click:用户点击事件,当 checkBox 参数为 true 时,本事件识别为 select
//select:点击复选框事件
//defaultSel:点击被默认设置为选中项的条目的回调事件
//more:点击更多按钮事件,当 checkBox 参数为 true 时,本事件识别为 select
//scrollUp:向上滑动事件
//scrollDown:向下滑动事件
contacts: [] //JSON 数组;所选条目的联系人信息,内容同传入的数据一致,仅当 eventType 为 select,且 singleCheck 为 false 时有值
contact: {} //JSON 对象;点击条目的联系人信息,内容同传入的数据一致,当 eventType 为 click,more 或者eventType 为 select,且singleCheck为 true 时有值
}
示例代码
var UIAddressBook = api.require('UIAddressBook');
UIAddressBook.open({
rect:{
x: 0,
y: 44,
w: api.frameWidth,
h: api.frameHeight - 104
},
contacts:[{
id:'1',
name: '张小明',
sex: 'male',
img: 'widget://image/head.png',
isGroupOwner: true
},{
id:'2',
name: '孙小红',
sex: 'fmale',
img: 'widget://image/head.png',
isGroupOwner: false
},{
id:'3',
name: '李小刚',
sex: 'ufo',
img: 'widget://image/head.png',
isGroupOwner: false
}],
fixedOn: api.frameName
}, function(ret) {
if (ret) {
alert(JSON.stringify(ret));
}
});
可用性
iOS系统,Android系统
可提供的1.0.0及更高版本
close
关闭列表模块
close()
示例代码
var UIAddressBook = api.require('UIAddressBook');
UIAddressBook.close();
可用性
iOS系统,Android系统
可提供的1.0.0及更高版本
hide
隐藏列表模块,并没有从内存里清除
hide()
示例代码
var UIAddressBook = api.require('UIAddressBook');
UIAddressBook.hide();
可用性
iOS系统,Android系统
可提供的1.0.0及更高版本
show
显示已隐藏的列表模块
show()
示例代码
var UIAddressBook = api.require('UIAddressBook');
UIAddressBook.show();
可用性
iOS系统,Android系统
可提供的1.0.0及更高版本
reloadData
刷新列表数据
reloadData({params})
params
contacts:
- 类型:数组对象
- 描述:列表数据源
- 内部字段:
[{
id:'123', //字符串类型;id
name: '小明', //字符串类型;条目的标题,不传则不显示
sex: 'male', //字符串类型;性别('male':男,'fmale':女,'ufo':'火星人')
img: 'widget://image/head.png' //字符串类型;头像地址,支持(http://,https://,fs://,widget://)
role: 1, //数字类型;是否为群主,默认为1,当role为0时,为群主
phones:[{'工作', '123123'},{'家庭', '12123133'},{'个人', '1123123'}], //JSON数组类型;联系人的手机号数
defaultSel: false //(可选项)布尔类型;设置默认选中状态,仅当checkBox 为 true 时有效,当为 true 时只返回点击事件(eventType 为 defaultSel)而不改变该条目选中状态;默认:false
}]
示例代码
var UIAddressBook = api.require('UIAddressBook');
UIAddressBook.reloadData({
contacts:[{
id:'1',
name: '张明',
sex: 'ufo',
img: 'widget://image/head.png',
isGroupOwner: false
},{
id:'2',
name: '孙红',
sex: 'male',
img: 'widget://image/head.png',
isGroupOwner: true
},{
id:'3',
name: '李刚',
sex: 'fmale',
img: 'widget://image/head.png',
isGroupOwner: false
}]
});
可用性
iOS系统,Android系统
可提供的1.0.0及更高版本
setSelected
设置选中的联系人
setSelected({params})
params
selected:
- 类型:布尔
- 描述:(可选项)设置/取消选中状态
- 默认:true(设置为选中状态)
contacts:
- 类型:数组
- 描述:要设置为选中状态的联系人id组成的数组
- 参数示例:[‘191’,’192’,’193’]
示例代码
var UIAddressBook = api.require('UIAddressBook');
UIAddressBook.reloadData({
contacts:['191','192','193']
});
可用性
iOS系统,Android系统
可提供的1.0.0及更高版本
getSelectedSync
获取所有当前选中的联系人信息,同步接口
getSelectedSync()
return
ret:
- 类型:JSON 对象
- 内部字段:
{
contacts: [{}] //数组类型;被选中的联系人的信息组成的数组,内部字段通open时传入的一致
}
示例代码
var UIAddressBook = api.require('UIAddressBook');
var ret = UIAddressBook.getSelectedSync();
api.alert(JSON.stringify(ret));
可用性
iOS系统,Android系统
可提供的1.0.0及更高版本
setRect
设置列表尺寸
setRect({params})
params
rect:
- 类型:JSON 对象
- 描述:(可选项)模块的位置及尺寸
- 内部字段:
{
x: 0, //(可选项)数字类型;模块左上角的 x 坐标(相对于所属的 Window 或 Frame);默认:原值
y: 0, //(可选项)数字类型;模块左上角的 y 坐标(相对于所属的 Window 或 Frame);默认:原值
w: 320, //(可选项)数字类型;模块的宽度;默认:原值
h: 300 //(可选项)数字类型;模块的高度;默认:原值
}
animation:
- 类型:布尔
- 描述:(可选项)改变 rect 时,是否带动画效果,暂仅支持 iOS 平台
- 默认:false
示例代码
var UIAddressBook = api.require('UIAddressBook');
UIAddressBook.setRect({
rect: {
x: 0,
y: 0,
w: '320',
h: '400'
},
animation: true
});
可用性
iOS系统,Android系统
可提供的1.0.0及更高版本
附录
当设置为单选状态时,并将其中一个用户设置为设置默认选中状态,此时如果再次设置选中联系人时(包括默认选中状态的联系人),那么需要显示只有一个默认选中的状态,还是设置一个除此之外的联系人? 这个问题在android和ios上存在争议,因为技术人员觉得该问题影响可以忽略,则暂时略过,如果以后有强烈的需求要改动,再改动。