27. Harmonyos Next仿uv-ui 组件NumberBox 步进器组件禁用状态

温馨提示:本篇博客的详细代码已发布到 git : https://gitcode.com/nutpi/HarmonyosNext 可以下载运行哦!

文章目录

    • 1. 组件介绍
    • 2. 效果展示
    • 3. 禁用状态设置
      • 3.1 整体禁用
      • 3.2 输入框禁用
      • 3.3 长按禁用
    • 4. 完整示例代码
    • 5. 知识点讲解
      • 5.1 禁用状态属性
      • 5.2 禁用状态的样式处理
      • 5.3 禁用状态的交互处理
      • 5.4 禁用状态的应用场景
    • 6. 总结

1. 组件介绍

NumberBox步进器组件提供了多种禁用状态的设置,包括整体禁用、输入框禁用和长按禁用,可以根据不同场景的需求来控制用户的交互行为。本文将详细介绍如何在HarmonyOS NEXT中设置和使用NumberBox步进器的禁用状态功能。

2. 效果展示

3. 禁用状态设置

3.1 整体禁用

通过disabled属性可以禁用整个NumberBox组件:

NumberBox({value: this.value,disabled: true,  // 禁用整个组件onChange: (value: number) => {this.value = value;}
})

3.2 输入框禁用

通过disableInput属性可以只禁用输入框,保留按钮的功能:

NumberBox({value: this.value,disableInput: true,  // 禁用输入框onChange: (value: number) => {this.value = value;}
})

3.3 长按禁用

通过disableLongPress属性可以禁用长按增减功能:

NumberBox({value: this.value,disableLongPress: true,  // 禁用长按功能onChange: (value: number) => {this.value = value;}
})

4. 完整示例代码

下面是一个展示不同禁用状态的完整示例:

// NumberBoxDisabledDemo.ets
// NumberBox步进器禁用状态示例import { NumberBox } from '../components/NumberBox';@Entry
@Component
struct NumberBoxDisabledDemo {@State value1: number = 5;  // 正常状态@State value2: number = 5;  // 整体禁用@State value3: number = 5;  // 输入框禁用@State value4: number = 5;  // 长按禁用build() {Column() {// 标题Text('NumberBox 禁用状态示例').fontSize(20).fontWeight(FontWeight.Bold).margin({ bottom: 20 })// 正常状态Row() {Text('正常状态').width('40%').fontSize(16)NumberBox({value: this.value1,onChange: (value: number) => {this.value1 = value;}})}.width('100%').justifyContent(FlexAlign.SpaceBetween).alignItems(VerticalAlign.Center).padding(10)// 整体禁用Row() {Text('整体禁用').width('40%').fontSize(16)NumberBox({value: this.value2,disabled: true,  // 禁用整个组件onChange: (value: number) => {this.value2 = value;}})}.width('100%').justifyContent(FlexAlign.SpaceBetween).alignItems(VerticalAlign.Center).padding(10)// 输入框禁用Row() {Text('输入框禁用').width('40%').fontSize(16)NumberBox({value: this.value3,disableInput: true,  // 禁用输入框onChange: (value: number) => {this.value3 = value;}})}.width('100%').justifyContent(FlexAlign.SpaceBetween).alignItems(VerticalAlign.Center).padding(10)// 长按禁用Row() {Text('长按禁用').width('40%').fontSize(16)NumberBox({value: this.value4,disableLongPress: true,  // 禁用长按功能onChange: (value: number) => {this.value4 = value;}})}.width('100%').justifyContent(FlexAlign.SpaceBetween).alignItems(VerticalAlign.Center).padding(10)// 显示当前值Column() {Text('当前值:').fontSize(16).fontWeight(FontWeight.Bold).margin({ top: 20, bottom: 10 })Text('正常状态值: ' + this.value1).fontSize(14).margin({ bottom: 5 })Text('整体禁用值: ' + this.value2).fontSize(14).margin({ bottom: 5 })Text('输入框禁用值: ' + this.value3).fontSize(14).margin({ bottom: 5 })Text('长按禁用值: ' + this.value4).fontSize(14)}.width('100%').alignItems(HorizontalAlign.Center).margin({ top: 20 })}.width('100%').padding(16)}
}

5. 知识点讲解

5.1 禁用状态属性

NumberBox组件提供了三种禁用状态的属性:

  1. disabled:禁用整个组件,包括按钮和输入框。
  2. disableInput:只禁用输入框,保留按钮功能。
  3. disableLongPress:禁用长按增减功能,但保留点击功能。

5.2 禁用状态的样式处理

NumberBox组件会根据禁用状态自动调整UI样式:

