Uniapp踩坑input自动获取焦点ref动态获取实例不可用

前言

大家好我是没钱的君子下流坯,用自己的话解释自己的知识。很久很更新了,这几个月一直在加班,今天记录一个uniapp关于input中focus()方法自动获取焦点的坑。

案例

为了实现一个手机验证码的页面,验证码是五个输入框,输入第一个输入框后焦点自动获取到下一个输入框的焦点如图所示:在这里插入图片描述

实现思路

我的思路是给每个输入框动态绑定一个ref实例去调用实例上的focus()方法,我第一次的代码也是这样写的代码如下所示:

<template>
  <view class="container">
    <view class="otp-container">
      <input
        v-for="(item, index) in otpLength"
        :key="index"
        type="tel"
        maxlength="1"
        @input="onInput($event, index)"
        @focus="onFocus(index)"
        :ref="`input-${index}`"
        class="otp-input"
      />
    </view>
    <button @click="submitOTP">提交</button>
  </view>
</template>

<script>
export default {
  data() {
    return {
      otpLength: 5,         // 验证码的长度
      otpValues: ['', '', '', '', ''],  // 存储每个输入框的值
      activeIndex: null     // 当前聚焦的输入框索引
    };
  },
  methods: {
    onInput(event, index) {
      const value = event.target.value;
      this.$set(this.otpValues, index, value);  // 更新对应输入框的值

      if (value && index < this.otpLength - 1) {
        this.$nextTick(() => {
          this.focusNextInput(index + 1);  // 自动跳转到下一个输入框
        });
      }
    },
    onFocus(index) {
      this.activeIndex = index;  // 记录当前聚焦的输入框索引
    },
    focusNextInput(index) {
      console.log(`Trying to focus input-${index}`);
      console.log('this.$refs:', this.$refs);
      const ref = this.$refs[`input-${index}`];
      if (ref && Array.isArray(ref) && ref.length > 0) {
        ref[0].focus();  // 确保引用存在再调用 focus 方法
      } else {
        console.error(`Reference for input-${index} not found or invalid`, ref);
      }
    },
    submitOTP() {
      const otp = this.otpValues.join('');  // 将所有输入框的值拼接成一个字符串
      console.log('提交的验证码:', otp);  // 打印验证码
      // 这里可以添加提交验证码的逻辑
    }
  }
};
</script>

尝试方法1加判断排除DOM渲染

但是一直报错说 "TypeError: this.$refs["input-".concat(...)][0].focus is not a function" 我心想这怎么可能不是个函数难道未定义,我就抓紧打印ref发现是有这个实例的,当时就没多想又对代码进行了检查然后加了判断,考虑可能是没获取到实例或者dom没渲染出来,因为前面的input是通过v-for循环的所以进行了更全面的判断代码如下所示

    focusNextInput(index) {
      console.log(`Trying to focus input-${index}`);
      const ref = this.$refs[`input-${index}`];
 this.$nextTick(() => {
             // 检查 ref 是否存在
      if (Array.isArray(ref) && ref.length > 0 && ref[0].focus) {
        ref[0].focus();  // 如果是数组形式,使用 ref[0] 并调用 focus
      } else if (ref && ref.focus) {
        ref.focus();  // 如果直接是 DOM 元素也调用 focus
      } else {
        console.error(`Reference for input-${index} not found or invalid`, ref);
      }
        });

    },

尝试方法2查看ref实例用ref上的方法

发现报错还是"TypeError: this.$refs["input-".concat(...)][0].focus is not a function"我就懵逼了。发现不是代码的问题,问题肯定是出现在了ref实例上,我就仔细的看ref实例里面的所有方法如下图所示
在这里插入图片描述
发现里没有focus()我想这一次可算找到根本了一次解决直接换成_focus()方法,发现是不报错了但是效果没有,我又换成_onFocus()方法发现也是不报错但是效果没有。到此时为止没有任何思路。

