1.CSS盒子模型包括四个部分组成:设定的宽高+padding+border+margin;
2.JS盒子模型:通过系统提供的属性和方法,来获取当前元素的样式值
  JS提供的属性和方法:
  1. client系列:clientWidth,clientHeight,clientLeft,clientTop;
  2. offset系列: offsetWidth,offsetHeight,offsetLeft,offsetTop,offsetParent
  3. scroll系列:scrollWidth,scrollHeight,scrollLeft,scrollTop
3.关于父级
 1)parentNode  结构父级
 2)offsetParent  定位父级
4.JS提供的属性和方法:
1)clientWidth/clientHeight:元素设定的宽/高+左右padding值/上下padding值;
      clientLeft/clientTop:代表对应左边框/上边框的宽度;
     **跟内容是否溢出无关;
2)offsetWidth:clientWidth/clientHight+左右border/上下border;
     offsetLeft:当前元素的外边框距离定位父级内边框的距离;
    **跟内容是否溢出无关;
3)scrollHeight::
      跟内容是否溢出有关
     内容溢出:约等于上padding+真实内容的高度;
     内容没溢出:等于clientWidth或clientHeight;
      为什么是约等于?
      ①不同浏览器中,拿到的scrollHeight值是不同的;
      ②同一浏览器是否溢出隐藏,拿到的值不同;
5.关于JS盒子模型的一些问题
1)通过JS的属性和方法拿到的都是属性的复合 样式,拿不到单独的值;getCss;
2)拿到的复合样式值都是整数,不会出现小数;
3)offsetLeft只能求出当前元素的外边框距离定位元素父级的内边框之间的距离,但是求出与定位元素距离body的距离;—offset{left,top}
4)JS盒子模型的兼容性存在问题;—clientWidth,scrollHeight__—win
6.关于浏览器的常用兼容处理思想
 ①思想一,属性值的判断:
  • attr in window
  • obj.attr
  • typeOf obj.attr==‘function'
②思想二,浏览器异常捕获:try{……}  catch(e){……}  finally{……}
③思想三,通过浏览器判断处理浏览器兼容问题;
     var reg=/MSTE (6|7|8)/g;
  • reg.test(window.navigator.userAgent);//true:IE678;
  • window.navigator.userAgent.match(reg );true —>ie678
  • window.navigator.userAgent.search(reg); !==-1—>ie678
7.结构父级中最大的是HTML;定位父级中最大的元素是body;
8.this的用法
1)当前元素被触发的时候,会调用一个函数,函数中的this指向当前这个元素;

2)函数被调用的时候,点前面是谁,this就是谁

3)自执行函数中的this,window;

4)构造函数中的this是实例;

5)回调函数中的this默认是window;
6)call可以改变this指向
9.类和实例
//给类添加私有属性,跟实例没有任何关系;
//实例:可以使用自己的私有属性和方法,也可以使用原型上的公有方法,但实例无法使用类的私有属性和方法;
function Fn(){

    this.aa=123;//给实例添加私有属性;
}
Fn.aa=456;//给类添加私有属性;
var f=new Fn();
alert(f.aa);
alert(Fn.aa)
 
 
   
 
 
 
 
 
 
 
 