// 按钮禁用样式
.opacity(this.disabled ? 0.5 : 1.0)
.enabled(!this.disabled)// 输入框禁用样式
.backgroundColor(this.disabled ? '#F5F7FA' : '#FFFFFF')
.enabled(!this.disabled && !this.disableInput)

5.3 禁用状态的交互处理

  1. 整体禁用

    • 按钮变灰且不可点击
    • 输入框变灰且不可输入
    • 长按功能无效
  2. 输入框禁用

    • 按钮正常工作
    • 输入框变灰且不可输入
    • 长按功能正常
  3. 长按禁用

    • 按钮点击功能正常
    • 输入框正常工作
    • 长按时不会连续增减

5.4 禁用状态的应用场景

不同的禁用状态适用于不同的场景:

  1. 整体禁用

    • 数据加载中
    • 权限不足
    • 系统维护
  2. 输入框禁用

    • 只允许通过按钮调整
    • 防止手动输入错误
    • 精确控制数值变化
  3. 长按禁用

    • 需要精确控制的场景
    • 防止误操作
    • 特殊业务限制

6. 总结

本文详细介绍了NumberBox步进器组件的禁用状态功能。通过合理使用disabled、disableInput和disableLongPress属性,可以实现不同级别的交互控制,满足各种业务场景的需求。禁用状态不仅体现在功能的限制上,还包括视觉反馈的处理,为用户提供清晰的操作指引。

在实际应用中,应根据具体的业务需求选择合适的禁用状态,并注意提供适当的用户提示,以提升用户体验。同时,禁用状态的设置也应考虑到整体的交互流程,确保应用的可用性和易用性。

在下一篇文章中,我们将介绍NumberBox组件的样式定制功能,包括如何自定义按钮颜色、图标和尺寸等。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/897507.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Shardingsphere-jdbc 自定义脱敏规则

添加邮件脱敏规则: // 123123123qq.com,将前4个字符脱敏 12312****qq.com 代码重写MaskAlgorithm相关方法: /** Licensed to the Apache Software Foundation (ASF) under one or more* contributor license agreements. See the NOTICE…

大模型在甲状腺良性肿瘤诊疗全流程中的应用研究报告

目录 一、引言 1.1 研究背景与目的 1.2 研究意义与价值 二、甲状腺良性肿瘤概述 2.1 疾病介绍 2.2 流行病学特征 2.3 传统诊疗方法综述 三、大模型技术原理及应用优势 3.1 大模型技术简介 3.2 在医疗领域的应用进展 3.3 针对甲状腺良性肿瘤的应用优势 四、大模型在…

软件IIC和硬件IIC的主要区别,用标准库举例!

学习交流792125321,欢迎一起加入讨论! 在学习iic的时候,我们经常会遇到软件 IC和硬件 IC,它两到底有什么区别呢? 软件 IC(模拟 IC)和硬件 IC(外设 IC)是两种实现 IC 总线通信的方式…

店匠科技携手 PayPal 升级支付体验,助力独立站商家实现全球增长

在全球化电商竞争加剧的背景下,独立站为无数商户插上了通向事业成功的翅膀。然而,搭建店铺框架容易,真正实现有效运营却充满挑战。只有当各个环节如齿轮般严丝合缝,独立站运营才能更好地助推行进,实现稳健增长。如今,独立站商家面临着全链路运营的多重挑战。从品牌塑造、营销推…

密码学 网络安全 科普 网络安全密码技术

网络加密包括密码技术和网络加密方法两个方面。 一、 密码技术   密码技术一般分为常规密码和公钥密码。   常规密码是指收信方和发信方使用相同的密钥,即加密密钥和解密密钥是相同或等价的。比较著名的常规密码算法有DES及其各种变形、IDEA、FEAL、Skipjack…

P8686 [蓝桥杯 2019 省 A] 修改数组--并查集 or Set--lower_bound()的解法!!!

P8686 [蓝桥杯 2019 省 A] 修改数组--并查集 题目 并查集解析代码【并查集解】 Set 解法解析lower_bound代码 题目 并查集解析 首先先让所有的f(i)i,即每个人最开始的祖先都是自己,然后就每一次都让轮到那个数的父亲1&#xff08…

Anaconda中虚拟环境安装g++和gcc相同版本

安装torchSDF的时候遇到的,这是g和gcc版本不一致的问题 gcc: fatal error: cannot execute cc1plus: execvp: No such file or directory compilation terminated.查看gcc, g版本 gcc --version | head -n1 g --version | head -n1发现gcc的是anaconda中的&#x…

C++编程:进阶阶段—4.2对象

目录 4.2 对象特征 4.2.1 构造函数和析构函数 4.2.2 构造函数的分类 4.2.3 拷贝函数调用时机 4.2.4 构造函数调用规则 4.2.5 深拷贝与浅拷贝 4.2.6 初始化列表 4.2.7 类对象作为类成员 4.2.8 静态成员 4.2.9 成员变量和成员函数的存储 4.2.10 this指针 4.2.11 空指针…

