HTML5+CSS3从入门到精通 offset大家族
沉沙 2018-09-10 来源 : 阅读 1217 评论 0

摘要:本篇教程探讨了HTML5+CSS3从入门到精通 offset大家族,希望阅读本篇文章以后大家有所收获,帮助大家HTML5+CSS3从入门到精通 。

本篇教程探讨了HTML5+CSS3从入门到精通 offset大家族,希望阅读本篇文章以后大家有所收获,帮助大家HTML5+CSS3从入门到精通 。

<

<!doctype html>
<html lang="en">
 <head>
  <meta charset="UTF-8">
  <meta name="Generator" content="EditPlus®">
  <meta name="Author" content="">
  <meta name="Keywords" content="">
  <meta name="Description" content="">
      <title>offset大家族</title>
      <style type="text/css">
      body,html{
         margin:0;
         padding:0;
         }
            .grandpa{
               margin-left:50px;
               width:500px;
               height:300px;
               background:#ff9933;
               position:relative;
               border:5px solid #33ff00;
            }
            .father{
              width:300px;
              height:300px;
              background:#ff3366;
              padding:20px;
              border:5px solid #ffff00;
            }
            .son{
              width:100px;
              height:100px;
              background:#0000ff;
              padding:10px;
              border:5px solid #ccffcc;
            }
      </style>
 </head>
 <body>
    <div class="grandpa">
      <div class="father" style="position:absolute;left:300px">
        <div class="son" style="left:300px" ></div>
      </div>
    </div>
    
    
   <script type="text/javascript">
       var father=document.querySelector(".father");
       var grandpa=document.querySelector(".grandpa");
       var son=document.querySelector(".son");
        
        console.log(son.offsetWidth);//130
        console.log(son.offsetHeight);//130
        console.log(son.offsetLeft);//25
        console.log(son.offsetTop);//25
        console.log(son.offsetParent.className);//grandpa
        console.log(son.parentNode);//<div class="father"></div>
        console.log(son.style.left);//300px  这里虽然获得300px 但是由于没有设置position属性所以不起作用
        console.log(father.style.left);//300px
        son.offsetLeft="300";
        console.log(son.offsetLeft);//20
        son.style.left="500px";
        console.log(son.style.left);
        /*
          offsetWidth    元素本身的宽度  content+padding+border  动态
          offsetHeight   元素本身的高度  content+padding+border  动态
          offsetLeft        此元素左外边框到有定位的长辈的边框距离  就近长辈
          offsetTop        此元素右外边框到有定位的长辈的边框距离  就近长辈 
          js没有right 和 bottom
          所以 right=son.offsetLeft+son.offsetWidth
                  top=son.offsetTop+son.offsetHeight
                  
                 1. son.style.left   访问的话只能得到行内的style值
                    
                  这样的div class="son" style="position:absolute;top:300px"></div>

                 2. 行内样式如果没有设置top值  style.top 得到的是空字符串 ""

                 3.offsetLeft 得到的是数字 30  而style.left得到的是字符串 30px

                 4.offsetLeft 是 onlyRead  就是只可以get  不能set   style.left 可以set  也可以get

                 5.offsetLeft 可以返回没有设置定位属性盒子的left 
                   而style.left 不行  没有设置定位属性的盒子没有left top属性
                   虽然可以获得行内设置的left   style.left  300px
                   <div class="box" style="left:300px"></div>
                   但是没有作用  因为没有设置position
                 

                 5.

                  如果想访问css style 还可以用以下方法
                  标准浏览器window.getComputedStyle(son)["left"];
                  IE  son.currentStyle("left");

               offsetParent  得到最近的有定位的长辈
               比较记忆
               parentNode   得到父节点  

            


        */
   </script>
 </body>
</html>

     

本文由职坐标整理并发布,希望对同学们有所帮助。了解更多详情请关注职坐标WEB前端HTML5/CSS3频道!

本文由 @沉沙 发布于职坐标。未经许可,禁止转载。
喜欢 | 1 不喜欢 | 0
看完这篇文章有何感觉?已经有1人表态,100%的人喜欢 快给朋友分享吧~
评论(0)
后参与评论

您输入的评论内容中包含违禁敏感词

我知道了

助您圆梦职场 匹配合适岗位
验证码手机号,获得海同独家IT培训资料
选择就业方向:
人工智能物联网
大数据开发/分析
人工智能Python
Java全栈开发
WEB前端+H5

请输入正确的手机号码

请输入正确的验证码

获取验证码

您今天的短信下发次数太多了,明天再试试吧!

提交

我们会在第一时间安排职业规划师联系您!

您也可以联系我们的职业规划师咨询:

小职老师的微信号:z_zhizuobiao
小职老师的微信号:z_zhizuobiao

版权所有 职坐标-一站式IT培训就业服务领导者 沪ICP备13042190号-4
上海海同信息科技有限公司 Copyright ©2015 www.zhizuobiao.com,All Rights Reserved.
 沪公网安备 31011502005948号    

©2015 www.zhizuobiao.com All Rights Reserved

208小时内训课程