尝试方法3通过uniapp自带获取dom节点

中午吃了饭以后,我想为什么在uniapp中ref实例里面的方法不能用,那我通过uniapp自带的获取dom节点然后通过dom再去控制焦点,说干就干代码如下

    focusNextInput(index) {
		  console.log(`Trying to focus input-${index}`);
		  const ref = this.$refs[`input-${index}`];
		 if (ref && ref.length > 0) {
			// 使用微信小程序的API来设置焦点
			console.log(reg,'sssssssssssss')
			this.$nextTick(() => {
			  uni.createSelectorQuery().in(this).select(`#input-${index}`).fields({ node: true }).exec((res) => {
			      res[0].node._onFocus();  // 使用 focus 方法设置焦点
			  });
			});
		  } else {
			console.error(`Reference for input-${index} not found or invalid`, ref);
		  }
    },

我把这段代码修改后发现使用focus()还不行_focus()方法_onFocus()方法也不行

解决办法

上面我是所能用的方法都用了,这时候我想着看看官网吧,发现uniapp有自带的获取焦点的方法,只有用官网的方法才可以也就是<input :focus="focusState" @blur="dataExamine()"></input>这种,我心想那直接控制:focus实现代码如下所示:

<template>
  <view class="container">
    <view class="otp-container">
      <input
        v-for="(item, index) in otpLength"
        :key="index"
        type="tel"
		v-model="otpValues[index]"
		:focus="activeIndex === index"
        maxlength="1"
        @input="onInput($event, index)"
        @focus="onFocus(index)"
        :ref="`input-${index}`"
        :id="`input-${index}`"
        class="otp-input"
      />
    </view>
    <button @click="submitOTP">提交</button>
  </view>
</template>

<script>
export default {
  data() {
    return {
      otpLength: 5,          // 验证码的长度
      otpValues: ['', '', '', '', ''], // 存储每个输入框的值
      activeIndex: null      // 当前聚焦的输入框索引
    };
  },
  mounted() {
    // 页面加载完成时绑定 refs
    this.$nextTick(() => {
      console.log('Initial refs:', this.$refs);
    });
  },
  methods: {
    onInput(event, index) {
      const value = event.target.value;
      console.log(event, index, value,'1111111111111111111111111');
      this.$set(this.otpValues, index, value);  // 更新对应输入框的值

      if (value && index < this.otpLength - 1) {
        this.$nextTick(() => {
          this.focusNextInput(index + 1);  // 自动跳转到下一个输入框
        });
      }
    },
    onFocus(index) {
		this.activeIndex = index;  // 记录当前聚焦的输入框索引
		console.log(this.activeIndex);
    },
    focusNextInput(index) {
		console.log(`Trying to focus input-${index}`);
	    this.activeIndex = index;  // 设置指定输入框为焦点
    },
    submitOTP() {
      const otp = this.otpValues.join('');  // 将所有输入框的值拼接成一个字符串
      console.log('提交的验证码:', otp);  // 打印验证码
      // 这里可以添加提交验证码的逻辑
    }
  }
};
</script>

到此这个效果算是完成了,uniapp中有很多细节和vue上有偏差,还是需要熟读文档。还是那句话代码代码千千万,适合自己最重要。

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

GA/T1400视图库平台EasyCVR视频融合平台HLS视频协议是什么?

在数字化时代&#xff0c;视频监控系统已成为保障安全、提升效率的关键技术。EasyCVR视频融合云平台&#xff0c;作为TSINGSEE青犀视频在“云边端”架构体系中的重要一环&#xff0c;专为大中型项目设计&#xff0c;提供了一个跨区域、网络化的视频监控综合管理系统平台。它不仅…

文献解读-DNAscope: High accuracy small variant calling using machine learning

关键词&#xff1a;基准与方法研究&#xff1b;基因测序&#xff1b;变异检测&#xff1b; 文献简介 标题&#xff08;英文&#xff09;&#xff1a;DNAscope: High accuracy small variant calling using machine learning标题&#xff08;中文&#xff09;&#xff1a;DNAsc…

