简述js中严格模式和普通模式的区别。

JavaScript016

简述js中严格模式和普通模式的区别。,第1张

严格模式是一种将更好的错误检查引入代码中的方法。 在使用严格模式时,无法使用隐式声明的变量、将值赋给只读属性或将属性添加到不可扩展的对象等1、 严格模式的目的 1) 消除Javascript语法的一些不合理、不严谨之处,减少一些怪异行为2)消除代码运行的一些不安全之处,保证代码运行的安全3) 提高编译器效率,增加运行速度4) 为未来新版本的Javascript做好铺垫 2、声明严格模式可以通过在文件、程序或函数的开头添加 "use strict"来声明严格模式。 此类声明称作“指令序言”。 严格模式声明的范围取决于其上下文。 如果在全局上下文(函数的范围之外)中声明严格模式,则程序中的所有代码都处于严格模式。如果在函数中声明严格模式,则函数中的所有代码都处于严格模式。 例如,在以下示例中,所有代码都处于严格模式,并且函数外部的变量声明会导致出现语法错误“严格模式下未定义变量”<pre t="code" l="js">"use strict"

function testFunction(){

var testvar = 4

return testvar

}

// This causes a syntax error.

testvar = 5在以下示例中,仅 testFunction 中的代码处于严格模式。 函数外部的变量声明不会导致语法错误,但函数内部的声明会导致语法错误<pre t="code" l="js">function testFunction(){

"use strict"

// This causes a syntax error.

testvar = 4

return testvar

}

testvar = 5

var person1=createPerson("Nicholas",29,"software Engineer")

var person1=new Person("Nicholas",29,"software Engineer")

区别在这两句话中,你可以看到第一个语句里面没有new关键字,直接执行一个函数;而第二个表达式中有new,也就是说是新实例化了一个对象。

JS中关于this的定义是:函数直接在全局中执行,那么this指向的是全局对象window。也就是说你在createPerson中new了一个o,但是你再执行this.name=name那么就等于是执行了window.name=name,o对象本身不会有任何印象,最后你return了o也只是得到了一个空对象。

而JS中执行了new之后,等于通过构造函数创建了一个新对象,那么这个构造函数中的this也就指向了这个新实例化的对象,此时this.name=name修改了新对象person1中的name值。

关于对象实例化的知识和this指向的问题题主还多翻一翻博客园的文章,讲的很详细,从长久发展来看先打好基础对你以后的道路更有好处。