学习内容:作用域(全局作用域,函数作用域),this关键字,构造函数
学习笔记:
作用域: ?? ??作用域指一个变量的作用范围 ?? ???在JS中有两种作用域,一个是全局作用域,一个是函数作用域
全局作用域:
直接编写在script标签中的JS代码,都在全局作用域;全局作用域在页面打开时创建,在页面关闭时销毁。在全局作用域中有一个全局对象window(代表着一个浏览器的窗口,它由浏览器创建),我们可以直接使用。在全局作用域中创建的变量都会作为window对象属性保存;创建的函数都会作为window对象的方法保存
实例:
加window也可以调用
?? ??? ??? ?全局作用域中的变量都是全局变量,在页面内的任意位置都可以访问;创建的函数都会作为window对象的方法保存;使用var关键字声明的变量,会在所有的代码执行之前被声明
变量的前向声明: ?? ??? ??? ?使用var关键字声明的变量,会在所有的代码执行之前被声明(但是不会被赋值) ?? ??? ??? ?但是如果声明变量时不使用var关键字,则变量不会被声明提前
?不使用var关键字则变量不会提前声明:
?函数的声明提前: ?? ??? ??? ?使用函数声明形式创建的函数function 函数(){}
function fun(){ ?? ??? ??? ??? ?document.write("我是一个fun函数"+"<br/>"); ?? ??? ??? ?}
?? ??? ? ? ?它会在所有代码执行之前就被创建,所以可以在函数声明前来调用函数
? ? ? ? ? ? fun(); ?? ??? ??? ?function fun(){ ?? ??? ??? ??? ?document.write("我是一个fun函数"+"<br/>"); ?? ??? ??? ?}
?? ??? ??? ?使用函数表达式创建的函数,不会被提前声明,所以不能在声明前调用
?函数作用域:
调用函数时创建函数作用域,函数执行完毕以后,函数作用域销毁;每调用一次就会创建一次函数作用域,它们之间是相互独立的;在函数作用域中可以访问到全局作用域的变量,但在全局作用域中访问不到函数作用域中的变量
当在函数作用域中操作一个变量时,它会先在自身作用域中寻找,如果有则直接使用,如果没有则向上一级作用域寻找(就近原则)
?在函数中要访问全局变量可直接使用window对象
?? ??? ??? ?在函数中,不使用var声明的变量都会成为全局变量
?? ??? ??? ?形参相当于在函数中声明了变量
?
this关键字:
在单独使用this时,拥有者是全局对象,因此?this?指的是全局对象。
在浏览器窗口中,全局对象是?[object Window]:
var x=this;
函数中的 默认this
在 JavaScript 函数中,函数的拥有者默认绑定?this。
因此,在函数中,this?指的是全局对象?[object Window]。
?function fun(){
return this;
}
?解析器再调用函数每次都会像函数内部传进一个隐含参数,这个隐含参数就是this,this指向的是一个对象,这个对象我们称为函数执行的上下文对象;根据函数的调用方式不同,this会指向不同的对象 ?? ??? ??? ?1.以函数形式调用,this永远是window ?? ??? ??? ?2.以对象方法调用时,this就是调用方法的那个对象? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? 3.当以构造函数调用时,this就是新创建的那个对象
?
?如果不用this关键字,那么这个代码里的name将会被锁死
?构造函数:
一般构造函数首字母大写 ?? ??? ??? ?构造函数和普通函数的区别就是调用方式不同,普通函数是直接调用,而构造函数需要使用new关键字来调用 ?? ??? ??? ?构造函数的执行流程: ?? ??? ??? ?1.立刻调用新的对象 ?? ??? ??? ?2.将新建的对象设置为函数中的this,在构造函数中可以使用this来引用新建的对象 ?? ??? ??? ?3.逐行执行函数中的代码 ?? ??? ??? ?4.将新建的对象作为返回值的返回
?function Person(name,age,gender){ ?? ??? ??? ??? ?this.name=name; ?? ??? ??? ??? ?this.age=age; ?? ??? ??? ??? ?this,gender=gender; ?? ??? ??? ??? ?this.sayName=function(){ ? ? ? ? ? ? ? ? ? ? console.log(this.name); ?? ??? ??? ??? ?}; ?? ??? ??? ??? ?}
使用同一个构造函数创建的对象,我们称为一类对象,也将一个构造函数称为一个类 ?? ??? ??? ? 我们将通过一个构造函数创建的对象称为该类的实例
?? ??? ??? ? 使用instanceof可以检查一个对象是否是一个类的实例 ?? ??? ??? ? 语法: ?? ??? ??? ? 对象instanceof 构造函数;如果是,则返回true,否则返回false
?? ??? ??? ? 所有对象都是Object的后代,所有对象 instanceof Object 都会返回true
?
|