每日一博 - Java的Shallow Copy和Deep Copy

文章目录 概述创建对象的5种方式1. 通过new关键字2. 通过Class类的newInstance()方法3. 通过Constructor类的newInstance方法4. 利用Clone方法5. 反序列化 Clone方法基本类型和引用类型浅拷贝深拷贝如何实现深拷贝1. 让每个引用类型属性内部都重写clone()方法2. 利用序列化 概述…

【英特尔IA-32架构软件开发者开发手册第3卷:系统编程指南】2001年版翻译,2-25

文件下载与邀请翻译者 学习英特尔开发手册&#xff0c;最好手里这个手册文件。原版是PDF文件。点击下方链接了解下载方法。 讲解下载英特尔开发手册的文章 翻译英特尔开发手册&#xff0c;会是一件耗时费力的工作。如果有愿意和我一起来做这件事的&#xff0c;那么&#xff…

Odoo :一款免费开源的日化行业ERP管理系统

文 / 开源智造Odoo亚太金牌服务 概述 构建以 IPD 体系作为核心的产品创新研发管控体系&#xff0c;增进企业跨部门业务协同的效率&#xff0c;支撑研发管控、智慧供应链、智能制造以及全渠道营销等行业的场景化&#xff0c;构筑行业的研产供销财一体化管理平台。 行业的最新…

【Golang】——Gin 框架中间件详解:从基础到实战

中间件是 Web 应用开发中常见的功能模块&#xff0c;Gin 框架支持自定义和使用内置的中间件&#xff0c;让你在请求到达路由处理函数前进行一系列预处理操作。这篇博客将涵盖中间件的概念、内置中间件的用法、如何编写自定义中间件&#xff0c;以及在实际应用中的一些最佳实践。…

计算机网络 (3)计算机网络的性能

一、计算机网络性能指标 速率&#xff1a; 速率是计算机网络中最重要的性能指标之一&#xff0c;它指的是数据的传送速率&#xff0c;也称为数据率&#xff08;Data Rate&#xff09;或比特率&#xff08;Bit Rate&#xff09;。速率的单位是比特/秒&#xff08;bit/s&#xff…

云原生之运维监控实践-使用Telegraf、Prometheus与Grafana实现对InfluxDB服务的监测

背景 如果你要为应用程序构建规范或用户故事&#xff0c;那么务必先把应用程序每个组件的监控指标考虑进来&#xff0c;千万不要等到项目结束或部署之前再做这件事情。——《Prometheus监控实战》 去年写了一篇在Docker环境下部署若依微服务ruoyi-cloud项目的文章&#xff0c;当…

【C++】类中的“默认成员函数“--构造函数出现的意义?拷贝构造时“无穷递归”和“双重释放”出现的原因?

目录 "默认"成员函数 概念引入&#xff1a; 一、构造函数 问题引入&#xff1a; 1&#xff09;构造函数的概念 2&#xff09;构造函数实例 3&#xff09;构造函数的特性 4)关于默认生成的构造函数 (默认构造函数) 默认构造函数未完成初始化工作实例: 二…

fastapi 调用ollama之下的sqlcoder模式进行对话操作数据库

from fastapi import FastAPI, HTTPException, Request from pydantic import BaseModel import ollama import mysql.connector from mysql.connector.cursor import MySQLCursor import jsonapp FastAPI()# 数据库连接配置 DB_CONFIG {"database": "web&quo…

基于微信小程序的乡村研学游平台设计与实现,LW+源码+讲解

摘 要 信息数据从传统到当代&#xff0c;是一直在变革当中&#xff0c;突如其来的互联网让传统的信息管理看到了革命性的曙光&#xff0c;因为传统信息管理从时效性&#xff0c;还是安全性&#xff0c;还是可操作性等各个方面来讲&#xff0c;遇到了互联网时代才发现能补上自…

