offsetWidth与offsetLeft

offsetWidth与offsetLeft1、offsetWidth:为元素的width+元素的padding+边框的宽度如图:2、offsetLeft、offsetTop、offsetRight、offsetBottom以offsetLeft为例进行说明,在不同的浏览器中其值不同,且与父元素的position属性(relative,absolute,fixed)有关。现分以下几种情况说明:(测试所用的浏览…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全家桶1年46,售后保障稳定

1、offsetWidth: 为元素的width+元素的padding+边框的宽度

如图:offsetWidth与offsetLeft

2、offsetLeft、offsetTop、offsetRight、offsetBottom

以offsetLeft为例进行说明,在不同的浏览器中其值不同,且与父元素的position属性(relative,absolute,fixed)有关。现分以下几种情况说明:(测试所用的浏览器版本为:Chrome 68.0.3440.106, opera54.0, Firefox61.0.1和IE11.0)

2.1在父元素均不设置position属性时,在Chrome,opera和IE浏览器中offsetLeft是元素边框外侧到浏览器窗口内侧的距离且body.offsetLeft=0,

offsetWidth与offsetLeft

在firefox浏览器中offsetLeft是元素边框外侧到body内侧的距离body.offsetLeft=-边框宽度

如图:

offsetWidth与offsetLeft

2.2当父元素设置position元素时又分为两种情况,

2.2.1如果父元素是body且body设置了position属性,在Chrome和opera浏览器中offsetLeft是元素边框外侧到body边框外侧的距离,

offsetWidth与offsetLeft

在IE和fireForx浏览器中offsetLeft是元素边框外侧到body边框内侧的距离

offsetWidth与offsetLeft

2.2.2如果父元素不是body元素且设置了position属性时,offsetLeft为元素边框外侧到父元素边框内侧的距离(各浏览器情况一致)。

如图

offsetWidth与offsetLeft

3、下面通过实例进行说明(Chrome浏览器):

Html结构为

offsetWidth与offsetLeft

Css样式:将body,container,box, content的margin和padding都设置为10px,container长宽为300px,box长宽为100px,content长宽为50px,都设置宽度为5px的边框。具体查看下方源代码。效果如下图

offsetWidth与offsetLeft

3.1 offsetWidth

container.offsetWidth =container的width+padding+边框宽度=300+2×10+2×5=330

console.log(container.offsetWidth)输出结果为

offsetWidth与offsetLeft

3.2

3.2.1父元素均不设置position属性

document.body.offsetLeft=0

document.body.offsetLeft= container边框外侧到窗口内侧的距离=body.margin+body边框宽度+container.margin+container.padding+container的left=10+5+10+10=35px;

aBoxes[0].offsetLeft=第一个div.box边框外侧到窗口内侧的距离=body.margin+body边框宽度+container.margin+container.padding+container边框宽度+box.margin+box.padding=10+5+10+10+5+10+10px=60px;

console.log(document.body.offsetLeft)

console.log(document.body.offsetLeft)

console.log(aBoxes[0].offsetLeft)输出结果为

offsetWidth与offsetLeft

2.2.2将body的position设置为relative

 document.body.offsetLeft=0

   container.offsetLeft=container边框外侧到body边框外侧的距离= body边框宽度+container.margin+container.padding =5+10+10=25px;

aBoxes[0].offsetLeft=第一个div.box边框外侧到body边框外侧的距离= body边框宽度+container.margin+container.padding+container边框宽度+box.margin+box.padding=5+10+10+5+10+10px=50px;

console.log(document.body.offsetLeft);

console.log(container.offsetLeft);

console.log(aBoxes[0].offsetLeft);输出结果为

offsetWidth与offsetLeft

2.2.3将container的position设置为relative,并设置其left为100px,body不设置position属性。

oContainer.offsetLeft= 为container边框外侧到窗口内侧的距离=body.margin+body边框宽度+container的left+container.margin+container.padding+container的left=10+5+100+10+10=135;

   aBoxes[0].offsetLeft=第一个div.box边框外侧到container边框内侧的距离= container.padding+box.margin=10+10px=20;

    aBoxes[1].offsetLeft= 第二个div.box边框外侧到container边框内侧的距离= container.padding + box.margin +box.offsetWidth+2*box.margin=10+10+130+10+10=170;

console.log(oContainer.offsetLeft);

console.log(aBoxes[0].offsetLeft);

console.log(aBoxes[1].offsetLeft);输出结果为:

offsetWidth与offsetLeft

<!DOCTYPE html>
<html lang="en">
<head>
	<meta charset="UTF-8">
	<title>Document</title>
	<style type="text/css">
		*{
			margin: 0;
			padding: 0;
		}
		body{
			//position: relative;
			margin:10px;
			padding: 10px;
			border: 5px solid black;
		}
		#container{
			position: relative;
			left: 100px;
			margin: 10px;
			padding: 10px;
			border: 5px solid #ccc;
			background: red;
			width: 300px;
			height: 300px;
			//overflow: hidden;
		}
		.box{
			position: relative;
			float: left;
			margin: 10px;
			padding: 10px;
			border: 5px solid black;
			background: orange;
			width: 100px;
			height: 100px;
		}
		.content{
			margin: 10px;
			padding: 10px;
			border: 5px solid black;
			background: yellow;
			width: 50px;
			height: 50px;
		}
	</style>
