3.10【HarmonyOS鸿蒙开发】组件DatePicker

3.10【HarmonyOS鸿蒙开发】组件DatePicker

作者:韩茹

公司:程序咖(北京)科技有限公司

鸿蒙巴士专栏作家

DatePicker主要供用户选择日期。

一、支持的XML属性

DatePicker的共有XML属性继承自:StackLayout

DatePicker的自有XML属性见下表:

属性名称中文描述取值取值说明使用案例
date_order显示格式,年月日0表示日期以日-月-年的格式显示。ohos:date_order=“0”
1表示日期以月-日-年的格式显示。
2表示日期以年-月-日的格式显示。
3表示日期以年-日-月的格式显示。
4表示日期以日-月的格式显示。
5表示日期以月-日的格式显示。
6表示日期以年-月的格式显示。
7表示日期以月-年的格式显示。
8表示只显示年份。
9表示只显示月份。
10表示只显示日期。
day_fixed日期是否固定boolean类型可以直接设置true/false,也可以引用boolean资源。ohos:day_fixed=“true"ohos:day_fixed=”$boolean:true"
month_fixed月份是否固定boolean类型可以直接设置true/false,也可以引用boolean资源。ohos:month_fixed=“true"ohos:month_fixed=”$boolean:true"
year_fixed年份是否固定boolean类型可以直接设置true/false,也可以引用boolean资源。ohos:year_fixed=“true"ohos:year_fixed=”$boolean:true"
max_date最大日期long类型可以直接设置长整型值,也可以引用string资源。ohos:time=“1234567"ohos:time=”$string:date"
min_date最小日期long类型可以直接设置长整型值,也可以引用string资源。ohos:time=“1234567"ohos:time=”$string:date"
text_size文本大小float类型表示尺寸的float类型。可以是浮点数值,其默认单位为px;也可以是带px/vp/fp单位的浮点数值;也可以引用float资源。ohos:text_size=“30"ohos:text_size=“16fp"ohos:text_size=”$float:size_value”
normal_text_size取消选中文本的大小float类型表示尺寸的float类型。可以是浮点数值,其默认单位为px;也可以是带px/vp/fp单位的浮点数值;也可以引用float资源。ohos:normal_text_size=“30"ohos:normal_text_size=“16fp"ohos:normal_text_size=”$float:size_value”
selected_text_size选中文本的大小float类型表示尺寸的float类型。可以是浮点数值,其默认单位为px;也可以是带px/vp/fp单位的浮点数值;也可以引用float资源。ohos:selected_text_size=“30"ohos:selected_text_size=“16fp"ohos:selected_text_size=”$float:size_value”
normal_text_color取消选中文本的颜色color类型可以直接设置色值,也可以引用color资源。ohos:normal_text_color="#A8FFFFFF"ohos:normal_text_color="$color:black"
selected_text_color选中文本的颜色color类型可以直接设置色值,也可以引用color资源。ohos:selected_text_color="#A8FFFFFF"ohos:selected_text_color="$color:black"
operated_text_color操作项的文本颜色color类型可以直接设置色值,也可以引用color资源。ohos:operated_text_color="#A8FFFFFF"ohos:operated_text_color="$color:black"
selected_normal_text_margin_ratio已选文本边距与正常文本边距的比例float类型可以直接设置浮点数值,也可以引用float浮点数资源。取值需>0.0f,默认值为1.0f。ohos:selected_normal_text_margin_ratio=“0.5"ohos:selected_normal_text_margin_ratio=”$float:ratio"
selector_item_num显示的项数integer类型可以直接设置整型数值,也可以引用integer资源。ohos:selector_item_num=“10"ohos:selector_item_num=”$integer:num"
shader_color着色器颜色color类型可以直接设置色值,也可以引用color资源。ohos:shader_color="#A8FFFFFF"ohos:shader_color="$color:black"
top_line_element选中项的顶行Element类型可直接配置色值,也可引用color资源或引用media/graphic下的图片资源。ohos:top_line_element="#FFFFFFFF"ohos:top_line_element=“ c o l o r : b l a c k " o h o s : t o p l i n e e l e m e n t = " color:black"ohos:top_line_element=" color:black"ohos:toplineelement="media:media_src"ohos:top_line_element=”$graphic:graphic_src"
bottom_line_element选中项的底线Element类型可直接配置色值,也可引用color资源或引用media/graphic下的图片资源。ohos:bottom_line_element="#FFFFFFFF"ohos:bottom_line_element=“ c o l o r : b l a c k " o h o s : b o t t o m l i n e e l e m e n t = " color:black"ohos:bottom_line_element=" color:black"ohos:bottomlineelement="media:media_src"ohos:bottom_line_element=”$graphic:graphic_src"
wheel_mode_enabled选择轮是否绕行boolean类型可以直接设置true/false,也可以引用boolean资源。ohos:wheel_mode_enabled=“true"ohos:wheel_mode_enabled=”$boolean:true"