基于Java Springboot城市交通管理系统

一、作品包含 源码数据库设计文档万字PPT全套环境和工具资源部署教程 二、项目技术 前端技术&#xff1a;Html、Css、Js、Vue、Element-ui 数据库&#xff1a;MySQL 后端技术&#xff1a;Java、Spring Boot、MyBatis 三、运行环境 开发工具&#xff1a;IDEA/eclipse 数…

手机直连卫星NTN通信初步研究

目录 1、手机直连卫星之序幕 2、卫星NTN及其网络架构 2.1 NTN 2.2 NTN网络架构 3、NTN的3GPP标准化进程 3.1 NTN需要适应的特性 3.2 NTN频段 3.3 NTN的3GPP标准化进程概况 3.4 NTN的3GPP标准化进程的详情 3.4.1 NR-NTN 3.4.1.1 NTN 的无线相关 SI/WI 3.4.1.2…

基本数据类型和包装类型的区别、缓存池、自动拆箱装箱(面试题)

目录 1. 八种基本类型及对应包装类型 2. 基本类型和包装类型 区别 3. 自动拆箱装箱 3.1 自动装箱 3.2 自动拆箱 3.3 缓存池 4. 高频面试案例分析 1. 八种基本类型及对应包装类型 基本数据类型类型描述范围&#xff08;指数形式&#xff09;位数包装类型byte整型&#x…

Aria2-CVE-2023-39141漏洞分析

前言&#xff1a; 在偶然一次的渗透靶机的时候&#xff0c;上网查询Aria2的历史漏洞&#xff0c;发现了这个漏洞&#xff0c;但是网上并没有对应的漏洞解释&#xff0c;于是我就就源代码进行分析&#xff0c;发现这是一个非常简单的漏洞&#xff0c;于是发这篇文章跟大家分享一…

androidstudio入门到放弃配置

b站视频讲解传送门 android_studio安装包&#xff1a;https://developer.android.google.cn/studio?hlzh-cn 下载安装 开始创建hello-world 1.删除缓存 文件 下载gradle文件压缩&#xff1a;gradle-8.9用自己创建项目时自动生成的版本即可&#xff0c;不用和我一样 https://…

河道无人机雷达测流监测系统由哪几部分组成?

在现代水利管理中&#xff0c;河道无人机雷达监测系统正逐渐成为一种重要的工具&#xff0c;为河道的安全和管理提供了强大的技术支持。那么&#xff0c;这个先进的监测系统究竟由哪几部分组成呢&#xff1f; 河道无人机雷达监测系统工作原理 雷达传感器通过发射电磁波或激光束…

Mac上详细配置java开发环境和软件(更新中)

文章目录 概要JDK的配置JDK下载安装配置JDK环境变量文件 Idea的安装Mysql安装和配置Navicat Premium16.1安装安装Vscode安装和配置Maven配置本地仓库配置阿里云私服Idea集成Maven 概要 这里使用的是M3型片 14.6版本的Mac 用到的资源放在网盘 链接: https://pan.baidu.com/s/17…

CKA认证 | Day3 K8s管理应用生命周期(上)

第四章 应用程序生命周期管理&#xff08;上&#xff09; 1、在Kubernetes中部署应用流程 1.1 使用Deployment部署Java应用 在 Kubernetes 中&#xff0c;Deployment 是一种控制器&#xff0c;用于管理 Pod 的部署和更新。以下是使用 Deployment 部署 Java 应用的步骤&#x…

ffmpeg编程入门

文章目录 ffmpeg流程常用的音视频术语常用概念复用器编解码器ffmpeg的整体结构注册组件相关封装格式相关函数的调用流程 相关的ffpmeg数据结构简介数据结构之间的关系 ffmpeg流程 图中的函数 以及结构体都是ffmpeg自带提供的 ffmpeg打开的时候 和其他io操作差不多 有一个类似句…