DOM算法系列005-获取给定节点所属的window对象

news2025/2/3 17:21:12

UID: 20221220091217
aliases:
tags:
source:
cssclass:
created: 2022-12-20


我们知道,在一个HTML页面中,可以包含很多个框架或框架集,那么,当给定一个节点,我们如何获取这个节点所属的window对象呢?

首先,我们看看MDN上对window对象的讲解:

在这里,MDN直接告诉了我们,要获取window 对象,可以使用通过document 对象上的defaultView 来获取。

也就是说,我们的代码可能是这样的:

function getWindow(node) {
	var doc = getDocument(node); // 这个方法目前不存在,只是示例
	return doc.defaultView;
}

但是,当我们在查看MDN上关于 defaultView 的解释时,却看到了这样一句话:

尽管现在大多数人都使用chrome相同内核的浏览器了,IE已经被扫入历史的簸箕中了,但是国内一些政企由于历史原因,仍旧使用着IE8,那我们就不得不考虑兼容问题。

然后我们在 Dottoro 的web开发者文档里,寻找关于window 的线索(这个文档比MDN好的一点是它包含了很多IE早期版本的API说明)

很幸运被我们找到了,而且不止一个其他对象的属性指向window,而且有一个刚好也是在document 对象上。
其浏览器兼容性:

由此,兼容代码如下:

function getWindow(node) {
	var doc = getDocument(node); // 这个方法目前不存在,只是示例
	return doc.defaultView || doc.parentWindow;
}

现在唯一剩余的问题就是,如何根据node 获取到它所属的 document 对象。
同样,为了优先兼容IE,我们先看Dottoro开发者文档上document的关联对象:

这里,几乎所有标签和所有类型的节点都支持ownerDocument 这个属性,这个属性就直接指向节点或标签所在的文档对象。

再在MDN上验证一下

可以看到,这个属性是挂在顶层Node对象上,也就是所有节点上都会有这个属性,搞定:

function getWindow(node) {
	var doc = node.ownerDocument || node;// 传入node如果就是document时
	return doc.defaultView || doc.parentWindow;
}

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

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

相关文章