二、使用DatePicker

1、在XML中创建DatePicker

<DatePicker
        ohos:id="$+id:date_pick"
        ohos:height="match_content"
        ohos:width="300vp"
        ohos:background_element="#22AA0000"
        >

创建默认的DatePicker:

datepickeryunxing1

2、获取当前选择日期,日/月/年,DatePicker默认选择当前日期。

				// 获取DatePicker实例
        DatePicker datePicker = (DatePicker) findComponentById(ResourceTable.Id_date_pick);
        int day = datePicker.getDayOfMonth();
        int month = datePicker.getMonth();
        int year = datePicker.getYear();

				System.out.println("day:"+day+",month:"+month+",year:"+year);

我们是可以获取到年月日信息的:

WX20210617-095920@2x

3、响应日期改变事件:

在XML中添加Text显示选择日期:

<Text
        ohos:id="$+id:text_date"
        ohos:height="match_content"
        ohos:width="match_parent"
        ohos:hint="date"
        ohos:text_alignment="center"
        ohos:margin="10vp"
        ohos:padding="4vp"
        ohos:text_color="#AA0000"
        ohos:text_size="20fp">

在Java代码中响应日期改变事件:

Text selectedDate = (Text) findComponentById(ResourceTable.Id_text_date);
        datePicker.setValueChangedListener(
                new DatePicker.ValueChangedListener() {
                    @Override
                    public void onValueChanged(DatePicker datePicker, int year, int monthOfYear, int dayOfMonth) {
                        // 格式化显示字符串
                        selectedDate.setText(String.format("%02d/%02d/%4d", dayOfMonth, monthOfYear, year));
                    }
                }
        );

日期改变响应效果:

datepickeryunxing2

4、设置当前日期

datePicker.updateDate(2021, 8, 8);

设置当前日期效果:

WX20210617-100722@2x

5、设置日期的范围

如需对DatePicker的日期选择范围有要求,可以设置属性min_date和max_date。设置的值为日期对应的Unix时间戳

设置最小日期:

<DatePicker
    ...
    ohos:min_date="1623895868">
</DatePicker>

或者在代码中设置:

datePicker.setMinDate(1623895868);

设置最小日期为2021/06/17:

WX20210617-101331@2x

设置最大日期:

在XML中设置:

<DatePicker
    ...
    ohos:max_date="1630339200">
</DatePicker>

在代码中设置:

datePicker.setMaxDate(1630339200);

设置最大日期为2021/08/31:

WX20210617-101545@2x

固定年/月/日

在XML中设置:

<DatePicker
    ...
    ohos:year_fixed="true">
</DatePicker>

在代码中设置:

datePicker.setYearFixed(true);

三、样式设置

1、文本相关属性

设置待选项的字体大小和颜色

<DatePicker
    ...
    ohos:normal_text_color="#00FFFF"
    ohos:normal_text_size="20fp">
</DatePicker>

设置待选项的字体大小和颜色效果:

WX20210617-101925@2x

