鸿蒙5.0实战案例:基于ArkUI的验证码实现

往期推文全新看点(文中附带全新鸿蒙5.0全栈学习笔录)

✏️ 鸿蒙(HarmonyOS)北向开发知识点记录~

✏️ 鸿蒙(OpenHarmony)南向开发保姆级知识点汇总~

✏️ 鸿蒙应用开发与鸿蒙系统开发哪个更有前景?

✏️ 嵌入式开发适不适合做鸿蒙南向开发?看完这篇你就了解了~

✏️ 对于大前端开发来说,转鸿蒙开发究竟是福还是祸?

✏️ 鸿蒙岗位需求突增!移动端、PC端、IoT到底该怎么选?

✏️ 记录一场鸿蒙开发岗位面试经历~

✏️ 持续更新中……


场景描述

场景一:基于自定义键盘的验证码实现,进入页面后直接输入验证码,第一个验证码输入完后可自动跳到下一个,拉起的键盘是自定义数字键盘,验证码的输入框带选中效果。

场景二:基于系统键盘的验证码实现,进入页面后直接输入验证码,第一个验证码输入完后可自动跳到下一个,验证码的输入框带选中效果。

方案描述

场景一:

基于自定义键盘的验证码实现,进入页面后直接输入验证码,第一个验证码输入完后可自动跳到下一个,拉起的键盘是自定义数字键盘,验证码的输入框带选中效果。

方案

每个验证码都是通过text实现的,而不是textInput。
在页面中写一个textInput将其隐藏,通过sendEventByKey方法将textInput的点击事件转移给text,同时给textInput绑定自定义键盘,这样点击text即可拉起自定义键盘。
将输入框的值赋值给text,通过text将其展示出来。

核心代码

1.写一个TextInput将其隐藏,给TextInput设置id后,在Text的点击事件中通过sendEventByKey方法将TextInput的点击事件转移到Text上,这样就可以点击Text拉起软键盘。

2.在onChange中对codeTxt进行赋值,将输入框的值赋给codeTxt,再通过codeTxt的下标进行展示。

3.对codeTxt进行监听,showMouse是一个布尔类型的数组,当前验证码处于输入状态时,将其值改为true,这样就可改变输入框的选中状态。

