位置: 编程技术 - 正文

Javascript学习笔记3 作用域(javascript基础笔记)

编辑:rootadmin
在Javascript,全局环境本身就一个对象。在浏览器宿主中这个对象是window,而当Javascript用于其它非浏览器的宿主,如嵌入式的环境中,可能会是其它的对象。 在这里也纠正一个观念,有很多人都认为Javascript只在浏览器中使用,其实Javascript也能在很多非Web情况下使用,据介绍Javascript在一些基于嵌入式的应用领域表现得也很出色,当然这些我也只是听过传说而已。 言归正传,当我们写下:var i=1时,其实就是声明了一个window作用域的一个变量。 而当我们写下i=1时,是声明了一个window的属性。 看这样一段代码: [Ctrl+A 全选 注:如需引入外部Js需刷新才能执行] 这段代码分别输出的结果是:undefined world,welcome china, hello china. 我们来分别解释: 在上文中,我们说过,在Javascript预编译时,会把所有var变量创建,默认值为undefined,我们在这里可以举一个例子: 我们可以写这样一段代码: [Ctrl+A 全选 注:如需引入外部Js需刷新才能执行] 当我们执行运行这段脚本时,可以发现,首先弹出undefined,然后回提示脚本错误,提示b不存在。由此就可以表明,a在预编译的过程中就已经被创建并且初始化为undefined,而b却只能在实际运行时按顺序去解释。其实在预编译后的Javascript代码可以近乎理解如下: [Ctrl+A 全选 注:如需引入外部Js需刷新才能执行] 接下来我们可以谈一下函数的作用域问题,每当代码运行进入一个函数时,Javascript引擎就会自动创建一个新的作用域,然后把这个新作用域作为当前作用域的子作用域,然后把当前的代码作用域切换到这个新作用域。当代码退出函数时,这个作用域销毁,把代码作用域交还给他的父作用域。 好,准备工作差不多了,接下来我们就来解释第一个问题:问什么会输出undefined world。 首先代码进行在预编译,当进入 Test方法时,开启一个新作用域,然后把全局作用域作为他的父作用域。然后对Test内的方法进行预编译,和上面的代码一样,Test方法被预编译后方法体大致如下: 当然,在当前作用域下无法找到b,于是他就会到他的父作用域下,也就是全局作用域找到了b=“world”。于是也就产生了这样的结果。 第二次弹出welcome china,没什么好说的。 第三次,弹出hello china。我们可以这样理解,var a 只是 方法Test的一个局部变量,而b由于事先未声明,因此他会去父作用域中去找到对应的定义。 好,接下来,我们再看一下这个方法的若干个变体。 [Ctrl+A 全选 注:如需引入外部Js需刷新才能执行] 首先,我们将方法体内的var a改成a,我们先不看答案,直接来分析,首先,在预编译阶段,方法体内几乎没有任何改变,因此此时a和b一样,都要去他们的父作用域中去寻找,因此第一次出的结果应该是hello world,第二次没什么说的:welcome china,第三次由于a和b在本作用域内都没有事先定义,因此都是再改变父作用域内的值,因此应该输出welcome china. 我们继续: [Ctrl+A 全选 注:如需引入外部Js需刷新才能执行] 和上面的分析一样,应该输出undefined undefined,welcome china,hello world. 继续: [Ctrl+A 全选 注:如需引入外部Js需刷新才能执行] 应该是undefined world,welcome china,hello china. 经试验,都没问题, 不知道你明白了么? 因此我们可以得出,每个变量在找不到自己的定义时,都会沿着作用链向上寻找,这样就很可能会出现未预知的错误,给排错添加了很多困难。更麻烦的是,还可能会对父作用域上的变量值进行修改,因此我们在声明变量时应该尽量加上var,尽管Javascript并不强迫我们这样做。

推荐整理分享Javascript学习笔记3 作用域(javascript基础笔记),希望有所帮助,仅作参考,欢迎阅读内容。

Javascript学习笔记3 作用域(javascript基础笔记)

文章相关热门搜索词:javascript教程,javascript教程推荐知乎,javascript学习指南,javascript教程,javascript教程推荐知乎,javascript教程推荐知乎,javascript教程推荐知乎,javascript教程推荐知乎,内容如对您有帮助,希望把文章链接给更多的朋友!

Javascript学习笔记4 Eval函数 eval的作用其实很简单,就是把一段字符串传递给JS解释器,由Javascript解释器将这段字符串解释成Javascript代码,并且执行他。举个最简单的例子:scripttyp

Javascript学习笔记5 类和对象 面向对象语言三大特点:继承,多态,封装,这三点虽然Javascript没有提供天然的语法实现,但是我们都可以通过prototype等技巧来实现,因此这种说法似

Javascript学习笔记6 prototype的提出 首先我们继续上文的代码,我们来把这段代码延伸一下:scripttype="text/javascript"varPerson=function(name,age){this.name=name;this.age=age;this.Introduce=function(){alert("Mynamei

标签: javascript基础笔记

本文链接地址:https://www.jiuchutong.com/biancheng/382896.html 转载请保留说明!

上一篇:Javascript学习笔记2 函数(javascript教程推荐知乎)

下一篇:Javascript学习笔记4 Eval函数(javascript要怎么学)

  • 特许权使用费所得包括
  • 国债利息收入计入财务费用吗
  • 银企对账如何操作
  • 暂估工资成本
  • 防雨棚设计规范
  • 本月支付上月运费
  • 福利费用计入
  • 小规模纳税人如何纳税
  • 企业转增股本要交税吗
  • 没有发票怎么报销入账
  • 买酒专票怎么可以抵税
  • 借款合同 增值税
  • 一般纳税人开普票多少个点
  • 公允价值变动损益是什么意思
  • 税收分类编码选错了会罚款么
  • 购车时服务费用怎么算
  • 土地增值税的纳税人是在我国境内
  • 支付短期借款利息
  • 谷歌浏览器adobe flash player已不再支持
  • 月末计提电费
  • bios设置教程视频
  • win10开机启动项怎么删除
  • 王者荣耀中哪吒的图片
  • 支付宝流量红包怎么取消
  • 未售车位出租有哪些税要缴纳
  • 用约当产量法怎么计算约当总产量
  • 汇算清缴应补税额小于400
  • 商住房买卖过户流程
  • mapbox wms
  • 翡翠湾攻略
  • 行政事业单位 银行
  • 恩智浦杯官网
  • php使用( )关键字来创建对象
  • 所得税季报资产总额怎么算
  • 基于用户的协同过滤算法
  • 人类记忆存储在哪
  • 购买方红字信息表已开销售方系统查不到
  • 供货单位与开票单位不一致
  • 年终奖税金怎么扣
  • phpcms添加内容
  • PostgreSQL教程(四):数据类型详解
  • 哪些发票不可以报销入账
  • 加计抵减与加计抵消区别
  • 进项税有余额在报表如何反应
  • 融资性售后回租承租方出售资产为什么不缴纳增值税
  • 去年的管理费用多做了今年怎样调账
  • 上月暂估的成本这月收到票怎么做
  • 科技专项资金的考核指标确需调整
  • 原材料暂估入库是什么意思
  • 个体工商户怎么变更法人
  • 今年缴纳上年的税收滞纳金
  • 接受捐赠固定资产存货等有相关凭据的其成本按什么确定
  • 承兑汇票需要做账吗
  • 企业购买的原材料确认为资产,这属于会计确认的范畴
  • 公司注册实收资本
  • 结转生产成本是负数怎么办
  • oracle忘记用户名密码怎么办
  • 数据库连接说明
  • xampp修改mysql默认密码的方法
  • sqlserver数据库和mysql区别
  • win7系统双击不能打开我的电脑
  • Windows Server 2008关闭闲置状态的IDE通道
  • linux系统中的输入输出分为三类
  • IPad怎么连接电视机看看影视
  • linux常用命令详解
  • ubuntu系统升级 开机黑屏怎么解决
  • win1020h2镜像
  • windows8输入法
  • shell脚本数组的用法
  • bootstrap技术
  • 被调用的对象已与其客户端断开连接怎么办
  • html+css网站设计基础教程
  • bootstrap 多级菜单
  • excel一行首尾互换
  • unity sliced
  • jquery创建map集合
  • 个人开个什么公司比较好
  • 国税电子税务局官网
  • 广西电票科技有限公司
  • 肉类零售
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设