# Picker Picker是滑动选择器组件,类型支持普通选择器、日期选择器、时间选择器、时间日期选择器和多列文本选择器。具体用法请参考[Picker API](../js-reference/js-based-web-like-development-paradigm/js-components-basic-picker.md)。 ## 创建Picker组件 在pages/index目录下的hml文件中创建一个Picker组件。 ```
picker
``` ``` /* index.css */ .container { flex-direction: column; justify-content: center; align-items: center; background-color: #F1F3F5; } ``` ![zh-cn_image_0000001210951541](figures/zh-cn_image_0000001210951541.gif) ## 设置Picker类型 通过设置Picker的type属性来选择滑动选择器类型,如定义Picker为日期选择器。 ```
``` ``` /* index.css */ .container { flex-direction: column; justify-content: center; align-items: center; background-color: #F1F3F5; } .pickertext{ margin-bottom: 30px; } ``` ``` // xxx.js export default { data: { rangetext:['15', "20", "25"], textvalue:'Select text', datevalue:'Select date', } } ``` ![zh-cn_image_0000001163515416](figures/zh-cn_image_0000001163515416.gif) > ![icon-note.gif](public_sys-resources/icon-note.gif) **说明:** > - 普通选择器设置取值范围时,需要使用数据绑定的方式。 > > - 日期选择器的lunarswitch属性只支持手机和平板设备。 ## 设置时间展现格式 Picker的hours属性定义时间的展现格式,可选类型有12小时制和24小时制。 ```
``` ``` /* index.css */ .container { flex-direction: column; justify-content: center; align-items: center; background-color: #F1F3F5; } .pickertime { margin-bottom:50px; width: 300px; height: 50px; } ``` ![zh-cn_image_0000001163212630](figures/zh-cn_image_0000001163212630.gif) > ![icon-note.gif](public_sys-resources/icon-note.gif) **说明:** > - hours属性为12:按照12小时制显示,用上午和下午进行区分; > > - hours属性为24:按照24小时制显示。 ## 添加响应事件 对Picker添加change和cancel事件,来对选择的内容进行确定和取消。 ```
``` ``` /* index.css */ .container { flex-direction: column; justify-content: center; align-items: center; background-color: #F1F3F5; } .pickermuitl { margin-bottom:20px; width: 600px; height: 50px; font-size: 25px; letter-spacing:15px; } ``` ``` // xxx.js import prompt from '@system.prompt'; export default { data: { multitext:[["a", "b", "c"], ["e", "f", "g"], ["h", "i"]], multitextvalue:'Select multi-line text', multitextselect:[0,0,0], }, multitextonchange(e) { this.multitextvalue=e.newValue; prompt.showToast({ message:"Multi-column text changed to:" + e.newValue }) }, multitextoncancel() { prompt.showToast({ message:"multitextoncancel" }) }, } ``` ![zh-cn_image_0000001163372620](figures/zh-cn_image_0000001163372620.gif) ## 场景示例 在本场景中,开发者可以自定义填写当前的健康情况来进行打卡。 ```
Health check-in
Office:
Office hours:
Having fever or cold symptoms
Close contact with someone with COVID-19
``` ``` /* index.css */ .doc-page { flex-direction: column; background-color: #F1F3F5; } .title { margin-top: 30px; margin-bottom: 30px; margin-left: 50px; font-weight: bold; color: #0000ff; font-size: 38px; } .out-container { flex-direction: column; align-items: center; } .pick { width: 80%; height: 76px; border: 1px solid #0000ff; border-radius: 20px; padding-left: 12px; } .txt { width: 80%; font-size: 18px; text-align: left; margin-bottom: 12px; margin-left: 12px; } .dvd { margin-top: 30px; margin-bottom: 30px; margin-left: 80px; margin-right: 80px; color: #6495ED; stroke-width: 6px; } ``` ``` // xxx.js import pmt from '@system.prompt' export default { data: { yorn1:'No', yorn2:'No', pos:'Home', yesno:['Yes', 'No'], posarr:['Home', 'Company'], datevalue:'Select time', datetimeselect:'2012-5-6-11-25', dateselect:'2021-9-17', showbuild:true }, onInit() { }, isFever(e) { this.yorn1 = e.newValue }, isTouch(e) { this.yorn2 = e.newValue }, setPos(e) { this.pos = e.newValue if (e.newValue === 'Non-research center') { this.showbuild = false } else { this.showbuild = true } }, setbuild(e) { this.build = e.newValue }, dateonchange(e) { this.datevalue = e.year + "-" + e.month + "-" + e.day; pmt.showToast({ message:"date:"+e.year+"-"+e.month+"-"+e.day }) }, datetimeonchange(e) { this.datetimevalue=e.year+"-"+e.month+"-"+e.day+" "+e.hour+":"+e.minute; pmt.showToast({ message:"Time:"+e.month+"-"+e.day+" "+e.hour+":"+e.minute }) }, showtoast() { pmt.showToast({ message: 'Submitted.', duration: 2000, gravity: 'center' }) } } ``` ![zh-cn_image_0000001208703849](figures/zh-cn_image_0000001208703849.gif)