首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

为什么.nextElementSibling不返回null?

.nextElementSibling是JavaScript中的一个属性,用于获取当前元素的下一个兄弟元素。

为什么.nextElementSibling不返回null?

在HTML文档中,元素之间的空格、换行符等被视为文本节点,它们也被认为是元素的兄弟节点。所以即使当前元素没有直接的兄弟元素,.nextElementSibling也会返回下一个非文本节点的兄弟元素。

例如,考虑以下HTML代码:

代码语言:html
复制
<div id="parent">
  <span>元素1</span>
  <span>元素2</span>
  <span>元素3</span>
</div>

如果我们使用JavaScript代码来获取第一个span元素的下一个兄弟元素,即:

代码语言:javascript
复制
var firstSpan = document.querySelector('#parent span');
var nextSibling = firstSpan.nextElementSibling;

在这种情况下,.nextElementSibling将返回第二个span元素,而不是null,因为第一个span元素后面有一个文本节点(换行符),然后才是第二个span元素。

如果我们想要获取下一个非文本节点的兄弟元素,可以使用以下代码:

代码语言:javascript
复制
var nextSibling = firstSpan.nextElementSibling;
while (nextSibling && nextSibling.nodeType !== 1) {
  nextSibling = nextSibling.nextElementSibling;
}

这段代码将循环遍历兄弟节点,直到找到下一个非文本节点为止。

推荐的腾讯云相关产品和产品介绍链接地址:

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

为什么建议你用去 “! = null” 做判空?

他们总喜欢在方法中返回null,因此,在调用这些方法时,也不得不去判空。另外,也许受此习惯影响,他们总潜意识地认为,所有的返回都是不可信任的,为了保护自己程序,就加了大量的判空。...吐槽完毕,回到这个题目本身: 进行判空前,请区分以下两种情况: 1、null 是一个有效有意义的返回值(Where null is a valid response in terms of the contract...这里给一些实践建议: 1、假如方法的返回类型是collections,当返回结果是空时,你可以返回一个空的collections(empty list),而不要返回null,这样调用侧就能大胆地处理这个返回...如果你养成习惯,都是这样写代码(返回空collections而返回null),你调用自己写的方法时,就能大胆地忽略判空) 2、返回类型不是collections,又怎么办呢?...解决这个问题的一个方式,就是使用Null Object pattern(空对象模式) 改造后 类定义如下,这样定义findAction方法后,确保无论用户输入什么,都不会返回null对象 public

