为帮助用户更好更快的使用插件,论坛维护了一个示例,示例中包含示例代码、知识点讲解、注意事项等,供您参考。
UICustomPicker 插件是一个自定义内容选择器;可自定义插件位置、内容取值范围、内容标签,设置选中内容;可用于实现固定取值范围的内容选择器,多项内容之间没有级联关系;同一个页面可以打开多个插件实例,以插件 id 区分。
打开自定义选择器
open({params}, callback(ret, err))
rect:
{
x: 0, //(可选项)数字类型;插件左上角的 x 坐标(相对于所属的 Window 或 Frame);默认:0
y: 0, //(可选项)数字类型;插件左上角的 y 坐标(相对于所属的 Window 或 Frame);默认:0
w: 320, //(可选项)数字类型;插件的宽度;默认:所属的 Window 或 Frame 的宽度
h: 480 //(可选项)数字类型;插件的高度;默认:所属的 Window 或 Frame 的高度
}
styles:
{
bg: 'rgba(0,0,0,0)', //(可选项)字符串类型;选中内容区域的背景,支持 rgb,rgba,#,图片路径(本地路径,fs://、widget://);默认:'rgba(0,0,0,0)'
normalColor: '#959595', //(可选项)字符串类型;未选中内容的字体颜色,支持 rgb,rgba,#;默认:'#959595'
normalSize:15, //(可选项)数字类型;未选中内容字体大小;默认:15
selectedColor: '#3685dd', //(可选项)字符串类型;选中内容的字体颜色,支持 rgb,rgba,#;默认:'#3685dd'
disableSelectColor: '#EDEDED',//(可选项)字符串类型;不可选中项的字体颜色,支持 rgb,rgba,#;默认:'#EDEDED'
selectedSize: 36, //(可选项)数字类型;选中内容的字体大小;默认:36.0
tagColor: '#3685dd', //(可选项)字符串类型;内容标签的字体颜色,支持 rgb,rgba,# ;默认:'#3685dd'
tagSize: 12, //(可选项)数字类型;内容标签的字体大小;默认:12
tagMarginR:10, //(可选项)数字类型;标签距离当前picker的右边框的距离;默认:0
pickersWidth:[60, 20, 20] //(可选项)数组类型;picker所占插件宽度的百分比,不传时均分插件宽度,数组长度等于data数组的长度
}
data:
[{
tag: '时', //(可选项)字符串类型;内容标签;不传或传空则不显示
scope: '0-23' //内容的取值范围
//支持字符串类型,如:'0-23' ,表示取值范围为0至23,中间符号为英文连字符'-',只有整数范围可以如此传参
//支持数组类型,如:['一','二','三','四'],表示内容取值范围包含在数组之内
//支持数组类型,如:[{value:'一',id:1},{value:'二',id:2},{value:'三',id:3},{value:'四',id:4}],表示内容取值包含在 JSON 对象组成的数组之内,其中 value 为必须传键值。其余可自定义,此 JSON 对象会在 callback 内回调给前端
}]
disableSelect:
[{
scope: '0-23' //支持数组类型,如:['一','二','三','四']或[{value:'一',id:1},{value:'二',id:2},{value:'三',id:3},{value:'四',id:4}],表示设置不可被中选项的内容
}]
rows:
autoHide:
loop:
fixedOn:
fixed:
ret:
{
id: 0, //数字类型;插件的 id,用于区分插件的多个实例
eventType: 'show', //字符串类型;交互事件类型
//取值范围:
//show(插件打开成功)
//selected(选择器选中内容)
data: ['12','30'] //数组类型;选择器选中的内容数组,内部元素与源数据保持一致
}
var UICustomPicker = api.require('UICustomPicker');
UICustomPicker.open({
rect: {
x: 30,
y: api.frameHeight / 2 - 170,
w: api.frameWidth - 60,
h: 340
},
styles: {
bg: 'rgba(0,0,0,0)',
normalColor: '#959595',
selectedColor: '#3685dd',
selectedSize: 36,
tagColor: '#3685dd',
tagSize: 10
},
data: [{
tag: '时',
scope: '0-23'
}, {
tag: '分',
scope: ['a', 'b', 'c', 'd']
}],
rows: 3,
fixedOn: api.frameName,
fixed: true
}, function(ret, err) {
if (ret) {
api.alert({
msg: JSON.stringify(ret)
})
} else {
api.alert({
msg: JSON.stringify(err)
})
}
});
iOS系统,Android系统
可提供的1.0.0及更高版本
关闭自定义选择器
close({params})
id:
var UICustomPicker = api.require('UICustomPicker');
UICustomPicker.close({
id: 0
});
iOS系统,Android系统
可提供的1.0.0及更高版本
显示自定义选择器
show({params})
id:
var UICustomPicker = api.require('UICustomPicker');
UICustomPicker.show({
id: 0
});
iOS系统
可提供的1.0.0及更高版本
隐藏自定义选择器
hide({params})
id:
var UICustomPicker = api.require('UICustomPicker');
UICustomPicker.hide({
id: 0
});
iOS系统
可提供的1.0.0及更高版本
设置自定义选择器当前选中的内容
setValue({params})
id:
data:
var UICustomPicker = api.require('UICustomPicker');
UICustomPicker.setValue({
id: 0,
data: ['12', '30']
});
iOS系统,Android系统
可提供的1.0.0及更高版本
刷新数据源
refreshData({params})
id:
data:
[{
tag: '时', //(可选项)字符串类型;内容标签;不传或传空则不显示
scope: '0-23' //内容的取值范围
//支持字符串类型,如:'0-23' ,表示取值范围为0至23,中间符号为英文连字符'-',只有整数范围可以如此传参
//支持数组类型,如:['一','二','三','四'],表示内容取值范围包含在数组之内
//支持数组类型,如:[{value:'一',id:1},{value:'二',id:2},{value:'三',id:3},{value:'四',id:4}],表示内容取值包含在 JSON 对象组成的数组之内,其中 value 为必须传键值。其余可自定义,此 JSON 对象会在 callback 内回调给前端
}]
var UICustomPicker = api.require('UICustomPicker');
UICustomPicker.refreshData({
id: 0,
data: [{
tag:'大写',
scope:[
{value:'一',id:1},
{value:'二',id:2},
{value:'三',id:3},
{value:'四',id:4}
]
},{
tag:'汉子',
scope:[
{value:'壹',id:1},
{value:'贰',id:2},
{value:'叁',id:3},
{value:'肆',id:4}
]
}]
});
iOS系统,Android系统
可提供的1.0.0及更高版本
为帮助用户更好更快的使用插件,论坛维护了一个示例,示例中包含示例代码、知识点讲解、注意事项等,供您参考。