JS基础学习5

学习内容:作用域(全局作用域,函数作用域),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

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值