深入JavaScript高级语法,语法最严格的语言

  深入JavaScript高级语法,语法最严格的语言

  本文给大家带来了一些关于javascript的知识,主要介绍了一些关于严格模式的相关问题。严格模式很好理解,是一种限制性的JavaScript模式,使得代码隐式脱离了“懒惰模式”。下面就来看看吧,希望对你有帮助。

  【相关推荐:javascript视频教程,web前端】

  

一、认识严格模式

  在ECMAScript5标准中,JavaScript提出了严格模式的概念:

  严格模式很好理解,是一种限制性的JavaScript模式,使得代码隐式脱离了“懒惰模式”。

  支持严格模式的浏览器在代码中检测到严格模式时,会以更严格的方式检测和执行代码。

  模式对普通的JavaScript语义施加了一些限制:

  该模式通过抛出错误严格剔除部分原有静默错误

  严格模式允许JS engine在执行代码时进行更多的优化(无需处理一些特殊的语法)。

  该模式严格禁止某些可能在ECMAScript未来版本中定义的语法。

  

二、开启严格模式

  那么如何开启严格模式呢?该模型严格支持粒度迁移:

  可以支持在js文件中打开严格模式;还支持对某个函数开启严格模式;

三、严格模式限制

   JavaScript是为了新手开发者更容易使用而设计的,所以有时候Ben买错了语法,不要以为可以正常解析;

  但是,这种方法可能会留下安全隐患;

  在严格模式下,这种事务会被当作一个错误来处理,这样可以很快发现并纠正;

  总结一些常见的限制:

  

1.无法意外的创建全局变量

  有两种方法可以意外创建全局变量:

  直接声明全局变量,不带关键字全局。在函数中声明不带关键字的变量。默认情况下,函数被提升为全局变量。

  代码如下:“使用严格的”

  //禁止意外创建全局变量

  Message=“意外创建了全局变量”

  Console.log(message) //错误消息为:未捕获的引用错误:消息未定义

  函数foo () {

  年龄=20岁

  console.log(年龄)

  }

  O ()//ReferenceError:年龄未定义

2.严格模式下会使引起静默失败的赋值操作报出错误异常

  示例代码如下:

  //开启严格模式,直接把问题变成错误。

  使用严格

  const v=100//(定义常数)

  v=1.14//重新赋值(作为变量)

  console . log(v);//uncaughttypeerror:常量变量的赋值。

3.严格模式下试图删除不可删除的属性

  在严格模式下,delect运算符不能用于变量。

  

(1).对变量使用delete关键字

   //打开严格模式

  使用严格

  var v=100

  删除v;//在非严格模式下:这里是静默失败,变量V既不上报也不删除。

  console . log(v);//100

  //开启严格模式后,改为严格模式下报错删除不合格标识符。

(2).对数组和对方法属性使用delete关键字

  在严格模式下,对数组和方法属性使用delete关键字的效果不变。

  //打开严格模式

  使用严格

  //1.在严格模式下删除数组内容。

  var arr=[1,2,3,4]

  删除arr[0];

  console . log(arr);//[ 1个空项目,2,3,4 ]

  //2.严格模式下删除函数的属性

  var obj={

  名称:“GG债券”

  }

  删除obj.name

  console . log(obj . name)//undefined

4.严格模式不允许函数参数有相同的名称

  示例代码如下:

  使用严格

  //不允许具有相同参数名称的函数

  函数foo2 (x,y,x) {

  console.log(x,y,x)

  }

  O 2 (10,20,30)//语法错误:此上下文中不允许重复的参数名

5.不允许0的八进制语法

  示例代码如下:

  //不允许原始的八进制格式

  var num1=0123

  Var num2=0o123 //可以用这种格式写成八进制

  Var num3=0x123 //可以用十六进制写成这种格式

  Var num4=0b100 //可以用这种格式写成二进制

  console.log(num1) //SyntaxError:严格模式下不允许八进制文本。

  console.log (num2,num3,num4)//83 291 4:

6.在严格模式下,不允许使用with

  的代码示例如下:

  使用严格

  var message= Hello World

  var obj={ name: jam ,年龄:20 }

  with语句可以形成自己的作用域。在with语句中打印年龄时,会输出obj对象中的年龄属性,但在with语句中打印不存在的属性消息时,会逐层搜索外部作用域。

  函数foo () {

  用(obj)

  console.log(年龄)

  console.log(消息)

  }

  console.log(消息)

  }

  o()//语法错误:严格模式代码不能包含with语句

7.在严格模式下,eval不再为上层引用变量

  示例代码如下:

  var jsString= var message= hello world ; console.log(消息)

  Eval(jsString) //输出hello world

  Console.log(message) //错误消息为:引用错误:消息未定义

8.严格模式下,this绑定不会默认转成对象

  示例代码如下:

  使用严格

  //在严格模式下,自执行函数(默认绑定)会指向undefined,在非严格模式下会指向window

  函数foo () {

  console.log(this)

  }

  Foo() //undefined【相关推荐:javascript视频教程,web前端】以上是JavaScript高级语法学习严格模式的细节。更多请关注我们的其他相关文章!

郑重声明:本文由网友发布,不代表盛行IT的观点,版权归原作者所有,仅为传播更多信息之目的,如有侵权请联系,我们将第一时间修改或删除,多谢。

留言与评论(共有 条评论)
   
验证码: