严格模式:由ECMA-262规范定义的JavaScript标准,对javascrip的限制更强。这篇文章主要介绍了Javascript 严格模式use strict详解 ,需要的朋友可以参考下
严格模式:由ECMA-262规范定义的JavaScript标准,对javascrip的限制更强。
(非严格的模式,被称为“马虎模式/稀松模式/懒散模式”。)
一、严格模式的使用
严格模式可以在脚本或函数级别实现。(即全局和局部模式)
1.全局
在js文件的最前面添加 "use strict"
2.局部
在函数内部添加 "use strict",如下
function fn() { "use strict"; //some code }
二、严格模式和非严格模式的对比
1.严格模式下,无法删除(delete)变量(delete是不合格的标识符))。非严格模式下会删除失败返回false
"use strict"; var x; delete x;//报错Delete of an unqualified identifier in strict mode.(不合格的标识符)
2.严格模式中,函数形参存在同名的,抛出错误; 非严格模式不会
严格模式下
function fn(a,a){ "use strict"; result=a+a; console.log(result); } fn(2,4);//Duplicate parameter name not allowed in this context(重复的参数名称在此上下文中不允许)
非严格模式下
function fn1(a,a){ "use strict"; result=a+a; console.log(result); } fn1(2,4);//结果为8
3.严格模式不允许八进制整数直接量(如下)。非严格模式下不会报错。
"use strict" var x=089; console.log(x);//报错:Decimals with leading zeros are not allowed in strict mode.
4.严格模式中,arguments对象是传入函数内实参列表的静态副本(即不再追踪参数的变化);非严格模式下,arguments对象里的元素和对应的实参是指向同一个值的引用。
严格模式下
fn(5); function fn(a){ "use strict"; a = 42; // return a==arguments[0];//返回false console.log(a);//结果为42 console.log(arguments[0]);//结果为5,严格模式下arguments[0]表示这个调用方法的第一个参数 (不再追踪 参数的变化,在函数内部,参数a被重新赋值为42,但arguments[0]仍然为5.) }
非严格模式下
fn(5); function fn(a){ a = 42; // return a==arguments[0];//返回true console.log(a);//结果为42 console.log(arguments[0]);//结果为42(追踪参数变化) }
5.严格模式中 eval和arguments当做关键字,它们不能被赋值和用作变量声明
"use strict"; var eval=3;//报错:Unexpected eval or arguments in strict mode var argument=6;//同样报错
6.严格模式会限制对调用栈的检测能力,访问arguments.callee,arguments.callee.caller会抛出异常
严格模式下:
"use strict"; function fn(n){ if(n==0){ return 1; }else{ return n*arguments.callee(n-1); } } console.log(fn(5));//报错
非严格模式下:
function fn(n){//阶乘 if(n==0){ return 1; }else{ return n*arguments.callee(n-1); } } console.log(fn(5));//正常120
caller:在一个函数调用另一个函数时,被调用函数会自动生成一个caller属性,指向调用它的函数对象。如果该函数当前未被调用,或并非被其他函数调用,
则caller为null。如下:
严格模式下:
"use strict" function fn1() { var n1= fn1.caller; console.log(n1); } function fn2() { fn1(); } fn2();//报错
非严格模式下:
function fn1() { var n1= fn1.caller;//此例中caller指向调用它的函数(fn2) console.log(n1); } function fn2() { fn1(); } fn2();// 结果打印出:function fn2(){ fn1( ) };
7.严格模式变量必须先声明,直接给变量赋值,不会隐式创建全局变量,不能用with。
严格模式下
"use strict"; with(obj){ x; }//报错:Strict mode code may not include a with statement
解释:道运行脚本时,首先是编译,然后再执行。显然在编译的时候,所以就不能在编译时确定with语句块中的变量到底归属哪个对象。[with语句块中的变量是(cl)的属性
还是上一层变量作用域链中的变量。]。只能在执行时才能确定(c1)是Clothes的一个实例。这与严格模式有编译时就检查变量是否定义冲突,所以严格模式不会with语句的使用。
扩展:with语句的使用(用来引用某个特定对象中已有的属性,但是不能用来给对象添加属性。)
with(object instance) { //代码块 } eg:function Clothes(){ this.color="red"; this.size="m"; this.price="cheap"; } var c1=new Clothes(); with(c1){ var str="颜色:"+color+",尺寸:"+size+",价格:"+price; document.write(str); }//结果(颜色:red,尺寸:m,价格:cheap)
严格模式中 call apply传入null undefined保持原样不被转换为window
以上是Javascript教程use strict严格模式详解的详细内容。更多信息请关注PHP中文网其他相关文章!

C 和JavaScript通过WebAssembly实现互操作性。1)C 代码编译成WebAssembly模块,引入到JavaScript环境中,增强计算能力。2)在游戏开发中,C 处理物理引擎和图形渲染,JavaScript负责游戏逻辑和用户界面。

JavaScript在网站、移动应用、桌面应用和服务器端编程中均有广泛应用。1)在网站开发中,JavaScript与HTML、CSS一起操作DOM,实现动态效果,并支持如jQuery、React等框架。2)通过ReactNative和Ionic,JavaScript用于开发跨平台移动应用。3)Electron框架使JavaScript能构建桌面应用。4)Node.js让JavaScript在服务器端运行,支持高并发请求。

Python更适合数据科学和自动化,JavaScript更适合前端和全栈开发。1.Python在数据科学和机器学习中表现出色,使用NumPy、Pandas等库进行数据处理和建模。2.Python在自动化和脚本编写方面简洁高效。3.JavaScript在前端开发中不可或缺,用于构建动态网页和单页面应用。4.JavaScript通过Node.js在后端开发中发挥作用,支持全栈开发。

C和C 在JavaScript引擎中扮演了至关重要的角色,主要用于实现解释器和JIT编译器。 1)C 用于解析JavaScript源码并生成抽象语法树。 2)C 负责生成和执行字节码。 3)C 实现JIT编译器,在运行时优化和编译热点代码,显着提高JavaScript的执行效率。

JavaScript在现实世界中的应用包括前端和后端开发。1)通过构建TODO列表应用展示前端应用,涉及DOM操作和事件处理。2)通过Node.js和Express构建RESTfulAPI展示后端应用。

JavaScript在Web开发中的主要用途包括客户端交互、表单验证和异步通信。1)通过DOM操作实现动态内容更新和用户交互;2)在用户提交数据前进行客户端验证,提高用户体验;3)通过AJAX技术实现与服务器的无刷新通信。

理解JavaScript引擎内部工作原理对开发者重要,因为它能帮助编写更高效的代码并理解性能瓶颈和优化策略。1)引擎的工作流程包括解析、编译和执行三个阶段;2)执行过程中,引擎会进行动态优化,如内联缓存和隐藏类;3)最佳实践包括避免全局变量、优化循环、使用const和let,以及避免过度使用闭包。

Python更适合初学者,学习曲线平缓,语法简洁;JavaScript适合前端开发,学习曲线较陡,语法灵活。1.Python语法直观,适用于数据科学和后端开发。2.JavaScript灵活,广泛用于前端和服务器端编程。


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

Video Face Swap
使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

Dreamweaver CS6
视觉化网页开发工具

ZendStudio 13.5.1 Mac
功能强大的PHP集成开发环境

螳螂BT
Mantis是一个易于部署的基于Web的缺陷跟踪工具,用于帮助产品缺陷跟踪。它需要PHP、MySQL和一个Web服务器。请查看我们的演示和托管服务。

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)