位置: 编程技术 - 正文

JavaScript起点(严格模式深度了解)(js启动)

编辑:rootadmin
严格模式(Strict Mode)是ECMAScript5新增的功能。ECMAScript5虽然可以向后兼容ECMAScript3,但如果使用严格模式,哪些ECMAScript5“不在建议使用”的ECMAScript3语法功能将会被全部进制,如果出现就会抛出一行。引入Strict Mode目的是允许开发人员能够选择“更好”的Javascript版本,这个版本能用不同的方式处理那些普遍而又臭名昭著的错误。目前所有的主流浏览器的最新版本——包括IE与Opera——都支持严格模式。关于严格模式的大多数信息都可以在《ES5规范》[PDF]的第页找到。 如何启用严格模式 可以在全局范围内使用严格模式,也可以在一个函数范围内使用严格模式。如果要再全局范围内启用严格模式,只需要在程序的第一行使用代码即可: 在函数的内部启用严格模式,只需要在函数体内第一行使用代码即可: 启用严格模式的语句只是一段普通的字符串“use strict”,没有任何新语法。这意味着不会对就旧式浏览器造成任何负面影响,因此可以大胆使用。在函数内部启用严格模式的一个实际应用是,把整个Javascript类库定义在严格模式的函数内部,这样就可以不影响外部的代码: 严格模式带来了什么? 在开始介绍特殊特性之前,你需要记住,严格模式的目标之一是允许更快地调试错误。帮助开发者调试的最佳途径是当确定的问题发生时抛出相应的错误(throw errors when certain patterns occur),而不是悄无声息地失败或者表现出奇怪的行为(这正是如今不在严格模式下的Javascript做的)。严格模式下的代码抛出更多的错误信 息,这是好事,因为它能帮助开发者很快注意到一些必须立即解决的问题。去除with语句(Eliminates with) 首先,严格模式去除了with语句。当with语句出现在严格模式中时,它会被认为是非法的Javascript语句并抛出语法错误。所以,使用严格模式的第一步就是确保你没有在使用with。 防止意外的全局变量(Prevents accidental globals) 第二点是,变量在赋值之前必须声明。在非严格模式下,给一个未声明的变量赋值将自动生成一个该名字的全局变量。这是Javascript中最普遍的错误之一。严格模式中,这样做将抛出一个错误。 取消this值的强制转换(Eliminates this coercion) 另一个重要的变化是,当this值为null或undefined时,不会再将其强制转换为全局对象。也就是说,this保留了它的原始值,也因此可能会导致一些依赖于强制转换的代码发生错误。例如: 根本而言,this值必须赋值,否则将保留undefined值。这意味着调用构造函数时若漏掉了new关键字也会导致错误: 在这段代码里,调用Person构造函数时缺少了new关键字,此时this值为undefined。由于你不能给undefined添加属性,这段代码抛出了一个错误。在非严格模式下,this会强制转换为全局对象,因此name属性能够被正确赋值为全局变量。 拒绝重复(No duplicates)当你做了大量的编码的时候,你很容易在对象中定义了重复的属性或者给函数定义了重复的参数名。严格模式下,这两种情况都会导致错误的发生: 这两者都是语法错误,在代码执行之前将抛出错误。 更安全的eval()(Safer eval())eval()没有被移除,但它在严格模式下发生了一些变化。最大的改变是:在eval()语句中声明的变量以及函数不会在包含域中创建。例如: 任意由eval()创建的变量或函数仍呆在eval()里。然而,你可以通过从eval()中返回一个值的方式实现值的传递: 不可改变引发的错误(Errors for immutables) ECMAScript 5 同时引入了修改属性特征的能力,例如设置一个属性为只读或者冻结整个对象的结构(freezing an entire object's structure)。在非严格模式下,试图修改一个不可变的属性时将悄无声息地失败。你可能在使用一些原生APIs的时候已经遇到这类问题。严格模式将 保证无论你在何时试图使用一种不被允许的方式修改一个对象或对象的属性时抛出错误。 这个例子中,name属性被设置为只读。在非严格模式下,对name的赋值将悄无声息地失败;而在严格模式下,一个错误将被抛出。注:如果你在使用ECMAScript属性能力(the ECMAScript attribute capabilities),我强烈推荐你开启严格模式。如果你在改变对象的可变性(mutability of objects),你将遇到一堆错误,而它们在非严格模式下将被安静地带过。

推荐整理分享JavaScript起点(严格模式深度了解)(js启动),希望有所帮助,仅作参考,欢迎阅读内容。

JavaScript起点(严格模式深度了解)(js启动)

文章相关热门搜索词:javascript.,javascript起源,javascript cgi,javascript起源,javascripts,javascripts,javascriptz,javascript.,内容如对您有帮助,希望把文章链接给更多的朋友!

document.all的一个比较完整的总结及案例 一.document.all是页面内所有元素的一个集合。例如:document.all(0)表示页面内第一个元素二.document.all可以判断浏览器是否是IEif(document.all){alert("isIE!");}三.

js用Date对象处理时间实现思路及代码 先说说这次的应用场景:从XML文件中读取数据,然后将里面的数据返回到页面中用一个第三方插件进行绘图。在XML里读取出来的数据当然是字符串类型

表单元素的submit()方法和onsubmit事件应用概述 表单元素拥有submit方法,同时也具有onsubmit事件句柄,用于监听表单提交。可以使用elemForm.submit();方法触发表单提交。1、表单元素中出现了name="submit"的

标签: js启动

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

上一篇:js中parseFloat(参数1,参数2)定义和用法及注意事项(js parseint parsefloat)

下一篇:javascript克隆对象深度介绍(js如何深度克隆一个对象)

  • 增值税留抵退税怎么做账务处理
  • 新公司税务报到网上操作流程
  • 企业注销,账面余额怎样调账
  • 期初和期末余额均在借方的账户,一般属于
  • 一般纳税人简易计税可以抵扣进项税额吗
  • 公司与公司之间借款需要交税吗
  • 房地产开发企业预收款预缴增值税
  • 外贸企业一般纳税人申报
  • 收取车辆使用费怎么做账
  • 临时工工资能否用公户支付
  • 公告费交了以后能否撤销
  • 二手房如何缴纳契税
  • 固定资产折旧摊销表A105080
  • 挂靠被查出来后挂靠费怎么处理?
  • 公司变卖后员工怎么办
  • 农业水费管理使用办法
  • 待抵扣税费
  • 增值税需要计提吗
  • 销售退货成本如何计算
  • 红字发票不小心点了暂存怎么办
  • 发放股票股利后的未分配利润怎么算
  • 开票税额与申报税额差一分账务怎么处理
  • 工会财务任务是什么
  • 电信增值税发票怎么抵扣
  • 软件公司客户经理一般月薪多少
  • 平均净资产计算公式是什么意思
  • linux系统怎么更改主机名
  • win7系统怎样
  • 王者荣耀怎么解除关系
  • 发票来了冲预付账款怎么记账
  • Win10怎么清除系统
  • 跨期发票怎么作废
  • 苹果官网
  • 笔记本保养技巧和方法
  • 苹果手机最贵的软件是哪个
  • 酒店预收款管理制度
  • php中strcmp函数
  • 临时经营如何纳税
  • 应交税费会计分录例题
  • 加拿大猞猁雪兔
  • 银行转账手续费最高多少钱
  • 怎么理解php语言
  • Vue2 Element description组件 列合并
  • php无限级分销
  • 公交卡充值发票报销单怎么填
  • 根据不同资产涉及的税有哪些
  • 给股东分配股利
  • 发票开预付卡充值可以计入费用吗
  • 兼职人员属于雇主吗
  • 个税累计预扣法导致税交多了
  • 个体工商户税收起征点是多少?
  • 企业的其他应付款怎么处理
  • case语句怎么执行
  • 存货成本核算方式
  • 小规模城建税减半征收2020新政策
  • 处理废旧材料会计分录
  • 增值税留抵税款制度
  • 计提的应收账款坏账准备的科目有哪些
  • 当月的进项税可以不认证吗?
  • 医院药品进销差价会计核算
  • 出口收汇核销单的作用
  • 以汽车投资作为投资项目
  • 多缴的印花税怎么抵下次税费
  • 资产处置损失抵税
  • 预计销售收入增长率怎么算
  • 往来账是什么样的
  • sql中的存储过程
  • 组策略禁止打开文件对话框输入路径
  • service是什么程序
  • win11注意
  • iis安装失败找不到源文件
  • linuxzen
  • windows8ip地址怎么设置
  • Lesson02_05 头元素
  • unity开发的小游戏
  • nodejs使用视频教程
  • unity 协作
  • Unity3D之iTween
  • JavaScript ParseFloat()方法
  • 惠济区第五中学怎么样
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设