鸿蒙5.0开发进阶:JS组件-基础组件(picker-view)

往期鸿蒙5.0全套实战文章必看:(文中附带全栈鸿蒙5.0学习资料)


picker-view

说明

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

嵌入页面的滑动选择器。

子组件

不支持。

属性

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

名称类型默认值必填描述
typestringtext

设置滑动选择器的类型,该属性不支持动态修改,可选项有:

- text:文本选择器。

- time:时间选择器。

- date:日期选择器。

- datetime:日期时间选择器。

- multi-text:多列文本选择器。

文本选择器

名称类型默认值必填描述
rangeArray-

设置文本选择器的取值范围。

使用时需要使用数据绑定的方式range ={{data}},js中声明相应变量data:["15","20","25"]。

selectedstring0设置文本选择器的默认选择值,该值需要为range的索引。
indicatorprefixstring-文本选择器选定值增加的前缀字段。
indicatorsuffixstring-文本选择器选定值增加的后缀字段。

时间选择器

名称类型默认值必填描述
containsecondbooleanfalse时间选择器是否包含秒。
selectedstring当前时间

设置时间选择器的默认取值,格式为 HH:mm;

当包含秒时,格式为HH:mm:ss。

hoursnumber

241-4

-5+

设置时间选择器采用的时间格式,可选值:

- 12:按照12小时制显示,用上午和下午进行区分;

- 24:按照24小时制显示。

从API Version 5开始,默认值会依据系统当前所选地区和语言选择当地习惯的小时制(12小时制或24小时制)。

日期选择器

名称类型默认值必填描述
start<time>1970-1-1设置日期选择器的起始时间,格式为 YYYY-MM-DD。
end<time>2100-12-31设置日期选择器的结束时间,格式为 YYYY-MM-DD。
selectedstring当前日期设置日期选择器的默认选择值,格式为 YYYY-MM-DD。
lunar5+booleanfalse设置日期选择器弹窗界面是否为农历展示。
lunarswitchbooleanfalse设置日期选择器是否显示农历开关,显示农历开关时,可以在弹窗界面展现农历的开关由于公历和农历切换。在设置显示农历时,开关状态为开,当设置不显示农历时,开关状态为关。

日期时间选择器

名称类型默认值必填描述
selectedstring当前日期时间设置日期时间选择器的默认取值,格式有两种,为月日时分MM-DD-HH-mm或者年月日时分YYYY-MM-DD-HH-mm,不设置年时,默认使用当前年,该取值表示选择器弹窗时弹窗界面的默认选择值。
hoursnumber

241-4

-5+

设置日期时间选择器采用的时间格式,可选值:

- 12:按照12小时制显示,用上午和下午进行区分;

- 24:按照24小时制显示。

从API Version 5开始,默认值会依据系统当前所选地区和语言选择当地习惯的小时制(12小时制或24小时制)。

lunar5+booleanfalse设置日期时间选择器弹窗界面是否为农历展示。
lunarswitchbooleanfalse设置日期时间选择器是否显示农历开关,显示农历开关时,可以在弹窗界面展现农历的开关由于公历和农历切换。在设置显示农历时,开关状态为开,当设置不显示农历时,开关状态为关。

多列文本选择器

名称类型默认值必填描述
columnsnumber-设置多列文本选择器的列数。
range二维Array-

设置多列文本选择器的选择值,该值为二维数组。长度表示多少列,数组的每项表示每列的数据,如 [["a","b"], ["c","d"]]。

使用时需要使用数据绑定的方式range ={{data}},js中声明相应变量data:["15","20","25"]。

selectedArray[0,0,0,…]设置多列文本选择器的默认值,每一列被选中项对应的索引构成的数组,该取值表示选择器弹窗时弹窗界面的默认选择值。

样式

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

名称类型默认值必填描述
color<color>#ffffff候选项字体颜色。
font-size<length>16px候选项字体尺寸,类型length,单位px。
selected-color<color>#ff0a69f7选中项字体颜色。
selected-font-size<length>20px选中项字体尺寸,类型length,单位px。
disappear-color5+<color>#ffffff渐变消失项的字体颜色。消失项是在一列中有五个选项场景下最上和最下的两个选项。
disappear-font-size5+<length>14px渐变消失项的字体尺寸。消失项是在一列中有五个选项场景下最上和最下的两个选项。
font-familystringsans-serif选项字体类型。字体列表,用逗号分隔,每个字体用字体名或者字体族名设置。列表中第一个系统中存在的或者通过自定义字体指定的字体,会被选中作为文本的字体。

事件

仅支持如下事件:

文本选择器

名称参数描述
change{ newValue: newValue, newSelected: newSelected }文本选择器选定值后触发该事件。

时间选择器

名称参数描述
change{ hour: hour, minute: minute, [second:second]}