//展示在页面上的文本
@State @Watch('setValue') codeTxt: string = '';
@State Index: number[] = [0, 1, 2, 3, 4, 5]
//控制选中文本样式
@State showMouse: boolean[] = [];@Builder
buildAEnterCodeInput() {Flex({direction: FlexDirection.Row,alignItems: ItemAlign.Center,justifyContent: FlexAlign.SpaceBetween}) {Column(){Row(){//text将拿到的值进行逐个展示Text(this.codeTxt[0]).fontSize(18).fontWeight(600).textAlign(TextAlign.Center).width(50).height(50).margin({ left: 5, right: 5 })// .border({ width: 0.5, color:  Color.Grey ,style: BorderStyle.Solid })//设置验证码选中的样式.border(this.showMouse[this.Index[0]] ? this.btnCancelBorderActive : this.btnCancelBorder).borderRadius(5)……}.onClick(()=>{//通过sendEventByKey方法将输入框的点击事件转移给textsendEventByKey('TextInput',10,'')})//写一个输入框,将其隐藏TextInput({ controller: this.controller }).width('100%').height(100)// .zIndex(1).opacity(0).id('TextInput').customKeyboard(this.CustomKeyboardBuilder()).onChange((value) => {//将隐藏的输入框的value值赋值给codeTxt this.codeTxt = valueif (this.codeTxt.length >= 6) {return}})}}.backgroundColor(Color.White).height(50).margin({ left: 15, right: 15 }).id("customInput").defaultFocus(false)
}
//对codeTxt进行监听,
setValue() {if (this.codeTxt) {this.handelInputTxt(this.codeTxt.length, this.codeTxt);} else {this.handelInputTxt(0, '');}
}//改变输入框选中的值,showMouse是一个布尔类型的数组,当前验证码处于输入状态时,将其值改为true
handelInputTxt(length: number, val: string) {length === this.maxLength ? this.showMouse.fill(false) : this.showMouse.fill(false).splice(length - 1, 0, true);console.log('----length', length)console.info("----this.showMouse", JSON.stringify(this.showMouse));
}

设置的公共页面,点击即可拉起半模态。

//公共页面,点击即可拉起半模态
@Builder
buildTitleName() {CommonPage().onClick(() => {//模态弹窗是否展示this.isShow = true}).bindSheet($$this.isShow, this.bindSheetBuilder, {height: '70%',// detents:[SheetSize.MEDIUM,SheetSize.LARGE,500],// backgroundColor:Color.Gray,blurStyle: BlurStyle.Thick,showClose: false,// title:{title:""},preferType: SheetType.CENTER})……

场景二:

基于系统键盘的验证码实现,进入页面后直接输入验证码,第一个验证码输入完后可自动跳到下一个,验证码的输入框带选中效果。

方案

1.验证码均是通过六个text实现。

2.通过输入法框架拉起系统键盘,对系统键盘进行监听,即可做到输入和删除的效果。

3.进行条件判断,符合条件时就对输入法进行绑定和监听,否则就解绑输入法。

核心代码

展示在页面上的六个Text,通过输入法框架拉起键盘。

@Builder
buildAEnterCodeInput() {Flex({ direction: FlexDirection.Row, alignItems: ItemAlign.Center, justifyContent: FlexAlign.SpaceBetween }) {Text(this.codeTxt[0]).fontSize(18).fontWeight(600).textAlign(TextAlign.Center).width((this.screenWidth - 110) / 6).height("100%").margin({ left: 5, right: 5 }).border({width: 0.5,color:  Color.Grey ,style: BorderStyle.Solid}).borderRadius(5)}.backgroundColor(Color.White).height(50).margin({ left: 15, right: 15 }).id("customInput").defaultFocus(false).onVisibleAreaChange([0.0, 1.0], (isVisible: boolean, currentRatio: number) => {if (isVisible && currentRatio >= 1.0) {//绑定输入法this.attachAndListener();}if (!isVisible && currentRatio <= 0.0) {//解绑输入法this.dettach()}})//点击即通过输入法的控制拉起键盘.onClick(async () => {if (this.isAttached && this.keyboardStatus != 2) {// 输入法配置项let textConfig: inputMethod.TextConfig = {inputAttribute: {textInputType: inputMethod.TextInputType.NUMBER,enterKeyType: inputMethod.EnterKeyType.GO}};// 控件绑定输入法await this.inputController.attach(true, textConfig)return}})
}

实现思路:对输入法进行绑定和监听,通过输入法框架拉起软键盘,可以订阅输入法应用插入、删除文本事件等。

//解绑输入法
dettach() {this.inputController.off('insertText');this.inputController.off('deleteLeft');this.inputController.off('sendKeyboardStatus');this.inputController.detach((err: BusinessError) => {if (err) {console.error(`Failed to detach: ${JSON.stringify(err)}`);return;}this.isAttached = falseconsole.log('Succeeded in detaching inputMethod.');});
}// 绑定和设置监听
async attachAndListener() {// 输入法配置项let textConfig: inputMethod.TextConfig = {inputAttribute: {//拉起数字键盘textInputType: inputMethod.TextInputType.NUMBER,enterKeyType: inputMethod.EnterKeyType.GO}};// 控件绑定输入法await this.inputController.attach(true, textConfig)this.isAttached = truethis.attachListener()
}/*** 订阅输入法回调*/
attachListener(): void {// 订阅输入法应用插入文本事件this.inputController.on('insertText', (text) => {if (this.codeTxt.length >= 6) {return}  this.codeTxt += text;console.info("this.inputText", "insertText this.inputText===" + this.codeTxt)})// 订阅输入法应用向左删除事件this.inputController.on('deleteLeft', (length) => {this.codeTxt = this.codeTxt.substring(0, this.codeTxt.length - 1);console.info("this.inputText", "deleteLeft  this.inputText===" + this.codeTxt,'length'+length)})// 订阅输入法应用发送输入法软键盘状态事件this.inputController.on('sendKeyboardStatus', (keyboardStatus: inputMethod.KeyboardStatus) => {this.keyboardStatus = keyboardStatusconsole.info("ImsaKit this.inputText keyboardStatus= " + this.keyboardStatus)})
}

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

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

相关文章

Springboot + Ollama + IDEA + DeepSeek 搭建本地deepseek简单调用示例

1. 版本说明 springboot 版本 3.3.8 Java 版本 17 spring-ai 版本 1.0.0-M5 deepseek 模型 deepseek-r1:7b 需要注意一下Ollama的使用版本&#xff1a; 2. springboot项目搭建 可以集成在自己的项目里&#xff0c;也可以到 spring.io 生成一个项目 生成的话&#xff0c;如下…

Ubuntu 的RabbitMQ安装

目录 1.安装Erlang 查看erlang版本 退出命令 2. 安装 RabbitMQ 3.确认安装结果 4.安装RabbitMQ管理界面 5.启动服务并访问 1.启动服务 2.查看服务状态 3.通过IP:port 访问界面 4.添加管理员用户 a&#xff09;添加用户名&#xff1a;admin&#xff0c;密码&#xff1…

Powershell Install deepseek

前言 deepseekAI助手。它具有聊天机器人功能&#xff0c;可以与用户进行自然语言交互&#xff0c;回答问题、提供建议和帮助解决问题。DeepSeek 的特点包括&#xff1a; 强大的语言理解能力&#xff1a;能够理解和生成自然语言&#xff0c;与用户进行流畅的对话。多领域知识&…

VS Code 如何搭建C/C++开发环境

目录 1.VS Code是什么 2. VS Code的下载和安装 2.1 下载和安装 2.2.1 下载 2.2.2 安装 2.2 环境的介绍 2.3 安装中文插件 3. VS Code配置C/C开发环境 3.1 下载和配置MinGW-w64编译器套件 3.1.1 下载 3.1.2 配置 3.2 安装C/C插件 3.3 重启VSCode 4. 在VSCode上编写…

vue从入门到精通(十一):条件渲染

条件渲染 1.v-if 写法: (1).v-if“表达式” (2).v-else-if“表达式” (3).v-else“表达式” 适用于:切换频率较低的场景。 特点:不展示的DOM元素直接被移除。 注意:v-if可以和:v-else-if、v-else一起使用&#xff0c;但要求结构不能被“打断” 2.v-show 写法:v-show“…

Java之——“String类”(内容较多,结合目录察看分类)

前言 在C语言中已经涉及到字符串了&#xff0c;但是在C语言中要表示字符串只能使用字符数组或者字符指针&#xff0c;可以使用标准库提供的字符串系列函数完成大部分操作&#xff0c;但是这种将数据和操作数据方法分离开的方式不符合面向对象的思想&#xff0c;而字符串应用又…

【C++篇】树影摇曳,旋转无声:探寻AVL树的平衡之道

文章目录 从结构到操作&#xff1a;手撕AVL树的实现一、AVL树介绍1.1 什么是AVL树1.2 平衡因子的定义1.3 平衡的意义1.4 AVL树的操作 二、AVL树的节点结构2.1 节点结构的定义&#xff1a; 三、插入操作3.1 插入操作概述3.2 步骤1&#xff1a;按二叉查找树规则插入节点3.3 步骤2…

限制Doris端口访问,解决REST API漏洞

方案一&#xff1a;通过Linux防火墙规则限制 目标&#xff1a;限制Doris的端口&#xff0c;只允许指定的ip访问此端口&#xff0c;其他禁止 1、设置规则 1.1、准备工作 注意&#xff1a;以上命令顺序不能错&#xff0c;先禁止后允许&#xff0c;另外此处只是临时设置。 # …

本地部署MindSearch(开源 AI 搜索引擎框架),然后上传到 hugging face的Spaces——L2G6

部署MindSearch到 hugging face Spaces上——L2G6 任务1 在 官方的MindSearch页面 复制Spaces应用到自己的Spaces下&#xff0c;Space 名称中需要包含 MindSearch 关键词&#xff0c;请在必要的步骤以及成功的对话测试结果当中 实现过程如下&#xff1a; 2.1 MindSearch 简…

蓝桥杯15 填空题

1.握手问题&#xff1a; 思路&#xff1a;首先当所有人都握过手&#xff0c;由于一次握手相当于两个人都握手过&#xff0c;所以容易发现这是一个组合问题&#xff0c;为&#xff08;50*49&#xff09;/2&#xff0c;而其中有7个人没有相互握过手&#xff0c;那么减去&#xff…

SSH/RDP 无法访问?云服务器让远程管理更简单

在日常运维和管理云服务器时&#xff0c;远程连接&#xff08;SSH 访问 Linux 服务器&#xff0c;RDP 访问 Windows 服务器&#xff09;是不可或缺的操作。然而&#xff0c;不少用户在使用阿里云 ECS 或其他云服务器时&#xff0c;会遇到远程连接失败、超时或拒绝访问的问题&am…

【OS安装与使用】part6-ubuntu 22.04+CUDA 12.4运行MARL算法(多智能体强化学习)

文章目录 一、待解决问题1.1 问题描述1.2 解决方法 二、方法详述2.1 必要说明2.2 应用步骤2.2.1 下载源码并安装2.2.2 安装缺失的依赖项2.2.3 训练执行MAPPO算法实例 三、疑问四、总结 一、待解决问题 1.1 问题描述 已配置好基础的运行环境&#xff0c;尝试运行MARL算法。 1…

Flutter - 初体验

项目文件目录结构介绍 注&#xff1a;创建 Flutter 项目名称不要包含特殊字符&#xff0c;不要使用驼峰标识 // TODO 开发中运行一个 Flutter 三种启动方式 Run 冷启动从零开始启动Hot Reload 热重载执行 build 方法Hot Restart 热重启重新运行整个 APP 先看效果&#xff0c…

vue 手写分页

【先看效果】 &#xff08;1&#xff09;内容小于2页 不展示页码 &#xff08;2&#xff09;1 < 内容页数< 限定展示页码 展示&#xff1a;页码、上下页&#xff1b;隐藏&#xff1a;首页、末页图标&#xff0c;上、下一区间码。即&#xff1a;&#xff08;页数&#…

window安装MySQL5.7

1、下载MySQL5.7.24 浏览器打开&#xff1a; https://dev.mysql.com/get/Downloads/MySQL-5.7/mysql-5.7.24-winx64.zip 2、解压缩 下载下来的是一个压缩包&#xff0c;解压到你想放到的目录下面&#xff0c;我放的是“C:\MySQL” 3、配置MySQL环境变量 计算机右键 - 属性 …

Android Studio安装配置及运行

一、下载Android Studio 官网下载&#xff1a;下载 Android Studio 和应用工具 - Android 开发者 | Android Developers 跳转到下载界面&#xff0c;选择同意条款&#xff0c;并点击下载&#xff0c;如图&#xff1a; 二、详细安装 双击下载的文件 三、配置Android Studio …

电力通信物联网应用,国密网关守护电力数据安全

电力国密网关是用于保护电力调度数据网路由器和电力系统的局域网之间通信安全的电力专用网关机&#xff0c;主要为上下级控制系统之间的广域网通信提供认证与加密服务&#xff0c;实现数据传输的机密性、完整性。 国密算法网关功能特点 身份认证&#xff1a;对接入的设备和用户…

低代码与开发框架的一些整合[2]

1.分析的项目资源说明 经过近期的的不断分析与运行对比&#xff0c;最终把注意力集中在了以下几个框架&#xff1a; 01.dibootdiboot.diboot: 写的更少, 性能更好 -> 为开发人员打造的低代码开发平台。Mybatis-plus关联查询&#xff0c;关联无SQL&#xff0c;性能高10倍&a…

帆软报表FineReport入门:简单报表制作[扩展|左父格|上父格]

FineReport帮助文档 - 全面的报表使用教程和学习资料 数据库连接 点击号>>JDBC 选择要连接的数据库>>填写信息>>点击测试连接 数据库SQLite是帆软的内置数据库, 里面有练习数据 选择此数据库后,点击测试连接即可 数据库查询 方法一: 在左下角的模板数据集…

elf_loader:一个使用Rust编写的ELF加载器

本文介绍一个使用Rust实现的ELF加载器。 下面是elf_loader的仓库链接&#xff1a; github&#xff1a; https://github.com/weizhiao/elf_loaderhttps://github.com/weizhiao/elf_loader crates.io&#xff1a; https://crates.io/crates/elf_loaderhttps://crates.io/cra…