71010
  • 为什么建议你用去 “! = null” 做判空?

    他们总喜欢在方法中返回null,因此,在调用这些方法时,也不得不去判空。另外,也许受此习惯影响,他们总潜意识地认为,所有的返回都是不可信任的,为了保护自己程序,就加了大量的判空。...吐槽完毕,回到这个题目本身: 进行判空前,请区分以下两种情况: null 是一个有效有意义的返回值(Where null is a valid response in terms of the contract...这里给一些实践建议: 「1、假如方法的返回类型是 collections,当返回结果是空时,你可以返回一个空的 collections」 (empty list),而不要返回 null,这样调用侧就能大胆地处理这个返回...如果你养成习惯,都是这样写代码(返回空collections 而返回 null),你调用自己写的方法时,就能大胆地忽略判空) 「2、返回类型不是 collections,又怎么办呢?」...3、如果你想返回 null,请挺下来想一想,这个地方是否更应该抛出一个异常。

    56420

    为什么建议你用去 “ ! = null 做判空?

    他们总喜欢在方法中返回null,因此,在调用这些方法时,也不得不去判空。另外,也许受此习惯影响,他们总潜意识地认为,所有的返回都是不可信任的,为了保护自己程序,就加了大量的判空。...吐槽完毕,回到这个题目本身: 进行判空前,请区分以下两种情况: 1、null 是一个有效有意义的返回值(Where null is a valid response in terms of the contract...这里给一些实践建议: 1、假如方法的返回类型是collections,当返回结果是空时,你可以返回一个空的collections(empty list),而不要返回null,这样调用侧就能大胆地处理这个返回...如果你养成习惯,都是这样写代码(返回空collections而返回null),你调用自己写的方法时,就能大胆地忽略判空) 2、返回类型不是collections,又怎么办呢?...3、如果你想返回null,请挺下来想一想,这个地方是否更应该抛出一个异常

    98210

    NDK学习笔记:线程JNIEnv,JavaVM,JNI_OnLoad(GetEnv返回NULL?FindClass返回NULL?)

    GetEnv返回NULL? FindClass返回NULL ?...为什么?引用Google官方翻译: 由于VM通常是多执行绪(Multi-threading)的执行环境。每一个执行绪在呼叫native函数时,所传递进来的JNIEnv指标值都是不同的。...有了这个JavaVM,我们再调用AttachCurrentThread 附加当前线程到虚拟机VM当中,并返回线程对应的JNIEnv,我们就能愉快的撸码了!...这么解释吧,只有先AttachCurrentThread到JavaVM,分配到了独立的JNIEnv之后,GetEnv第二个参数二级指针返回的env才有值。...为什么会找不到 org.zzrblog.MainActivity?此问题更好的体现了JNIEnv的线程独立性问题了!如果FindClass用的是主线程env就不会报错了。

    2.7K41

    typeof运算对于null返回“Object

    您也许会问,为什么 typeof 运算符对于 null 值会返回 "Object"。这实际上是 JavaScript 最初实现中的一个错误,然后被 ECMAScript 沿用了。...对变量或值调用 typeof 运算符将返回下列值之一: undefined - 如果变量是 Undefined 类型的 boolean - 如果变量是 Boolean 类型的 number - 如果变量是...Number 类型的 string - 如果变量是 String 类型的 object - 如果变量是一种引用类型或 Null 类型的 这里需要注意的是:alert(typeof null); //...null被认为是对象的占位符,但仍然算做原始数据类型 另一种只有一个值的类型是 Null,它只有一个专用值 null,即它的字面量。...如果函数或方法要返回的是对象,那么找不到该对象时,返回的通常是 null。 2.Null类型 Null类型(空型)只有一个值就是:null

    2.2K40

    React报错之ref返回undefined或null

    原文链接:https://bobbyhadz.com/blog/react-ref-returns-undefined-or-null[1] 作者:Borislav Hadzhiev[2] 正文从这开始...~ 总览 当我们试图在其对应的DOM元素被渲染之前访问其current属性时,React的ref通常会返回undefined或者null。...该钩子返回一个可变的ref对象,ref对象上的current属性被初始化为传递的参数。 我们没有为useRef传递初始值,因此其current属性设置为undefined。...如果我们将null传递给钩子,如果立即访问其current属性,将会得到null。 需要注意的是,我们必须访问ref对象上的current属性,以此来访问设置了ref属性的div元素。...参考资料 [1] https://bobbyhadz.com/blog/react-ref-returns-undefined-or-null: https://bobbyhadz.com/blog/react-ref-returns-undefined-or-null

    1.2K10

    Microsoftthrifty:RPC方法返回NULL的异常处理

    https://blog.csdn.net/10km/article/details/86244875 我们知道:thrift框架是不允许返回值为null的,如果返回值为null,client...端会抛出异常,我在之前用facebook/swift框架时就遇到了这个问题,这是当时解决问题的记录《thrift:返回null的解决办法》,现在使用Microsoft/thrifty框架实现的客户端同样也存在这个问题..., "Missing result"); } } } 可以看到,返回结果为null时,会抛出类型为MISSING_RESULT的ThriftException异常。...Override public void onError(Throwable error) { // 如果关闭时有异常,则将异常转给callback对象, // 当方法返回值为...void onError(Throwable error) { // 对象ThriftException异常,判断类型是否为MISSING_RESULT,是则调用onSuccess正常返回

    1.4K40
    领券