BOM窗口代码大全

document.body.clientWidth ==> BODY对象宽度

document.body.clientHeight ==> BODY对象高度

document.documentElement.clientWidth ==> 可见区域宽度

document.documentElement.clientHeight ==> 可见区域高度

看了以上代码,可能会有疑问说body和可见区域到底有什么不同呢,我们在console里运行一下会发现在不同的网页中有不同的情况值,有的document.body.clientWidth和document.documentElement.clientWidth 的值相同,有的却不同,原因在哪呢?

原因就是:在浏览器默认的情况下,body有8-10px左右的边距,而可见区域包括了这个边距,因此如果我们用到body{padding:0;margin:0;}来消除这种默认的情况。那么document.body.clientWidth和document.documentElement.clientWidth 的值就会相同。
在这里插入图片描述

以下是兼容主流浏览器(IE/Firefox/Chrome/Safari)获取浏览器窗口可视区域(不包括滚动条)和滚动条位置的代码:

1// 获取浏览器窗口的可视区域的宽度 2function getViewPortWidth() { 3returndocument.documentElement.clientWidth || document.body.clientWidth; 4} 5 6// 获取浏览器窗口的可视区域的高度 7function getViewPortHeight() { 8returndocument.documentElement.clientHeight || document.body.clientHeight; 9}1011// 获取浏览器窗口水平滚动条的位置12function getScrollLeft() {13returndocument.documentElement.scrollLeft || document.body.scrollLeft;14}1516// 获取浏览器窗口垂直滚动条的位置17function getScrollTop() {18returndocument.documentElement.scrollTop || document.body.scrollTop;19}

网页可见区域宽: document.body.offsetWidth (包括边线的宽)

网页可见区域高: document.body.offsetHeight (包括边线的高)

网页正文部分上: window.screenTop

网页正文部分左: window.screenLeft

屏幕分辨率的高: window.screen.height

屏幕分辨率的宽: window.screen.width

屏幕可用工作区高度: window.screen.availHeight

屏幕可用工作区宽度: window.screen.availWidth

// 部分jQuery函数

$(window).height()  //浏览器时下窗口可视区域高度

$(document).height()    //浏览器时下窗口文档的高度

$(document.body).height()      //浏览器时下窗口文档body的高度

$(document.body).outerHeight(true) //浏览器时下窗口文档body的总高度 包括border padding margin

$(window).width()  //浏览器时下窗口可视区域宽度

$(document).width()//浏览器时下窗口文档对于象宽度

$(document.body).width()      //浏览器时下窗口文档body的高度

$(document.body).outerWidth(true) //浏览器时下窗口文档body的总宽度 包括border padding

HTML精确定位:scrollLeft,scrollWidth,clientWidth,offsetWidth

scrollHeight: 获取对象的滚动高度。

scrollLeft:设置或获取位于对象左边界和窗口中目前可见内容的最左端之间的距离

scrollTop:设置或获取位于对象最顶端和窗口中可见内容的最顶端之间的距离

scrollWidth:获取对象的滚动宽度

offsetHeight:获取对象相对于版面或由父坐标 offsetParent 属性指定的父坐标的高度

offsetLeft:获取对象相对于版面或由 offsetParent 属性指定的父坐标的计算左侧位置

offsetTop:获取对象相对于版面或由 offsetTop 属性指定的父坐标的计算顶端位置

event.clientX 相对文档的水平座标

event.clientY 相对文档的垂直座标

event.offsetX 相对容器的水平坐标

event.offsetY 相对容器的垂直坐标

document.documentElement.scrollTop 垂直方向滚动的值

event.clientX+document.documentElement.scrollTop 相对文档的水平座标+垂直方向滚动的量

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 获取BOM(浏览器对象模型)树的代码的实现方式有很多种,下面是一种常见的实现方式: ```javascript function getBomTree(node) { let tree = { name: node.nodeName, children: [] }; for (let i = 0; i < node.childNodes.length; i++) { let childNode = node.childNodes[i]; if (childNode.nodeType === 1) { // Element node tree.children.push(getBomTree(childNode)); } else if (childNode.nodeType === 3) { // Text node tree.children.push({ name: "TEXT", value: childNode.nodeValue }); } } return tree; } // 使用方法 let bomTree = getBomTree(document.documentElement); console.log(bomTree); ``` 上述代码中的`getBomTree`函数会遍历传入的节点及其子节点,创建一个包含节点信息的树形结构。对于元素节点,会递归调用`getBomTree`函数;对于文本节点,会将节点值保存在`value`属性中。最后返回构建好的BOM树。 调用`getBomTree`函数时,可以传入任意节点作为参数。一般情况下,可以将`document.documentElement`作为参数,它表示整个文档的根节点。获取到的`bomTree`对象将包含整个BOM树的信息。 这只是一种实现方式,根据具体需求和使用场景的不同,可能需要对代码进行适当的修改和调整。 ### 回答2: 获取BOM树的代码可以采用递归的方式遍历HTML文档树,逐层获取每个节点的子节点,并将节点信息保存到一个列表中。 以下是一个示例代码: ``` def get_bom_tree(node): bom_tree = [] # 用于保存BOM树的列表 children = node.childNodes # 获取当前节点的子节点列表 for child in children: if child.nodeType == child.ELEMENT_NODE: # 判断节点类型为元素节点 child_data = { 'tag': child.tagName, # 节点标签名 'attrs': dict(child.attributes.items()), # 节点属性 'children': get_bom_tree(child) # 递归获取子节点的BOM树 } bom_tree.append(child_data) return bom_tree # 示例用法 from xml.dom import minidom dom = minidom.parse('path/to/html/file') # 解析HTML文件 bom_tree = get_bom_tree(dom.documentElement) # 获取BOM树 # 打印BOM树 import json print(json.dumps(bom_tree, indent=4)) ``` 请注意,该代码使用了Python的内置库`xml.dom.minidom`来解析HTML文件,并递归获取BOM树。在使用之前,需要安装`xml.dom`库,可以使用`pip install xml.dom`命令进行安装。 ### 回答3: 获取BOM树(Browser Object Model)的代码可以通过JavaScript来实现。BOM树是指代表浏览器窗口窗口之间关系的树状结构。在Web开发中,可以使用以下代码来获取BOM树: ```javascript function getBomTree() { var currentWindow = window; // 获取当前窗口对象 var bomTree = { window: currentWindow, // 当前窗口对象为根节点 children: [] // 存储子窗口的数组 }; // 递归遍历子窗口 function traverseChildren(win, parentNode) { var iframes = win.document.getElementsByTagName('iframe'); // 获取当前窗口中的iframe元素 for (var i = 0; i < iframes.length; i++) { var iframeWindow = iframes[i].contentWindow; // 获取iframe窗口对象 var childNode = { window: iframeWindow, // 子窗口对象 children: [] // 存储子窗口的数组 }; parentNode.children.push(childNode); // 将子窗口节点添加到父节点的children数组中 traverseChildren(iframeWindow, childNode); // 递归遍历子窗口 } } traverseChildren(currentWindow, bomTree); // 调用递归函数遍历子窗口 return bomTree; } // 调用示例 var bomTree = getBomTree(); console.log(bomTree); ``` 以上代码通过递归函数`traverseChildren`来遍历子窗口,使用`getElementsByTagName`方法获取当前窗口中的所有`iframe`元素,然后获取其`contentWindow`属性来获取子窗口对象。通过递归调用,将所有子窗口对象存储在BOM树中。最后通过`console.log`将BOM树输出到控制台。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值