js注意点自结篇

1.绑定事件的区别

   ele.addEventListener(type,fn,false)   ele.attachEvent('on'+type,fn)

   谷歌,火狐,IE11                                            IE8

   this表示ele(当前绑定事件的对象)                    this表示window

   3个参数                                                           2个参数

   事件类型无on                                                  事件类型带on 

2.事件三个阶段 (e.eventPhase)

   ①捕获阶段 :从外向里

   ②目标阶段 :最开始选中的那个

   ③冒泡阶段 :从里向外

3.addEventListener中的第三个参数控制事件的阶段

   fasle 冒泡阶段

   true  捕获阶段

4.阻止事件冒泡

   IE8  window.event.cancelBubble = true;

   其他  e.stopPropagation()

5.事件参数e在IE8中不存在,所以用window.event来代替

6.页面加载事件

   什么叫页面加载完毕?

          页面中所有的内容,标签,属性,文本,包括外部引入的js文件

   window.onload = function () {

   }

7.location对象

   window.location.hash  // 地址栏上#后面的内容

                             host   // 主机名+端口号

                             hostname // 主机名

                             pathname // 地址栏的虚拟路径

                             port // 端口号

                             protocol // 协议

                             search // get请求后面的参数带?

8.history对象

   window.history.forward();

                           back();

9.navigator对象

   window.navigator.userAgent;// 判断用户浏览器的类型

   window.navigator.platform;// 系统平台类型

10.定时器的 编写 和 清除!!

     var timeId = setInterval(fn,1000)  // 1000ms = 1s

     window.clearInterval(timeId)

11.offset系列

     ele.offsetParent

     ele.offsetWidth    // 元素的宽,有边框

     ele.offsetHeight   // 元素的高,有边框

     ele.offsetLeft       // 元素距离左边位置的距离

     ele.offsetTop       // 元素距离上面位置的距离

     

     未脱离文档流的情况下

     offsetLeft: (所有父级元素margin + border+padding)+自己的margin

     脱离文档流的情况下

     offsetLeft:自己的left + 自己的margin

12.document获取固定元素

     document.body // body

     document.title  // 标签中的值

     document.documentElement // html

13.图片跟着鼠标飞

    document.onmousemove = funciton(e) {

        $('img').style.left = e.clientX + 'px';

        $('img').style.top = e.clientY + 'px';

    }

14.scroll系列

     ele.scrollWidth  // 元素中内容的实际宽度(如果内容很少,元素自身的宽),无边框

     ele.scrollHeight // 元素中内容的实际高度(如果内容很少,元素自身的高),无边框

     ele.scrollLeft // 向左卷曲出去的距离

     ele.scrollTop // 向上卷曲出去的距离

15.无论是否脱标获取left值

if(window.getComputedStyle){

    return window.getComputedStyle(ele,null)[attr];

}else {

    return ele.currentStyle[attr];

}

16.client系列(可视区域)

     clientWidth  // 可视区域的宽(没有边框),边框内部的宽度

     clientHeight // 可视区域的高(没有边框),边框内部的高度

     clientLeft     // 左边边框 的宽度

     clientTop     // 上边框 的宽度 

17.判断函数传入几个参数

     arguments.length,arguments[0]

     IE8不支持,e也没有,用window.event来代替

     兼容:

            e = window.event || e;

    IE8不能用e.pageX 和 e.pageY

    最终:clientX + 卷曲出去的距离

18.父级元素事件冒泡,必须是是相同事件才能阻止

     

19.字符串大量拼接浪费空间

     解决方案

var str = [];
for(var i =0;i<10;i++){
    str.push(i +'');
}
console.log(str.join('|'));

20.自调用函数,是为了防止变量名冲突

      (function(){

            ......

      }());

     自调用函数里面定义的函数外面无法调用

21.宁愿用函数表达式也不用函数声明,因为函数声明在IE8中预解析的时候会有问题

22.this 

     普通函数中的this:window

      定时器中的this:window

      构造函数中的this:实例对象

      对象的方法中的this:实例对象

      对象的原型方法中的this:实例对象

23.严格模式

     "use strict";  //===》严格

      function f1(){

          console.log(this);

      }

      f1();  // ===>undefined

      window.f1();// ===>Window......

24.函数也是对象,对象不一定是函数

     对象中应该有__proto__原型

     函数中应该有prototype原型

      如果一个东西里面既有__proto__又有prototype则,既是函数又是对象

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值