位置: 编程技术 - 正文

JavaScript预解析及相关技巧分析(js函数预解析)

编辑:rootadmin

推荐整理分享JavaScript预解析及相关技巧分析(js函数预解析),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:js的预处理,javascript解析引擎,css预解析,javascript预解析的作用,js解析机制,css预解析,javascript预解析的作用,javascript预解析的作用,内容如对您有帮助,希望把文章链接给更多的朋友!

本文实例讲述了JavaScript预解析及相关技巧。分享给大家供大家参考,具体如下:

变量

同样,以这两个小例子的错误对比提示开始。

先思考一下,为什么一个会提示 undefined , 一个却抛出变量未定义的错。。先看JavaScript的解析过程。

javascript在执行过程之前,会做一件事件“预解析”。解析引擎会以块为单位级别,执行所有 var 变量的创建,并赐予它们一个初始值:undefined。这样一来,第一个例子为什么会弹出undefined的原因就显而易见了。

所以第一段代码其实就等价于

那第二段代码为什么又抛错呢,此时就不再属于“预解析”阶段了,(在这里我假设浏览器遇到一个script标签时只做两件事:预解析和执行,其实不 只这两件事情),而处于执行阶段,抛错原因在于js在执行段状态并不知晓y2的状态(预解析阶段没有捕获到y2的任何信息),当然就抛出未定义的错误信 息。这里又牵扯到另一个问题: js 是弱类型语言,变量不定义可以用,那为什么这里又抛出为定义错误呢。

事出总有因,javascript总有很多自身奇怪的特性,有一个叫变量的读写不均等。未定义的变量,仅仅是可写,并不可读。何为可写,每个人都熟悉这样的写法:

但在对它的读操作,js引擎搜寻不到它的任何相关信息,就以自己的脾气行事,毫不客气抛一个未定义的错,这是js的游戏规则。还有但是,那为什么却 可以获取它的类型呢。还记得 js对对象的操作吧。如果访问对象一个不存在的属性及类型,会提示undefined, (因为它当前是window对象的一个属性)。

再注:这里需要区分, 变量的读写不均等 仅用于变量,读取所有对象的属性,不存在该特性,如果不存在,会提示undefined。

结论

到这里,我的思考结果: 对于变量和对象的写操作,他们有一定的类似之处.但是读操作,各有各的一套规则,正因为此,所以有了上面的问题。这样一来,下面这个题应该就很容易得到答案了吧。

函数

引申一下,function. 还记得上面提到的预解析,在javascript的预解析中,除了对var 变量的预定义,还包括了提取对函数的定义,所以可以在script的任何地方定义函数,在任何地方调用。不限于它之前.

JavaScript预解析及相关技巧分析(js函数预解析)

但函数的定义方式,包括了一种叫字面量定义法, 用var的方法声明function.看下面

还记得这个约定吧:调用必须出现在声明之后,为什么呢,如果理解了上面,其实这里答案已经明了。javascript 引擎在预解析 var 时 会给他们一个初始值 undefined,这样一来,如果我们在它的声明之前调用它,javascript 引擎还没拿到它的真实值,自然会报"xxx is not a function" 的错.这也理清了为什么同为函数声明,一个却关系到声明和调用的顺序,一个却无这样的约束。

结论

它是函数,是js执行,动态修改的结果,依然遵循了变量的预解析规则(在上面alert的时候,它还并没有拿到字面量函数的信息)。如果是两个混合呢。看下面, 同时存在了为y4的变量和function。

因为 javascript 在预解析时function的声明优先级高的缘故,所以y4自然为function类型, 但是在当y4 赋值之后(此时js引擎处于执行过程中),它对js的赋值操作将会覆盖function的声明。所以:

第一次alert结果,因为它处于js 执行过程中的顶端,所以为 function。 第二次再alert时, 它的值已经被重写为5(不要被function的定义位置在下所迷惑。)

从js的解析和执行分开来想,才发现眼前豁然开朗,很多问题的答案都很自然得浮出水面,正如那篇文章作者所说,"一旦理解了执行环境、调用对象、闭包、词法作用域、作用域链这些概念,JS语言的很多现象都能迎刃而解。"

现在再看,即使在这个存在着很多不可思议的语言中,也有很多可以追溯到它的缘由。

如何更好的做参数判断

讨论了上面那么多,那如何让它更贴近于实际开发呢,既然javascript的读写不均等性,如何才能避免在不报错的情况下做参数判断呢。

eg:

如何严谨一些呢。

最后补充又一个小quiz, (理解 预解析与执行的分离)