时间选择器选定值后触发该事件。

包含秒时,返回时分秒。

日期选择器

名称参数描述
change{ year:year, month:month, day:day }日期选择器选择值后触发该事件。

日期时间选择器

名称参数描述
change{ year:year, month:month, day:day, hour:hour, minute:minute }日期时间选择器选择值后触发该事件。

多列文本选择器

名称参数描述
columnchange{ column:column, newValue:newValue, newSelected:newSelected }多列文本选择器某一列的值改变时触发该事件,column:第几列修改,newValue:选中的值,newSelected:选中值对应的索引。

方法

不支持。

示例

文本选择器

<!-- xxx.hml -->
<div class="container">
    <text class="title">
        选中值:{{value}}  选中下标: {{index}}
    </text>
    <picker-view class="text-picker" type="text" range="{{options}}" selected="0" indicatorprefix="prefix" indicatorsuffix="suffix" @change="handleChange"></picker-view>
</div>
/* xxx.css */
.container {
    flex-direction: column;
    justify-content: center;
    align-items: center;
    width: 100%;
    height: 50%;
}
.title {
    font-size: 30px;
    text-align: center;
    margin-top: 50%;
}
/* xxx.js */
export default {
    data: {
        options: ['选项1', '选项2', '选项3'],
        value: "选项1",
        index: 0
    },
    handleChange(data) {
        this.value = data.newValue;
        this.index = data.newSelected;
    },
}

时间选择器

<!-- xxx.hml -->
<div class="container">
  <text class="title">
    Selected:{{time}}
  </text>
  <picker-view class="time-picker" type="time" selected="{{defaultTime}}" @change="handleChange"></picker-view>
</div>
/* xxx.css */
.container {
    flex-direction: column;
    justify-content: center;
    align-items: center;
    width: 100%;
    height: 50%;
}
.title {
    font-size: 31px;
    text-align: center;
    margin-top: 50%;
}
/* xxx.js */
export default {
  data: {
    defaultTime: "",
    time: "",
  },
  onInit() {
    this.defaultTime = this.now();
  },
  handleChange(data) {
    this.time = this.concat(data.hour, data.minute);
  },
  now() {
    const date = new Date();
    const hours = date.getHours();
    const minutes = date.getMinutes();
    return this.concat(hours, minutes);
  },
  fill(value) {
    return (value > 9 ? "" : "0") + value;
  },
  concat(hours, minutes) {
    return `${this.fill(hours)}:${this.fill(minutes)}`;
  },
}

日期选择器

<!-- xxx.hml -->
<div class="container">
    <text class="title">
        Selected:{{date}}
    </text>
    <picker-view class="time-picker" type="date" selected="{{defaultTime}}" @change="handleChange" lunarswitch="true"></picker-view>
</div>
/* xxx.css */
.container {
    flex-direction: column;
    justify-content: center;
    align-items: center;
    width: 100%;
    height: 50%;
}
.title {
    font-size: 31px;
    text-align: center;
    margin-top: 50%;
}
/* xxx.js */
export default {
    data: {
        date: "",
    },
    handleChange(data) {
        this.date = data.year + "年" + data.month + "月" + data.day + "日";
    },
}

日期时间选择器

<!-- xxx.hml -->
<div class="container">
    <text class="title">
        Selected:{{datetime}}
    </text>
    <picker-view class="date-picker" type="datetime"  hours="24" lunarswitch="true" @change="handleChange"></picker-view>
</div>
/* xxx.css */
.container {
    flex-direction: column;
    justify-content: center;
    align-items: center;
    width: 100%;
    height: 50%;
}
.title {
    font-size: 31px;
    text-align: center;
    margin-top: 50%;
}
/* xxx.js */
export default {
    data: {
        datetime: "",
    },
    handleChange(data) {
        this.datetime = data.year + "年" + data.month + "月" + data.day + "日" + data.hour + "时" + data.minute + "分";
    },
}

多列文本选择器

<!-- xxx.hml -->
<div class="container">
    <text class="title">
        Selected:{{ value }}
    </text>
    <picker-view class="multitype-picker" type="multi-text" columns="3" range="{{ multitext }}" @columnchange="handleChange"></picker-view>
</div>
/* xxx.css */
.container {
    flex-direction: column;
    justify-content: center;
    align-items: center;
    width: 100%;
    height: 50%;
}
.title {
    font-size: 31px;
    text-align: center;
    margin-top: 50%;
}
/* xxx.js */
export default {
    data: {
        multitext: [
            [1, 2, 3],
            [4, 5, 6],
            [7, 8, 9],
        ],
        value: ""
    },
    handleChange(data) {
        this.value = data.column + "列," + "值为" + data.newValue + ",下标为" + data.newSelected;
    },
}

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值