MiniX自绘渲染跨平台框架
  • 框架说明
  • 声明式开发范式
  • 内置Api
指南
接口
  • Minix CLI
示例
  • 类Web框架

    • 框架说明
    • 类Web开发范式
    • 内置Api
  • 指南
  • 组件
  • 接口
  • 示例
  • 规范
  • DophinHybrid

    • 快速上手 (opens new window)
    • UI 组件库 (opens new window)
    • jsBridge 接口 (opens new window)
  • DolphinWeex

    • 快速上手 (opens new window)
    • UI 组件库 (opens new window)
    • jsBridge 接口 (opens new window)
  • 发布消息
  • 常见问题
  • 更新日志
  • 框架说明
  • 声明式开发范式
  • 内置Api
指南
接口
  • Minix CLI
示例
  • 类Web框架

    • 框架说明
    • 类Web开发范式
    • 内置Api
  • 指南
  • 组件
  • 接口
  • 示例
  • 规范
  • DophinHybrid

    • 快速上手 (opens new window)
    • UI 组件库 (opens new window)
    • jsBridge 接口 (opens new window)
  • DolphinWeex

    • 快速上手 (opens new window)
    • UI 组件库 (opens new window)
    • jsBridge 接口 (opens new window)
  • 发布消息
  • 常见问题
  • 更新日志

# picker

说明: 从API version 4开始支持。后续版本如有新增内容,则采用上角标单独标记该内容的起始版本。

滑动选择器组件,类型支持普通选择器、日期选择器、时间选择器、时间日期选择器和多列文本选择器。

# 权限列表

无

# 子组件

不支持。

# 属性

除支持通用属性外,还支持如下属性:

名称 类型 默认值 必填 描述
type string - 否 该属性值不支持动态修改。可选择项有:
- text:文本选择器。
- date:日期选择器。
- time:时间选择器。
- datetime:日期时间选择器。
- multi-text:多列文本选择器。

# 普通选择器

滑动选择器类型设置为text时表示普通选择器。

名称 类型 默认值 必填 描述
range Array - 否 设置普通选择器的取值范围,如["15", "20", "25"]。
使用时需要使用数据绑定的方式range =,js中声明相应变量data:["15","20","25"]。
selected string 0 否 设置普通选择器弹窗的默认取值,取值需要是 range 的索引值,该取值表示选择器弹窗界面的默认选择值。
value string - 否 设置普通选择器的值。

# 日期选择器

滑动选择器类型设置为date时表示日期选择器。

名称 类型 默认值 必填 描述
start <time> 1970-1-1 否 设置日期选择器的起始时间,格式为 YYYY-MM-DD。
end <time> 2100-12-31 否 设置日期选择器的结束时间,格式为 YYYY-MM-DD。
selected string 当前日期 否 设置日期选择器弹窗的默认取值,格式为 YYYY-MM-DD,该取值表示选择器弹窗界面的默认选择值。
value string - 是 设置日期选择器的值。
lunar5+ boolean false 否 设置日期选择器弹窗界面是否为农历展示。
lunarswitch boolean false 否 设置日期选择器是否显示农历开关。当值为true时,显示农历开关,点击农历开关可切换公历和农历。当值为false时,不显示农历开关。
当lunarswitch=true且lunar=true时,开关按钮处于被选中状态。

# 时间选择器

滑动选择器类型设置为time时表示时间选择器。

名称 类型 默认值 必填 描述
containsecond boolean false 否 设置时间选择器是否包含秒。
selected string 当前时间 否 设置时间选择器弹窗的默认取值,格式为 HH:mm;当包含秒时,格式为HH:mm:ss,
该取值表示选择器弹窗界面的默认选择值。
value string - 否 设置时间选择器的值。
hours number 241-4
-5+
否 设置时间选择器采用的时间格式,可选值:
- 12:按照12小时制显示,用上午和下午进行区分;
- 24:按照24小时制显示。
从API Version 5开始,默认值会依据系统当前所选地区和语言选择当地习惯的小时制(12小时制或24小时制)。

# 日期时间选择器

滑动选择器类型设置为datetime时表示日期时间选择器,日期的选择范围为本年的日月。

名称 类型 默认值 必填 描述
selected string 当前日期时间 否 设置日期时间选择器弹窗的默认取值,有两种可选格式。
- 月日时分:MM-DD-HH-mm
- 年月日时分:YYYY-MM-DD-HH-mm
不设置年时,默认使用当前年,该取值表示选择器弹窗界面的默认选择值。
value string - 是 设置日期时间选择器的值。
hours number 241-4
-5+
否 设置日期时间选择器采用的时间格式,可选值:
- 12:按照12小时制显示,用上午和下午进行区分;
- 24:按照24小时制显示。
从API Version 5开始,默认值会依据系统当前所选地区和语言选择当地习惯的小时制(12小时制或24小时制)。
lunar5+ boolean false 否 设置日期时间选择器弹窗界面是否为农历展示。
lunarswitch boolean false 否 设置日期选择器是否显示农历开关。当值为true时,显示农历开关,点击农历开关可切换公历和农历。当值为false时,不显示农历开关。
当lunarswitch=true且lunar=true时,开关按钮处于被选中状态。

# 多列文本选择器

滑动选择器类型设置为multi-text时表示多列文本选择器。

名称 类型 默认值 必填 描述
columns number - 是 设置多列文本选择器的列数。
range 二维Array - 否 设置多列文本选择器的选择项,其中range 为二维数组。长度表示多少列,数组的每项表示每列的数据,如  [["a","b"], ["c","d"]]。
使用时需要使用数据绑定的方式range =,js中声明相应变量data:["15","20","25"]。
selected Array [0,0,0,…] 否 设置多列文本选择器弹窗的默认值,每一列被选中项对应的索引构成的数组,该取值表示选择器弹窗界面的默认选择值。
value Array - 否 设置多列文本选择器的值,每一列被选中项对应的值构成的数组。

# 样式

除支持通用样式外,还支持如下样式:

名称 类型 默认值 必填 描述
text-color <color> - 否 选择器的文本颜色。
font-size <length> - 否 选择器的文本尺寸。
allow-scale boolean true 否 选择器的文本尺寸是否跟随系统设置字体缩放尺寸进行放大缩小。
如果在config描述文件中针对ability配置了fontSize的config-changes标签,则应用不会重启而直接生效。
letter-spacing <length> 0 否 选择器的字符间距。见text组件的letter-spacing样式属性。
text-decoration string - 否 选择器的文本修饰。见text组件的text-decoration样式属性。
font-style string normal 否 选择器的字体样式。见text组件的font-style样式属性。
font-weight number | string normal 否 选择器的字体粗细。见text组件的font-weight样式属性。
font-family string sans-serif 否 选择器的字体列表,用逗号分隔,每个字体用字体名或者字体族名设置。列表中第一个系统中存在的或者通过自定义字体指定的字体,会被选中作为文本的字体。
line-height <length> 0px 否 选择器的文本行高。
column-height5+ <length> - 否 选择器的选择项列表高度。

# 事件

除支持通用事件外,还支持如下事件:

# 普通选择器

名称 参数 描述
change { newValue: newValue, newSelected: newSelected } 普通选择器选择值后点击弹窗中的确定按钮时触发该事件(newSelected为索引)。
cancel - 用户点击弹窗中的取消按钮时触发该事件。

# 日期选择器

名称 参数 描述
change { year: year, month: month, day: day } 日期选择器选择值后点击弹窗中的确认按钮时触发该事件。
从API Version 5开始,month值范围为: 0(1月)~11(12月)。
cancel - 用户点击弹窗中的取消按钮时触发该事件。

# 日期时间选择器

名称 参数 描述
change { year: year, month: month, day: day,  hour: hour, minute: minute} 日期时间选择器选择值后点击弹窗中的确认按钮时触发该事件。
cancel - 用户点击弹窗中的取消按钮时触发该事件。

# 时间选择器

名称 参数 描述
change { hour: hour, minute: minute, [second: second] } 时间选择器选择值后点击弹窗中的确认按钮时触发该事件,当使用时分秒时,还包含秒数据。
cancel - 用户点击弹窗中的取消按钮时触发该事件。

# 多列文本选择器

名称 参数 描述
change { newValue: [newValue1, newValue2, newValue3, …], newSelected:[newSelected1, newSelected2, newSelected3, …] } 多列文本选择器选择值后点击弹窗中的确认按钮时触发该事件,其中:
- newValue:被选中项对应的值构成的数组。
- newSelected:被选中项对应的索引构成的数组,两者的长度和range的长度一致。
columnchange { column: column, newValue: newValue, newSelected: newSelected } 多列文本选择器中某一列的值改变时触发该事件,其中:
- column:第几列修改。
- newValue:选中的值。
- newSelected:选中值对应的索引。
cancel - 用户点击弹窗中的取消按钮时触发该事件。

# 方法

除支持通用方法外,支持如下方法:

名称 参数 描述
show - 显示 picker。

# 示例