更多关于JavaScript相关内容感兴趣的读者可查看本站专题:《JavaScript切换特效与技巧总结》、《JavaScript查找算法技巧总结》、《JavaScript动画特效与技巧汇总》、《JavaScript错误与调试技巧总结》、《JavaScript数据结构与算法技巧总结》、《JavaScript遍历算法与技巧总结》及《JavaScript数学运算用法总结》

希望本文所述对大家JavaScript程序设计有所帮助。

JS动态插入并立即执行回调函数的方法 本文实例讲述了JS动态插入并立即执行回调函数的方法。分享给大家供大家参考,具体如下:!DOCTYPEhtmlPUBLIC"-//W3C//DTDXHTML1.0Transitional//EN""

动态加载js文件简单示例 本文实例讲述了动态加载js文件的方法。分享给大家供大家参考,具体如下:functionloadScript(url){varhd=document.getElementsByTagName('head')[0],js=document.createElement('s

javascript常见数字进制转换实例分析 本文实例讲述了javascript常见数字进制转换的方法。分享给大家供大家参考,具体如下:基本思路是先把其他进制的转化成十进制,然后再转化。这个过

标签: js函数预解析

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

上一篇:JavaScript实现显示函数调用堆栈的方法(js显示nan)

下一篇:JS动态插入并立即执行回调函数的方法(js动态添加dom)

  • 摊薄净资产收益率是什么意思
  • 纳税人为风险纳税人
  • 研发费用明细账
  • 主营业务收入借方发生额表示什么
  • 个体工商户增值税怎么计算
  • 工程图纸设计费用收费标准
  • 知道税负率和收入怎么算进项
  • 税务局三代手续费政策
  • 政府会计制度银行存款利息咋处理
  • 发票与入库单明细不一致税务可以吗
  • 收取车辆使用费怎么做账
  • 企业如何实现合理利润
  • 增值税零税率与免税有何不同
  • 外贸企业出口采购流程
  • 固定资产减少会怎么样
  • 汽车按揭费用收合法吗?
  • 退货的产品会重新包装吗
  • 上月未申报纳税补申报怎么做不会有罚款吗?
  • 6位数开票代码
  • 国有划拨地是否能转让土地
  • 正确解读《非居民金融账户涉税信息尽职调查管理办法》
  • 用友t3财务报表模块打不开
  • 发票超过标准可以报销吗
  • 创新券兑付怎么操作
  • 工会经费什么时候返还给企业
  • 免征增值税项目销售额含税吗
  • 供应商开免税的发票,为何还要收3个点税金?
  • 财务费用属于什么会计科目类别
  • 结转基本生产成本
  • QuickBooks - QuickBooks是什么进程 有什么用
  • win7如何设置高级网卡功能适合玩网络游戏
  • 余款退回会计分录
  • 国家减免税收
  • 新成立公司开票能开多少个点的发票
  • mac键盘快捷键设置
  • 财政部土地出让收支管理办法
  • 应付账款与其他应付款科目调整
  • 门面出租赚钱吗
  • 增值税报表填报说明
  • 企业付检测费的会计科目
  • vscode终端显示
  • 资产减值损失的借贷方向
  • python中for循环的缩进规则
  • 增值税纳税申报表怎么填
  • 融资租赁方式的条件
  • 调整未分配利润影响所得税吗
  • 已经认证抵扣的发票怎么红冲
  • 房屋消防工程
  • 劳务费发票入账科目
  • 原材料计入什么摘要
  • 上月的普票下月可以记账么
  • 采购的样品没有发票怎么入账
  • 搞活动的现金红包怎么用
  • 代收运输费的会计分录
  • 公益性捐赠会计利润总额计算方法
  • 跟老师出差路上可以聊些什么
  • 小规模公司用什么成本核算方法
  • 商业承兑汇票提示付款流程
  • 未达起征点可以申请一次性创业补贴吗
  • 记账凭证先写借方还是贷方
  • 招标代理服务费计算器在线
  • 加盟创业成功案例分析
  • php连接mysql的步骤代码
  • xp系统怎么提升性能
  • winpe安装系统教程
  • os x10.11el capitan beta4更新了什么?os x10.11el capitan beta4下载地址
  • linux系统批量替换内容
  • acer笔记本重装系统教程
  • windows10的便签纸在哪
  • linux mds
  • linux page buffer cache深入理解
  • linux find命令详解xargs
  • javascript折叠菜单
  • cocos2dx官方教程
  • opengl opengl
  • javascript语言介绍
  • unity3d2019安装步骤
  • javascript HTML+CSS实现经典橙色导航菜单
  • 安徽国家税务局网上办税平台
  • 北京市延庆区城管执法局
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设