JS学习:第二周——NO.3盒子模型的更多相关文章

  1. 【吴恩达课后测验】Course 1 - 神经网络和深度学习 - 第二周测验【中英】

    [中英][吴恩达课后测验]Course 1 - 神经网络和深度学习 - 第二周测验 第2周测验 - 神经网络基础 神经元节点计算什么? [ ]神经元节点先计算激活函数,再计算线性函数(z = Wx + ...

  2. 201671010140. 2016-2017-2 《Java程序设计》java学习第二周

                                 学习第二周(Java基本程序设计结构)      这一周,着重学习了Java的简单程序设计实现及运行,通过自己操作,发现Java的程序语法大面 ...

  3. H5学习第二周

    怎么说,在各种感觉中h5学习的第二周已经过来了,先总结一下,感觉学习h5是一件让我爱恨交加的事,学会一些新的知识并把它成功运行出来的时候是非常激动和兴奋的,但是有时候搞不懂一个标签或者属性的时候,就有 ...

  4. CSS3与页面布局学习笔记(二)——盒子模型(Box Model)、边距折叠、内联与块标签、CSSReset

    一.盒子模型(Box Model) 盒子模型也有人称为框模型,HTML中的多数元素都会在浏览器中生成一个矩形的区域,每个区域包含四个组成部分,从外向内依次是:外边距(Margin).边框(Border ...

  5. Java学习第二周学习笔记

    20145307<Java程序设计>第二周学习总结 教材学习内容总结 Java语言中的很多基本语法都和C语言类似,以下Java中的基本语法 标识符 标识符是程序中自定义的一些名称. 由26 ...

  6. CSS学习笔记(float和盒子模型)

    1.当元素或者是它的包裹层设置了绝对定位或者是浮动,那么margin:0 auto;自动居中的效果就不会实现. 2.盒子模型的三位立体结构图中从第一层到第五层依次为:border.content+pa ...

  7. IP通信基础学习第二周

    此周的课程学习应该算是我对此科目真正学校生涯的开始吧,尽管我对该科目仍感到很陌生. 课程一开头,老师就给我们简单的介绍了网络的定义.发展及其分类,重点讲了网络拓扑结构及其在局域网上具体的分层情况.该部 ...

  8. Java学习第二周

    这一周观看了黑马程序员毕向东的教学视频学习了数组的创建:数组元素的使用及遍历,类的声明,成员方法的声明,构造器的声明 数据类型[] 数组名 = new 数据类型[长度];数据类型[] 数组名 = {数 ...

  9. JS学习第二课

    <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...

随机推荐

  1. 【repost】js中(function(){…})()立即执行函数写法理解

    摘要: javascript和其他编程语言相比比较随意,所以javascript代码中充满各种奇葩的写法,有时雾里看花,当然,能理解各型各色的写法也是对javascript语言特性更进一步的深入理解. ...

  2. jsp基础

    1.1动态页面 动态页面的优势: 1.交互性:网页会根据用户的要求和选而动态改变和显示内容; 2.自动更新:无需改变页面代码,便会自动更新的页面内容; 3.随机性:当不同的时间,不同的人访问同一网址时 ...

  3. mac机上搭建php56/nginx 1.8.x/thinkphp 3.2.x/gearman扩展/seaslog扩展/redis扩展环境

    php的各种扩展配置起来实在不容易,记录一下备忘: 一.php56 安装 虽然php7出来了,但是没用过,不知道有没有坑,这里仍然使用php5.6版本 1.1 安装php/php-pfm brew u ...

  4. 自动化运维工具ansible部署以及使用

    测试环境master 192.168.16.74webserver1 192.168.16.70webserver2 192.168.16.72安装ansiblerpm -Uvh http://ftp ...

  5. 1001 数组中和等于K的数对 1090 3个数和为0

    二分查找.对数组每个V[i],在其中查找K-V[i],查找完成后修改v[i]避免重复输出 #include<iostream> #include<algorithm> #inc ...

  6. Socket通信类

    package com.imooc; import java.io.BufferedReader; import java.io.IOException; import java.io.InputSt ...

  7. Linux 基础操作

    根据关键字查找文件信息: cat <文件名> | grep <关键字>查询文件信息 显示100行: tail -100f easyhome.all.log |grep &quo ...

  8. 关于若干php 表单 的重新审视

    对于表单验证来说 应该在任何可能的时候对用户输入进行验证(通过客户端脚本).浏览器验证速度更快,并且可以减轻服务器的负载. 如果用户输入需要插入数据库,您应该考虑使用服务器验证.在服务器验证表单的一种 ...

  9. 用上了ReSharper

    用上了ReSharper,发现很爽1.使用var2.去掉无用的using3.将foreach改为linq let4.字符串为cost5.作用域与变量名适配6.文件夹与namespace不匹配7.去掉为 ...

  10. 【BZOJ-1656】The Grove 树木 BFS + 射线法

    1656: [Usaco2006 Jan] The Grove 树木 Time Limit: 5 Sec  Memory Limit: 64 MBSubmit: 186  Solved: 118[Su ...