【MySQL_04】数据库基本操作(用户管理--配置文件--远程连接--数据库信息查看、创建、删除)

文章目录 一、MySQL 用户管理1.1 用户管理1.11 mysql.user表详解1.12 添加用户1.13 修改用户权限1.14 删除用户1.15 密码问题 二、MySQL 配置文件2.1 配置文件位置2.2 配置文件结构2.3 常用配置参数 三、MySQL远程连接四、数据库的查看、创建、删除4.1 查看数据库4.2 创建、删除…

配置 Thunderbird 以使用 outlook 邮箱

配置 Thunderbird 以使用 outlook 邮箱 thunder bird 作为邮件客户端非常好用,不用每次登录邮箱网页端查看邮件,直接打开配置好的 thunder bird 即可免登录查看邮件。 0. 什么是 Thunder Bird ? https://www.thunderbird.net/zh-CN/ Thunderbird 创立…

边缘计算的业务种类划分

Pcdn的业务可以根据不同的分类标准来划分 一、按线路类型划分 汇聚模式:一个地方有多条线路,业务种类较多。通常使用X86或X99主板组装的服务器,或各品牌的准系统服务器。收益通常比单线模式更高。 单线模式:一个地方只有一条线路&…

服务器数据恢复—raid5阵列中硬盘出现坏道的数据恢复流程

服务器故障情况: 某公司一台服务器中有一组多块硬盘组成的磁盘阵列。磁盘阵列中有2块硬盘出现故障离线,服务器崩溃,上层数据丢失。 硬件检测: 硬件工程师对客户服务器内的所有硬盘进行物理故障检测,最终确认这2块硬盘…

Linux:多线程(三.POSIX信号量、生产消费模型、线程池)

目录 1. 生产者消费者模型 1.1 阻塞队列(BlockingQueue) 1.2 一个实际应用的例子 2. POSIX信号量 2.1 引入 2.2 回顾加深理解信号量 2.3 信号量的操作接口 3. 基于循环队列的生产消费模型 3.1 循环队列 3.2 整个项目 4. 线程池 4.1 概念 4.2 线程池实现 1. 生产者…

关于前后端整合和打包成exe文件的个人的总结和思考

前言 感觉有很多东西,不知道写什么,随便写点吧。 正文 前后端合并 就不说怎么开发的,就说点个人感觉重要的东西。 前端用ReactViteaxios随便写一个demo,用于CRUD。 后端用Django REST Framework。 设置前端打包 import { …

Android15 Camera框架中的StatusTracker

StatusTracker介绍 StatusTracker是Android15 Camera框架中用来协调Camera3各组件之间状态转换的类。 StatusTracker线程名:std::string("C3Dev-") mId "-Status" Camera3 StatusTracker工作原理 StatusTracker实现批处理(状态…

利用OpenResty拦截SQL注入

需求 客户的一个老项目被相关部门检测不安全,报告为sql注入。不想改代码,改项目,所以想到利用nginx去做一些数据校验拦截。也就是前端传一些用于sql注入的非法字符或者数据库的关键字这些,都给拦截掉,从而实现拦截sql…

警惕AI神话破灭:深度解析大模型缺陷与禁用场景指南

摘要 当前AI大模型虽展现强大能力,但其本质缺陷可能引发系统性风险。本文从认知鸿沟、数据困境、伦理雷区、技术瓶颈四大维度剖析大模型局限性,揭示医疗诊断、法律决策等8类禁用场景,提出可信AI建设框架与用户防护策略。通过理论分析与实操案…

颠覆语言认知的革命!神经概率语言模型如何突破人类思维边界?

颠覆语言认知的革命!神经概率语言模型如何突破人类思维边界? 一、传统模型的世纪困境:当n-gram遇上"月光族难题" 令人震惊的案例:2012年Google语音识别系统将 用户说:“我要还信用卡” 系统识别&#xff…

【Linux】详谈 基础I/O

目录 一、理解文件 狭义的理解: 广义理解: 文件操作的归类认知 系统角度 二、系统文件I/O 2.1 标志位的传递 系统级接口open ​编辑 open返回值 写入文件 读文件 三、文件描述符 3.1(0 & 1 & 2) 3.2 文件描…

超分之DeSRA

Desra: detect and delete the artifacts of gan-based real-world super-resolution models.DeSRA:检测并消除基于GAN的真实世界超分辨率模型中的伪影Xie L, Wang X, Chen X, et al.arXiv preprint arXiv:2307.02457, 2023. 摘要 背景: GAN-SR模型虽然…