为帮助用户更好更快的使用插件,论坛维护了一个示例,示例中包含示例代码、知识点讲解、注意事项等,供您参考。
UIListCard 展示了一个联系人列表。开发者只需传入数据源,插件会自动将联系人排序,展示出来。列表右侧字母导航条会自动随联系人数量调整。
列表条目(cell)布局如下图所示:
打开列表
open({params}, callback(ret))
rect:
{
x: 0, //(可选项)数字类型;插件左上角的 x 坐标(相对于所属的 Window 或 Frame);默认:0
y: 0, //(可选项)数字类型;插件左上角的 y 坐标(相对于所属的 Window 或 Frame);默认:0
w: 320, //(可选项)数字类型;插件的宽度,支持设置'auto';默认:所属的 Window 或 Frame 的宽度
h: 200 //(可选项)数字类型;插件的高度,支持设置'auto';默认:w * 2.0/3.0
}
contacts:
[{
name: '艾雪瑞', //(必传)字符串类型;条目的标题,若传空则放在#号分组下面
customerTypes: '个人客户'//(可选项)字符串类型;(可支持传入图片,可支持widget://和http://和https://)条目的类型,不传则不显示
}]
styles:
{
backgroudColor:'rgba(0,0,0,0)', // (可选项) 插件的背景颜色,默认:'rgba(0,0,0,0)'
sectionTitle: { //(可选项)JSON对象;标题的样式
bgColor: '#eee', //(可选项)字符串类型;标题的背景色,支持 rgb、rgba、#;默认:'#EEEEEE'
color: '#000', //(可选项)字符串类型;标题文字颜色,支持 rgb、rgba、#;默认:'#000000'
size: 12, //(可选项)数字类型;标题文字大小;默认:12.0
height: 25 //(可选项)数字类型;区域标题的高度,默认:25.0
},
item: { //(可选项)JSON对象;列表项的样式
bgColor: '#fff', //(可选项)字符串类型;列表项的背景色,支持 rgb、rgba、#;默认:'#FFFFFF'
activeBgColor: '#696969', //(可选项)字符串类型;列表项按下时的背景色,支持 rgb、rgba、#;默认:'#696969'
color: '#000', //(可选项)字符串类型;列表项的文字颜色,支持 rgb、rgba、#,默认:'#000000'
size: 14, //(可选项)数字类型;列表项的文字大小,默认:14.0
height: 40 //(可选项)数字类型;列表项的高度,默认:40.0
customerColor:'#000' // (可选项)字符串类型;条目类型的文字颜色
customerSize: 14, //(可选项)数字类型;条目类型的文字的大小
customerWidth:10 // (可选项) 数字类型;
条目类型若为图片,则此参数有效,条目类型图片的宽度
customerHeight:10 // (可选项) 数字类型;
条目类型若为图片,则此参数有效,条目类型图片的高度
}
}
indicator:
fixedOn:
ret:
{
eventType: 'show', //字符串类型;交互事件类型,取值范围如下:
//show:插件打开,数据排序成功显示在屏幕事件
//click:用户点击事件
key: 'A', //字符串类型;被点击的条目所在的区域的标题,仅当 eventType 为 click 时有值
section: 0, //数字类型;被点击的条目所在的区域在所有区域中的索引,仅当 eventType 为 click 时有值
index: 0, //数字类型;被点击的条目在所在区域内的索引,仅当 eventType 为 click 时有值
contact: {} //JSON 对象;所选条目的联系人信息,内容同传入的数据一致,仅当 eventType 为 click 时有值
}
var UIListCard = api.require('UIListCard');
UIListCard.open({
rect : {
x : 0,
y : 44,
w : api.frameWidth,
h : api.frameHeight - 104
},
contacts : [{
"employee_id" : 191,
"name" : "王科研",
"customerTypes" : "个人客户",
"dept_id" : "002000",
"isdeleted" : "N",
"tags" : "",
"isremark" : 1,
"phones" : [{
"phone" : "13366148872",
"type" : "1"
}]
}, {
"employee_id" : 192,
"name" : "艾瑞雪",
"customerTypes" : "个人客户",
"dept_id" : "002000",
"isdeleted" : "N",
"tags" : "",
"isremark" : 1,
"phones" : [{
"phone" : "13366148872",
"type" : "1"
}]
}, {
"employee_id" : 193,
"name" : "秋风疾",
"customerTypes" : "个人客户",
"dept_id" : "002000",
"isdeleted" : "N",
"tags" : "",
"isremark" : 1,
"phones" : [{
"phone" : "13366148872",
"type" : "1"
}]
}],
fixedOn : api.frameName
}, function(ret) {
if (ret) {
api.alert({
msg: JSON.stringify(ret)
})
}
});
iOS系统,Android系统
可提供的1.0.0及更高版本
关闭列表插件
close()
var UIListCard = api.require('UIListCard');
UIListCard.close();
iOS系统,Android系统
可提供的1.0.0及更高版本
隐藏列表插件,并没有从内存里清除
hide()
var UIListCard = api.require('UIListCard');
UIListCard.hide();
iOS系统,Android系统
可提供的1.0.0及更高版本
显示已隐藏的列表插件
show()
var UIListCard = api.require('UIListCard');
UIListCard.show();
iOS系统,Android系统
可提供的1.0.0及更高版本
刷新列表数据
reloadData({params})
contacts:
[{
name: '艾雪瑞', //字符串类型;条目的标题,若传空则放在#号分组下面。
customerTypes: '个人客户' //字符串类型;条目类型,不传则不显示
}]
var UIListCard = api.require('UIListCard');
UIListCard.reloadData({
contacts:[{
"employee_id": 191,
"name": "刘德华",
"customerTypes" : "个人客户",
"dept_id": "002000",
"isdeleted": "N",
"tags": "",
"isremark": 1,
"phones": [
{
"phone": "13366148872",
"type": "1"
}
]
},{
"employee_id": 192,
"name": "张学友",
"customerTypes" : "个人客户",
"dept_id": "002000",
"isdeleted": "N",
"tags": "",
"isremark": 1,
"phones": [
{
"phone": "13366148872",
"type": "1"
}
]
},{
"employee_id": 193,
"name": "郭富城",
"customerTypes" : "个人客户",
"dept_id": "002000",
"isdeleted": "N",
"tags": "",
"isremark": 1,
"phones": [
{
"phone": "13366148872",
"type": "1"
}
]
}]
});
iOS系统,Android系统
可提供的1.0.0及更高版本
向列表末端追加数据
appendData({params}, callback(ret))
data:
[{
name: '木子', //字符串类型;条目的标题,若传空则放在#号分组下面。
customerTypes: '个人客户' //字符串类型;条目类型,不传则不显示
}]
ret:
{
status: true //布尔型;true||false
}
var UIListCard = api.require('UIListCard');
UIListCard.appendData({
data: [{
"employee_id": 199,
"name": "木子",
"customerTypes" : "个人客户",
"dept_id": "002000",
"isdeleted": "N",
"tags": "",
"isremark": 1,
"phones": [
{
"phone": "13366148872",
"type": "1"
}
]
}]
}, function(ret, err) {
if (ret) {
api.alert({
msg: JSON.stringify(ret)
})
} else {
api.alert({
msg: JSON.stringify(err)
})
}
});
iOS系统,Android系统
可提供的1.0.0及更高版本
为帮助用户更好更快的使用插件,论坛维护了一个示例,示例中包含示例代码、知识点讲解、注意事项等,供您参考。