<!-- xxx.mxl -->
<div class="container">
  <select @change="selectChange">
        <option value="{{ item }}" for="item in selectList">
            {{ item }}
        </option>
  </select>
  <picker id="picker0" type="text" value="{{textvalue}}" selected="{{textselect}}" range="{{rangetext}}" onchange="textonchange"
    oncancel="textoncancel" class="pickertext"  "></picker>

  <picker id="picker1" type="date" value="{{datevalue}}" start="2002-2-5" end="2030-6-5" selected="{{dateselect}}" lunarswitch="true"
    onchange="dateonchange" oncancel="dateoncancel" class="pickerdate" show="false"></picker>

  <picker id="picker2" type="time" value="{{timevalue}}" containsecond="{{containsecond}}" selected="{{timeselect}}" hours="12"
    onchange="timeonchange" oncancel="timeoncancel" class="pickertime" show="false"></picker>

  <picker id="picker3" type="datetime" value="{{datetimevalue}}" selected="{{datetimeselect}}" hours="24" lunarswitch="true"
    onchange="datetimeonchange" oncancel="datetimeoncancel" class="pickerdatetime" show="false"></picker>

  <picker id="picker4" type="multi-text" value="{{multitextvalue}}" columns="3" range="{{multitext}}" selected="{{multitextselect}}"
    onchange="multitextonchange" oncancel="multitextoncancel" class="pickermuitl" show="false"></picker>
</div>
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
/* xxx.css */
.container {    
  flex-direction: column;
  justify-content: center;
  align-items: center;
}
 picker{
  width:60%;
  height:80px;
  border-radius:20px;
  text-color:white;
  font-size:15px;
  background-color:#4747e3;
  margin-left:20%;
}
 select{
  background-color: #efecec;
  height: 50px;
  width: 60%;
  margin-left: 20%;
  margin-top: 300px;
  margin-bottom: 50px;
  font-size: 22px;
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
// xxx.js
import router from '@system.router';
import prompt from '@system.prompt';
export default {
  data: {    
    selectList:["text","data","time","datetime","multitext"],
    rangetext:['15', "20", "25"],    
    multitext:[["a", "b", "c"], ["e", "f", "g"], ["h", "i"], ["k", "l", "m"]],    
    textvalue:'default textvalue',    
    datevalue:'default datevalue',    
    timevalue:'default timevalue',    
    datetimevalue:'default datetimevalue',    
    multitextvalue:'default multitextvalue',    
    containsecond:true,    
    multitextselect:[1,2,0],    
    datetimeselect:'2012-5-6-11-25',    
    timeselect:'11:22:30',    
    dateselect:'2021-3-2',    
    textselect:'2'
  },
  selectChange(e){
        for(let i = 0;i<this.selectList.length;i++){
            if(e.newValue == this.selectList[i]){
                this.$element("picker"+i).show();
            }
        }
    },
  textonchange(e) {    
    this.textvalue = e.newValue;    
    prompt.showToast({ message:"text:"+e.newValue+",newSelected:"+e.newSelected })
  },
  textoncancel(e) {    
    prompt.showToast({ message:"text: textoncancel" })
  },
  dateonchange(e) {    
    this.datevalue = e.year + "-" + e.month + "-" + e.day;    
    prompt.showToast({ message:"date:"+e.year+"-"+(e.month+1)+"-"+e.day })
  },
  dateoncancel() {    
    prompt.showToast({ message:"date: dateoncancel" })
  },
  timeonchange(e) {    
    if(this.containsecond){        
      this.timevalue=e.hour+":"+e.minute+":"+e.second;        
      prompt.showToast({ message:"Time:" + e.hour + ":" + e.minute + ":" + e.second })
    } else {        
      this.timevalue=e.hour+":"+e.minute;        
      prompt.showToast({ message:"Time:" + e.hour + ":" + e.minute })
    }},
  timeoncancel() {    
    prompt.showToast({ message:"timeoncancel" })
  },
  datetimeonchange(e) {    
    this.datetimevalue=e.year+"-"+e.month+"-"+e.day+" "+e.hour+":"+e.minute;    
    prompt.showToast({ message:"Time:"+(e.month+1)+"-"+e.day+" "+e.hour+":"+e.minute })
  },
  datetimeoncancel() {    
    prompt.showToast({ message:"datetimeoncancel" })
  },
  multitextonchange(e) {    
    this.multitextvalue=e.newValue;    
    prompt.showToast({ message:"Multi-column text change" + e.newValue })
  },
  multitextoncancel() {    
    prompt.showToast({ message:"multitextoncancel" })
  },
  popup_picker() {    
    this.$element("picker_text").show();
  },
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70

zh-cn_image_0000001191939702