设置已选项的字体大小和颜色

在XML中设置:

<DatePicker
    ...
    ohos:selected_text_color="#FF00FF"
    ohos:selected_text_size="20fp">
</DatePicker>

在代码中设置:

datePicker.setSelectedTextSize(40);
datePicker.setSelectedTextColor(new Color(Color.getIntColor("#FF00FF")));

设置已选项的字体大小和颜色效果:

WX20210617-102110@2x

设置操作项的字体颜色

在XML中设置:

<DatePicker
    ...
    ohos:operated_text_color="#FFA500">
</DatePicker>

在代码中设置:

datePicker.setOperatedTextColor(new Color(Color.getIntColor("#FFA500")));

设置操作项的字体颜色效果

datepickeryunxing3

2、设置DatePicker中所选文本边距与普通文本边距的比例

在XML中设置:

<DatePicker
    ...
    ohos:selected_normal_text_margin_ratio="10">
</DatePicker>

在代码中设置:

datePicker.setSelectedNormalTextMarginRatio(10.0f)

已选文本边距与正常文本边距比例设置为10的效果图:

WX20210617-102814@2x

3、设置滚轮绕行

在XML中设置:

<DatePicker
    ...
    ohos:wheel_mode_enabled="true">
</DatePicker>

在代码中设置:

datePicker.setWheelModeEnabled(true);

滚轮绕行效果:

WX20210617-104346@2x

4、设置选中日期的上下边框

在XML中设置:

<DatePicker
    ...
    ohos:top_line_element="#9370DB"
    ohos:bottom_line_element="#9370DB">
</DatePicker>

在代码中设置:

ShapeElement shape = new ShapeElement();
shape.setShape(ShapeElement.RECTANGLE);
shape.setRgbColor(RgbColor.fromArgbInt(0xFF9370DB));
datePicker.setDisplayedLinesElements(shape,shape);

添加选中项上下边框效果:

WX20210617-104511@2x

5、设置着色器颜色

在XML中设置:

<DatePicker
    ...
    ohos:shader_color="gray">
</DatePicker>

在代码中设置:

datePicker.setShaderColor(new Color(Color.getIntColor("#00CED1")));

设置着色器颜色效果:

WX20210617-104637@2x

更多内容:

1、社区:鸿蒙巴士https://www.harmonybus.net/

2、公众号:HarmonyBus

3、技术交流QQ群:714518656

4、视频课:https://www.chengxuka.com

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
antd的DatePicker组件也可以通过类似的方式实现清空功能。antd的DatePicker组件提供了一个allowClear属性,设置为true时就可以显示清空按钮。在清空按钮的点击事件中,可以将DatePicker组件的值设置为null或默认值。 示例代码: ``` import React, { useState } from 'react'; import { DatePicker } from 'antd'; function App() { const [date, setDate] = useState(null); const handleClear = () => { setDate(null); }; return ( <> <DatePicker value={date} onChange={value => setDate(value)} allowClear /> <button onClick={handleClear}>清空</button> </> ); } export default App; ``` 在这个示例中,另一个需要注意的点是,antd的DatePicker组件的值是一个Moment.js对象,而不是一个Date对象。因此,在onChange事件中获取到的value是一个Moment.js对象。如果需要将其转换为Date对象,可以使用toDate方法,例如:value.toDate()。 另外,antd的DatePicker组件还提供了一个ref属性,可以通过获取到这个ref来调用DatePicker组件的方法,包括clear方法。使用方式与React中的示例类似。 示例代码: ``` import React, { useRef } from 'react'; import { DatePicker } from 'antd'; function App() { const datePickerRef = useRef(null); const handleClear = () => { datePickerRef.current.clear(); }; return ( <> <DatePicker ref={datePickerRef} allowClear /> <button onClick={handleClear}>清空</button> </> ); } export default App; ``` 以上是在React中使用antd的DatePicker组件实现清空功能的方法,可以根据实际需要选择适合自己的方式。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值