Uncaught TypeError: Cannot set property 'className' of undefined 解决思路

本文主要是介绍Uncaught TypeError: Cannot set property 'className' of undefined 解决思路,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Cannot set property 'className' of undefined 解决思路其一

  • 使用了超出数组长度的下标
  • 介绍
    • 思路
    • 总结
    • 结语

使用了超出数组长度的下标

介绍

今天在帮别人调试js的时候,出现了个很奇怪的错误。

Cannot set property 'className' of undefined

再看一下代码:

	var div = document.getElementById("rm"); //获取divvar ul = div.getElementsByTagName("ul")[0]; //一个节点var lis = ul.getElementsByTagName("li"); //数组var divs = div.getElementsByTagName("div"); //数组for (var i = 0; i < lis.length; i++) {lis[i].index = i;lis[i].onclick = function() {for (var j = 0; j < lis.length; j++) {lis[j].className = "off1";divs[j].className = "hide1";}divs[this.index].className = "show1";}}

运行之后报错
运行显示'className未定义'

思路

  1. 首先,我们把 lisdivslenght(长度) 打印出来。
    长度不一致
    lis 的长度为 4divs 的长度为 3 ,并且他们的 下标 都从 0 开始。
    好了,我们在看一下报错的那一行代码
for (var j = 0; j < lis.length; j++) {lis[j].className = "off1";divs[j].className = "hide1";}

在这里可以看到 for循环 的判断条件是 j < lis.length ,这说明了 j 的值可以增加到 3 ,而divs集合的值最大为 2 。到这里为止,已经找到了问题的所在。

divs[j] 超出长度

总结

  1. 在这个问题中,出错的 原因 是因为 divs 的长度只有 3 ,但是在循环中却给 divs 循环赋值了 4

结语

记录一下一些比较常见的问题,方便自己复习,在 Javascript 中,有很多问题都有共同点,即使这篇文章不适合你,也希望这个思路能帮助到你,如果文章有错,欢迎大家指正。

一个喜欢编程世界的小白记……

这篇关于Uncaught TypeError: Cannot set property 'className' of undefined 解决思路的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/581752

相关文章

SpringBoot应用中出现的Full GC问题的场景与解决

《SpringBoot应用中出现的FullGC问题的场景与解决》这篇文章主要为大家详细介绍了SpringBoot应用中出现的FullGC问题的场景与解决方法,文中的示例代码讲解详细,感兴趣的小伙伴可... 目录Full GC的原理与触发条件原理触发条件对Spring Boot应用的影响示例代码优化建议结论F

MySQL中FIND_IN_SET函数与INSTR函数用法解析

《MySQL中FIND_IN_SET函数与INSTR函数用法解析》:本文主要介绍MySQL中FIND_IN_SET函数与INSTR函数用法解析,本文通过实例代码给大家介绍的非常详细,感兴趣的朋友一... 目录一、功能定义与语法1、FIND_IN_SET函数2、INSTR函数二、本质区别对比三、实际场景案例分

Pyserial设置缓冲区大小失败的问题解决

《Pyserial设置缓冲区大小失败的问题解决》本文主要介绍了Pyserial设置缓冲区大小失败的问题解决,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面... 目录问题描述原因分析解决方案问题描述使用set_buffer_size()设置缓冲区大小后,buf

PyInstaller打包selenium-wire过程中常见问题和解决指南

《PyInstaller打包selenium-wire过程中常见问题和解决指南》常用的打包工具PyInstaller能将Python项目打包成单个可执行文件,但也会因为兼容性问题和路径管理而出现各种运... 目录前言1. 背景2. 可能遇到的问题概述3. PyInstaller 打包步骤及参数配置4. 依赖

解决SpringBoot启动报错:Failed to load property source from location 'classpath:/application.yml'

《解决SpringBoot启动报错:Failedtoloadpropertysourcefromlocationclasspath:/application.yml问题》这篇文章主要介绍... 目录在启动SpringBoot项目时报如下错误原因可能是1.yml中语法错误2.yml文件格式是GBK总结在启动S

Python获取C++中返回的char*字段的两种思路

《Python获取C++中返回的char*字段的两种思路》有时候需要获取C++函数中返回来的不定长的char*字符串,本文小编为大家找到了两种解决问题的思路,感兴趣的小伙伴可以跟随小编一起学习一下... 有时候需要获取C++函数中返回来的不定长的char*字符串,目前我找到两种解决问题的思路,具体实现如下:

idea maven编译报错Java heap space的解决方法

《ideamaven编译报错Javaheapspace的解决方法》这篇文章主要为大家详细介绍了ideamaven编译报错Javaheapspace的相关解决方法,文中的示例代码讲解详细,感兴趣的... 目录1.增加 Maven 编译的堆内存2. 增加 IntelliJ IDEA 的堆内存3. 优化 Mave

如何解决mmcv无法安装或安装之后报错问题

《如何解决mmcv无法安装或安装之后报错问题》:本文主要介绍如何解决mmcv无法安装或安装之后报错问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录mmcv无法安装或安装之后报错问题1.当我们运行YOwww.chinasem.cnLO时遇到2.找到下图所示这里3.

浅谈配置MMCV环境,解决报错,版本不匹配问题

《浅谈配置MMCV环境,解决报错,版本不匹配问题》:本文主要介绍浅谈配置MMCV环境,解决报错,版本不匹配问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录配置MMCV环境,解决报错,版本不匹配错误示例正确示例总结配置MMCV环境,解决报错,版本不匹配在col

Feign Client超时时间设置不生效的解决方法

《FeignClient超时时间设置不生效的解决方法》这篇文章主要为大家详细介绍了FeignClient超时时间设置不生效的原因与解决方法,具有一定的的参考价值,希望对大家有一定的帮助... 在使用Feign Client时,可以通过两种方式来设置超时时间:1.针对整个Feign Client设置超时时间