定时器
声明定时器
var timer = setInterval(function{},1000);//每隔1000毫秒执行一次
清除器定时器
clearInterval(timer);
JS的严格模式
'use strict'采用js的严格模式 其中规定了命名规范以及语法限制
全选 反选
全选:check[i].checked = true;
反选:check[i].checked = !check[i].checked;
获取行间样式
ie:ele.currentstyle(attr);
其他浏览器:window.getcompatedstyle(obj).attr;
JS常见的错误(异常)
- undefined 定义了但是没有赋值
- ReferenceError 引用错误 表明一个不存在的变量被引用了
- TypeError 类型错误
JS的解析过程
alert(a);//undefined
var a = 10;
alert(a);//10
a=10;//赋值 声明优先与赋值
var a;//声明
alert(a);//10
a();//TypeError
var a = function xq(){//匿名函数一般不写名称
alert(xq);
}
a();//可以
xq();//引用错误 xq未定义
fn();//弹出1 无错误
function(){
alert(1);
}
总结:var a =10;分为两个步骤 第一是声明(编译阶段) 第二是赋值(执行阶段)
编译阶段:依次找到所有的声明 变量的定义;函数的定义(有名函数) 这时所有定义都会被提升到当前作用域的顶端 但局部变量(函数内部)不会
执行阶段:依次执行可以执行的代码 包括赋值操作 函数的执行 以及运算等
alert(a);//弹出function
function a(){};
var a; //函数优先级高于变量
alert(a);//function
function a(){};
var a = 10;
alert(a);//10
作用域
var num = 20;
function fn(){
num=10;
};
alert(num);//20
var num = 20;
function fn(){
num=10;
};
fn();
alert(num);//10
if(true){
var a = 1;
}
alert(a);//1 能取到
for(var i =0;i<5;i++){
}
alert(i);//能取到
if(true){
let a = 1;
}
alert(a);//取不到