位置: 编程技术 - 正文

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如何深度克隆一个对象)

  • 金融业产值和金融业增加值有什么不同
  • 免税农产品发票开具时税率怎么选
  • 减免房产税土地使用税 账务处理
  • 有限责任公司应当具备的条件
  • 职工宿舍楼日常管理制度
  • 变更注册资本的股东会决议范本
  • 冲减往年管理费用
  • 财政补助收入怎么结转
  • 股权投资损失该如何做账务处理及税前扣除相关规定
  • 没有计提坏账准备的应收帐款坏帐帐务处理
  • 注册公司买车划算吗
  • 财务怎么查询微信转账单号真假
  • 地税都包括什么
  • 五年之内,企业可追补应扣支出
  • 非企业性单位包括哪些单位
  • 什么收入不需要交税0税
  • 企业所得税调增调减项目有哪些
  • 苹果设置输入法在哪里设置
  • linux ssh命令用法
  • 在win7中创建快捷方式可以创建什么
  • 职工教育经费培训费扣除比例
  • 非上市公司转让股权需要缴纳增值税吗
  • 扬声器音量调节
  • 应收账款未计提坏账能直接核销
  • php23种设计模式
  • 公司赞助商
  • php sql 教程
  • 2021新旧会计准则
  • php常用的设计模式在开发中的实例
  • 银行对公中收
  • 销售多余材料计入什么
  • 农产品核定扣除和计算抵扣的区别
  • 员工的生活费会不会扣个税
  • phpwhile用法
  • laravel搭建
  • 个人借款放在哪个科目
  • 可供出售金融资产和交易性金融资产
  • vue set-cookie
  • 利润分配怎样做分录
  • 未发货先开票后付款是否违法
  • php调用微信扫描二维码
  • 资产总额怎么计算公式
  • win10下 yolov8 tensorrt模型加速部署【实战】
  • pytorch例程
  • 固定资产折旧四种方法公式
  • 用友财务软件怎么下载到电脑
  • python怎么设置窗口界面
  • php的do while语句
  • sql server异常怎么处理
  • 企业促销费用项目有哪些
  • 公司组织员工旅游需要交个税吗
  • 出口退税进项税额转出怎么申报
  • 一般存款账户可以办理现金缴存但不得办理现金支取
  • 公司销售二手车怎么申报增值税
  • 付款凭证怎么写样本
  • 一般纳税人的进项税额可以抵扣吗
  • 集团对子公司的管理办法
  • 借款和工程款可以分开吗
  • 影视行业成本核算方案
  • 企业投资所得如何征税
  • sqlserver如何查看操作日志
  • win10edge浏览器默认主页网址
  • win7系统硬盘安装版
  • dns server配置
  • 怎么在win7开始菜单添加文件夹
  • win10系统更新后无法开机
  • windows7开机
  • win8系统如何卸载软件
  • win10浏览器没有网络连接
  • linux启动cron定时任务
  • cortana小娜怎么用
  • python 自定义sort
  • 环境篇作文
  • opengl learn cn
  • shell替换文件中指定行的指定内容
  • python shape用法
  • php使用js
  • 南京退林还耕
  • 国家税务总局洛阳市分局
  • 京东开的店
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设