[HarmonyOS]——滑动选择器组件(Picker)

 一、基础介绍

 滑动选择器组件(Picker),在很多APP当中经常用来进行类别选别或者地址的选择。 

1、组件常用属性介绍

  •  value:设置默认选中的值
  • max_value:指定显示内容的最大值
  • min_value:指定显示内容的起始值
  • shader_color:着色器,修饰组件的颜色,从上下往中间渐变(由深到浅)
  • normal_text_size:未选中字体的大小
  • normal_text_color:未选中字体的颜色
  • selected_text_size:选中字体的大小
  • selected_text_color:选中字体的颜色
<?xml version="1.0" encoding="utf-8"?>
<DirectionalLayout
    xmlns:ohos="http://schemas.huawei.com/res/ohos"
    ohos:height="match_parent"
    ohos:width="match_parent"
    ohos:alignment="center"
    ohos:orientation="vertical">

    <!-- value:默认选中的值 -->
    <!-- shader_color:着色器,往中间渐变 -->
    <Picker
        ohos:id="$+id:picker"
        ohos:height="match_content"
        ohos:width="100vp"
        ohos:normal_text_size="30fp"
        ohos:selected_text_size="30fp"
        ohos:normal_text_color="#21a8fd"
        ohos:selected_text_color="#FF0000"
        ohos:max_value="6"
        ohos:min_value="0"
        ohos:value="3"
        ohos:shader_color="#00FF00"
        />
</DirectionalLayout>

 2、星期选择案例

星期选择案例中,组件的取值范围为0~6

public class MainAbilitySlice extends AbilitySlice {
    @Override
    public void onStart(Intent intent) {
        super.onStart(intent);
        super.setUIContent(ResourceTable.Layout_ability_main);

        //找到组件
        Picker picker = (Picker) findComponentById(ResourceTable.Id_picker);

        //存储星期1~7
        ArrayList<String> list = new ArrayList();
        list.add("星期一");
        list.add("星期二");
        list.add("星期三");
        list.add("星期四");
        list.add("星期五");
        list.add("星期六");
        list.add("星期日");

        //修改组件显示内容
//        picker.setFormatter(
//                new Picker.Formatter() {
//                    @Override
//                    public String format(int i) {
//                        //参数i:代表选中的数字
//                        //返回值就是要展示的内容
//                        return list.get(i);
//                    }
//                }
//        );

        //简化代码1
        //lamda表达式写法
//        picker.setFormatter(
//                (int i) -> {
//                    return list.get(i);
//                }
//        );

        //简化代码2
        //lamda继续优化1
        //当参数只有一个的时候,数据类型可以省略,雄安括号可以省略
//        picker.setFormatter(i -> list.get(i));

        //简化代码3
        //方法引用简化
        //用get当作抽象方法的方法体
        picker.setFormatter(list::get);
    }

    @Override
    public void onActive() {
        super.onActive();
    }

    @Override
    public void onForeground(Intent intent) {
        super.onForeground(intent);
    }

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
你可以通过封装自定义组件来实现 Uniapp 中的滑动选择器。以下是一个简单的封装示例: 1. 创建一个新的组件文件,比如 `CustomPicker.vue`。 2. 在 `CustomPicker.vue` 中,编写你的滑动选择器组件的模板代码,可以使用 `picker` 组件或者其他适合你需求的组件。 3. 在 `CustomPicker.vue` 中,为你的组件定义一个 `value` 属性和一个 `options` 属性,用于接收外部传入的值和选项。 4. 使用 `v-model` 来绑定 `value` 属性,以便可以双向绑定数据。 5. 在 `CustomPicker.vue` 中,监听滑动选择器的变化事件,并将选择的值通过自定义事件 `change` 发送出去。 6. 在外部使用滑动选择器组件时,导入并注册 `CustomPicker.vue` 组件。 7. 在外部使用滑动选择器组件时,通过 `v-model` 绑定选中的值,并通过 `@change` 监听值的变化。 下面是一个简单的示例代码: ```html <!-- CustomPicker.vue --> <template> <picker :value="value" @change="handleChange"> <picker-column v-for="option in options" :key="option">{{ option }}</picker-column> </picker> </template> <script> export default { props: { value: { type: [String, Number], default: '' }, options: { type: Array, default: [] } }, methods: { handleChange(e) { const { value } = e.detail; this.$emit('change', value); } } } </script> ``` 使用示例: ```html <template> <view> <custom-picker v-model="selectedValue" :options="pickerOptions" @change="handlePickerChange"></custom-picker> </view> </template> <script> import CustomPicker from './CustomPicker.vue'; export default { components: { CustomPicker }, data() { return { selectedValue: '', pickerOptions: ['Option 1', 'Option 2', 'Option 3'] } }, methods: { handlePickerChange(value) { console.log('Selected value:', value); } } } </script> ``` 以上示例中,`CustomPicker.vue` 组件封装了滑动选择器,并通过 `value` 属性接收选中的值,通过 `options` 属性接收选项列表。外部使用时,可以使用 `v-model` 来双向绑定选中的值,并通过 `@change` 监听值的变化。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Star星屹程序设计

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值