网创优客建站品牌官网
为成都网站建设公司企业提供高品质网站建设
热线:028-86922220
成都专业网站建设公司

定制建站费用3500元

符合中小企业对网站设计、功能常规化式的企业展示型网站建设

成都品牌网站建设

品牌网站建设费用6000元

本套餐主要针对企业品牌型网站、中高端设计、前端互动体验...

成都商城网站建设

商城网站建设费用8000元

商城网站建设因基本功能的需求不同费用上面也有很大的差别...

成都微信网站建设

手机微信网站建站3000元

手机微信网站开发、微信官网、微信商城网站...

建站知识

当前位置:首页 > 建站知识

JavaScript中函数进阶是怎样现进行的

JavaScript中函数进阶是怎样现进行的,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。

创新互联主要从事做网站、成都网站建设、网页设计、企业做网站、公司建网站等业务。立足成都服务铁力,10余年网站建设经验,价格优惠、服务专业,欢迎来电咨询建站服务:028-86922220

全局作用域

· 全局作用域是最大的作用域

· 在全局作用域中定义的变量可以在任何地方使用

· 页面打开的时候,浏览器会自动给我们生成一个全局作用域 window

· 这个作用域会一直存在,直到页面关闭就销毁了

// 下面两个变量都是存在在全局作用域下面的,都是可以在任意地方使用的var num = 100var num2 = 200

局部作用域

· 局部作用域就是在全局作用域下面有开辟出来的一个相对小一些的作用域

· 在局部作用域中定义的变量只能在这个局部作用域内部使用

· 在 JS 中只有函数能生成一个局部作用域,别的都不行

· 每一个函数,都是一个局部作用域

// 这个 num 是一个全局作用域下的变量 在任何地方都可以使用var num = 100

function fn() {

  // 下面这个变量就是一个 fn 局部作用域内部的变量  // 只能在 fn 函数内部使用  var num2 = 200}

fn()

变量使用规则(重点)

· 有了作用域以后,变量就有了使用范围,也就有了使用规则

· 变量使用规则分为两种,访问规则 和 赋值规则

访问规则

· 当我想获取一个变量的值的时候,我们管这个行为叫做 访问

· 获取变量的规则:

· 首先,在自己的作用域内部查找,如果有,就直接拿来使用

· 如果没有,就去上一级作用域查找,如果有,就拿来使用

· 如果没有,就继续去上一级作用域查找,依次类推

· 如果一直到全局作用域都没有这个变量,那么就会直接报错(该变量 is not defined)

var num = 100

function fn() {

  var num2 = 200

  function fun() {

    var num3 = 300

    console.log(num3) // 自己作用域内有,拿过来用    console.log(num2) // 自己作用域内没有,就去上一级,就是 fn 的作用域里面找,发现有,拿过来用    console.log(num) // 自己这没有,去上一级 fn 那里也没有,再上一级到全局作用域,发现有,直接用    console.log(a) // 自己没有,一级一级找上去到全局都没有,就会报错  }

  fun()}

fn()

· 变量的访问规则 也叫做 作用域的查找机制

· 作用域的查找机制只能是向上找,不能向下找

function fn() {

  var num = 100}fn()

console.log(num) // 发现自己作用域没有,自己就是全局作用域,没有再上一级了,直接报错

赋值规则

· 当你想给一个变量赋值的时候,那么就先要找到这个变量,在给他赋值

· 变量赋值规则:

· 先在自己作用域内部查找,有就直接赋值

· 没有就去上一级作用域内部查找,有就直接赋值

· 在没有再去上一级作用域查找,有就直接赋值

· 如果一直找到全局作用域都没有,那么就把这个变量定义为全局变量,在给他赋值

function fn() {

  num = 100}fn()

// fn 调用以后,要给 num 赋值// 查看自己的作用域内部没有 num 变量// 就会向上一级查找// 上一级就是全局作用域,发现依旧没有// 那么就会把 num 定义为全局的变量,并为其赋值// 所以 fn() 以后,全局就有了一个变量叫做 num 并且值是 100console.log(num) // 100

看完上述内容,你们掌握JavaScript中函数进阶是怎样现进行的的方法了吗?如果还想学到更多技能或想了解更多相关内容,欢迎关注创新互联行业资讯频道,感谢各位的阅读!


当前名称:JavaScript中函数进阶是怎样现进行的
当前网址:http://bjjierui.cn/article/gdjpde.html

其他资讯