【填坑向】Linux获取Java程序resource下的文件路径(这次的坑好像没填住……

​╮( ̄▽ ̄"")╭没错,就是那个传说中的FileNotFoundException,文件找不到了 一开始,特别单纯的俺是把文件直接放在项目根目录的,获取文件地址的位置就只写了一个文件名(相对路径&…

Nature子刊:生命的最初几个小时内可快速学习音位辨别—基于fNIRS研究

摘要 人类新生儿可以区分音素,但这种能力背后的神经机制尚不清楚。新生儿的大脑可以学会区分自然(前)元音和逆向(后)元音(在子宫中学习不到的)。利用功能近红外光谱,我们检测了出生…

工控CTF之协议分析2——MMS

协议分析 流量分析 主要以工控流量和恶意流量为主,难度较低的题目主要考察Wireshark使用和找规律,难度较高的题目主要考察协议定义和特征 简单只能简单得干篇一律,难可以难得五花八门 常见的工控协议有:Modbus、MMS、MQTT、CoA…

关于3D可视化的几个知识点

3D可视化,运用三维仿真技术实现信息感知、智能调度以及主动式运营维护,把复杂抽象的数据信息,以合适的人们视觉元素及视角用3D立体方式进行一比一还原呈现! 近些年,将繁琐的信息通过可视化的图表视觉化展现出来的应用场…

惠普Elite蜻笔记本系统损坏怎么U盘重装教学

惠普Elite蜻笔记本系统损坏怎么U盘重装教学,有用户使用的惠普Elite蜻笔记本系统受到了其他恶意程序的损坏,导致无法正常的开启使用。所以想要去进行电脑系统的重装。那么如何U盘重装电脑系统,一起来看看详细的重装步骤吧。 准备工作&#xff…

有哪些实用的软件开发项目管理工具?

给大家介绍下,目前最新的免费项目管理工具,希望对大家有所帮助。 1、 Co-Project智能项目管理工具 智能项目管理平台,是CoCode旗下的软件开发全生命周期的项目管理平台,涵盖了从需求、计划、设计、开发、测试再到交付的整个项目周…

青少年关联网络功能地形的性别差异

我们发现了个性化联想网络功能地形的规范性性别差异,包括腹侧注意、默认模式和额顶网络。此外,染色体富集分析显示,功能地形多变量模式的性别差异在空间上与x连锁基因的表达以及星形细胞和兴奋性神经元细胞类型的特征相耦合。这些结果突出了性…

实景三维模型色彩差异大,用模方与DasViewer直接对模型调色

在实际项目生产过程中,由于受到采集天气、设备、时间、季节、航高等各类因素的影响,重建后的三维模型尤其是大面积模型中,纹理不可避免的出现明暗不一、颜色不均匀的现象,导致后期处理时间与成本增高,影响项目工期。 三…

Apache Flink

目录 处理无边界和有边界数据 数据可以作为无边界流或有边界流处理 随时随地部署应用程序 以任何规模运行应用程序 利用内存性能 Apache Flink 起源于一个叫作 Stratosphere 的项目,它是由 3 所地处柏林的大学和欧洲其他一些大学共同进行的研究项目&#xff0c…

[附源码]计算机毕业设计Node.js湖南旅游景点网站(程序+LW)

项目运行 环境配置: Node.js最新版 Vscode Mysql5.7 HBuilderXNavicat11Vue。 项目技术: Express框架 Node.js Vue 等等组成,B/S模式 Vscode管理前后端分离等等。 环境需要 1.运行环境:最好是Nodejs最新版,我…

Java码客过去的一周年

入坑伊始 2021年12月20日 我本身就是一名计算机科学与技术的大学生,应该也算是行内的科班出身,但是在2021年12月20日之前,也就是离19届大学生考研差不多一年的时间,那时候有一周的SSM网站编程实训课程,惊讶的是虽然学…

别再用 JWT 作为 Session 系统了,问题重重,后果很危险!

SON Web Tokens,又称 JWT。本文将详解:为何 JWT 不适合存储 Session,以及 JWT 引发的安全隐患。望各位对JWT有更深的理解! 十分不幸,我发现越来越多的人开始推荐使用 JWT 管理网站的用户会话(Session&…

从头到尾Spring概念,家族,核心技术使用,事务这一篇就够了!!!

目录 1.了解Spring家族 家族成员 Spring常用项目介绍 2.Spring Framework体系结构 概述 体系图 3.Spring框架提供的核心技术 IOC控制反转 1.IOC与Spring的关系 2.什么是Bean DI 依赖注入 IoC/DI技术实现 1.基于XML的实现 2.基于注解的实现 3.基于java的实现 AO…

【案例实践】InVEST实践与进阶及在生态系统服务供需、固碳、城市热岛、论文写作中的应用

【查看原文】InVEST实践与进阶及在生态系统服务供需、固碳、城市热岛、论文写作等实际项目中的具体应用 【专家】: 白老师(研究员):长期从事生态系统结构-格局-过程-功能-服务的变化与响应关系等研究工作;重点围绕生…

使用 .NET MAUI 开发 ChatGPT 客户端

最近 chatgpt 很火,由于网页版本限制了 ip,还得必须开代理,用起来比较麻烦,所以我尝试用 maui 开发一个聊天小应用,结合 chatgpt 的开放 api 来实现(很多客户端使用网页版本接口用 cookie 的方式&#xff0…

含辞未吐,声若幽兰,史上最强免费人工智能AI语音合成TTS服务微软Azure(Python3.10接入)

所谓文无第一,武无第二,云原生人工智能技术目前呈现三足鼎立的态势,微软,谷歌以及亚马逊三大巨头各擅胜场,不分伯仲,但目前微软Azure平台不仅仅只是一个PaaS平台,相比AWS,以及GAE&am…

【云原生】k8s的pod基础

内容预知 1.pod的相关知识 1.1 pod的基础概念 1.2 k8s中pod的两种使用方式 1.3 pod 容器的常规使用流程 1.4 k8s中pod结构设计的巧妙用意 通常把Pod分为两类 2. 容器的分类 2.1 pause基础容器(infrastructure container) (1&#xf…

安装ZIMG 图片服务器

简介:zimg是图像存储和处理服务器。您可以使用URL参数从zimg获取压缩和缩放的图像。 zimg的并发I / O,分布式存储和时间处理能力非常出色。 您不再需要在图像服务器中使用nginx。在基准测试中,zimg可以在高并发级别上处理每秒3000图像下载任务…

【性能篇】29 # 怎么给Canvas绘制加速?

说明 【跟月影学可视化】学习笔记。 方法一&#xff1a;优化 Canvas 指令 例子&#xff1a;实现一些位置随机的多边形&#xff0c;并且不断刷新这些图形的形状和位置 <!DOCTYPE html> <html lang"en"><head><meta charset"UTF-8"…

openGauss的WDR报告解读

文章目录1.执行以下SQL命令,查询已经生成的快照信息。2.生成WDR报告。3.手工创建快照信息4.WDR涉及的数据表5.WDR报告解读在Oralce数据库中&#xff0c;遇到性能问题&#xff0c;我们通常会查看有无对应时间段的快照&#xff0c;生成awr报告并进一步分析&#xff08;AWR是Autom…