</head>
<body>
	<div id="container">            
		<div class="box">
                      <div class="content"></div>
		</div>
		<div class="box">
			<div class="content"></div>
		</div>
	</div>
 <script type="text/javascript">
 	var oContainer=document.getElementById("container");
 	var aBoxes=getElementsByClassName(oContainer,"box");
 	    
     console.log("container.offsetWidth="+oContainer.offsetWidth);
     console.log("box.offsetWidth="+aBoxes[0].offsetWidth);
     //console.log(aBoxes[1].firstElementChild.offsetWidth);
    
    //console.log(document.body.offsetLeft);
    console.log("container.offsetLeft="+oContainer.offsetLeft);
    console.log("box1.offsetLeft="+aBoxes[0].offsetLeft);
    console.log("box2.offsetLeft="+aBoxes[1].offsetLeft);
    console.log("content.offsetLeft="+aBoxes[1].firstElementChild.offsetLeft);
    // alert(document.body.offsetLeft);
    // alert(oContainer.offsetLeft);
    // alert(aBoxes[0].offsetLeft);
    // alert(aBoxes[1].offsetLeft);
    // alert(aBoxes[1].firstElementChild.offsetLeft);

 	function getElementsByClassName(parent,className){

 		var allChildren=parent.getElementsByTagName("*");
 		var arr=[];
 		for(var i=0;i<allChildren.length;i++){
 			if (allChildren[i].className==className) {
 				arr.push(allChildren[i]); 				
 			}
 		} 		
 		return arr;	 		
 	}
 </script>
	
</body>
</html>

Jetbrains全家桶1年46,售后保障稳定

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/198382.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 几种常见mybatis分页实现[通俗易懂]

    几种常见mybatis分页实现[通俗易懂]mybatis框架分页实现,有几种方式,最简单的就是利用原生的sql关键字limit来实现,还有一种就是利用interceptor来拼接sql,实现和limit一样的功能,再一个就是利用PageHelper来实现。这里讲解这三种常见的实现方式:无论哪种实现方式,我们返回的结果,不能再使用List了,需要一个自定义对象Pager。packagecom.xxx.mybatis.bean;…

    2022年10月20日
    3
  • 5g的控制信道编码方式_5gnr上行支持的信道编码

    5g的控制信道编码方式_5gnr上行支持的信道编码第1章物理层架构1.1物理层内部功能协议栈1.2物理层编码与处理过程(1)信道编码(2)调制解调(3)层映射(4)扩频预编码(仅仅用于上行,可选)(5)多天线技术的预编码(6)资源映射(7)OFDM变换本文主要探讨NR的信道编码技术第2章NR的物理层信道编码技术概述物理层信道编码不是单一的编码,而是有一组编码组成。以发送为例,阐述物理层信道编码的过程以及其中涉及到的主要,接收过程与之相反。(1)TrBloc……

    2025年7月3日
    2
  • listagg oracle10_oracle伪列

    listagg oracle10_oracle伪列oracle函数listagg的使用说明

    2025年9月28日
    3
  • Linux下tar解压到当前目录,zip压缩,tar压缩,tar解压[通俗易懂]

    Linux下tar解压到当前目录,zip压缩,tar压缩,tar解压[通俗易懂]很多时候我们需要把文件解压到当前目录,命令如下:tar-zxvfvscode-server-linux-x64.tar.gz-C./有时候很讨厌,因为tar.gz的包里就存在一个与压缩包同名的目录,这种情况的话需要先解压,再拷贝:tar-zxvfvscode-server-linux-x64.tar.gz-C./mvvscode-server-linux-x64/*….

    2022年5月11日
    72
  • 燃尽图_敏捷燃尽图

    燃尽图_敏捷燃尽图燃尽图(burndownchart)是在项目完成之前,对需要完成的工作的一种可视化表示。燃尽图有一个Y轴(工作)和X轴(时间)。理想情况下,该图表是一个向下的曲线,随着剩余工作的完成,“烧尽”至零

    2022年8月4日
    4
  • CAS单点登录(一)——初识SSO

    CAS单点登录(一)——初识SSO前言:其实好早就想把CAS的这一套知识整合一下,在工作上也应用到了这块,只是最近才在工作上接触到CAS,所以刚好把这些知识总结一下。这块可能是一个比较大的模块知识点,所以会有多篇文章进行逐一展开,笔者会尽量抽空更新,当然如果文章中存在错误,期望大家指出。一、初识CAS首先我们来说一下CAS,CAS全称为CentralAuthenticationService即中央认证服务,是一个企…

    2022年6月7日
    35

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号