盘点JavaScript中Eval函数的使用方法

Karen110
• 阅读 1213

大家好,我是进阶学习者。

一、前言

内建函数 eval 函数允许执行一个代码字符串。

语法 :

let result = eval(code);

例 :


let code = 'alert("Hello")';
eval(code); // Hello

运行结果:

盘点JavaScript中Eval函数的使用方法

代码字符串可能会比较长,包含换行符、函数声明和变量等。

eval 的结果是最后一条语句的结果。

例:


let value = eval('1+1');
alert(value); // 2
let value = eval('let i = 0; ++i');
alert(value); // 1

运行结果:

盘点JavaScript中Eval函数的使用方法

盘点JavaScript中Eval函数的使用方法

eval 内的代码在当前词法环境(lexical environment)中执行,因此它能访问外部变量:


let a = 1;
function f() { 
  let a = 2;  eval('alert(a)'); 
  // 2
}
  f();

运行结果:

盘点JavaScript中Eval函数的使用方法

它也可以更改外部变量:


let x = 5;
eval("x = 10");
alert(x); // 10,值被更改了

运行结果:

盘点JavaScript中Eval函数的使用方法

严格模式下,eval 有属于自己的词法环境。因此不能从外部访问在 eval 中声明的函数和变量:


// 提示:本教程所有可运行的示例都默认启用了严格模式 
'use strict'eval("let x = 5; function f() {}");
alert(typeof x); // undefined(没有这个变量)
// 函数 f 也不可从外部进行访问

如果不启用严格模式,eval 没有属于自己的词法环境,因此可以从外部访问变量 x 和函数 f。

二、案例

Eval-计算器

创建一个计算器,提示用户输入一个算术表达式,并返回其计算结果。

让使用 eval 来计算数学表达式:

let expr = prompt("Type an arithmetic expression?", '23+2');
alert( eval(expr) );

需要检查表达式是否正确。只需要计算并返回结果。用户可以输入任意文本或代码。

盘点JavaScript中Eval函数的使用方法

运行结果:

盘点JavaScript中Eval函数的使用方法

三、使用 “eval”


在 eval 中使用外部局部变量也被认为是一个坏的编程习惯,因为这会使代码维护变得更加困难。

有两种方法可以完全避免此类问题。

如果 \eval\ 中的代码,+没有使用外部变量,请以 window.\eval(...) 的形式调用 \eval\。

通过这种方式,该代码便会在全局作用域内执行:


let x = 1;
{
  let x = 5;
  window.eval('alert(x)'); // 1(全局变量)
}

运行结果:

盘点JavaScript中Eval函数的使用方法

如果 \eval\ 中的代码需要访问局部变量,可以使用 new Function 替代 \eval\,并将它们作为参数传递:


let f = new Function('a', 'alert(a)');
f(5); // 5

运行结果:

盘点JavaScript中Eval函数的使用方法

注:

new Function 从字符串创建一个函数,并且也是在全局作用域中的。所以它无法访问局部变量。

四、总结

本文基于JavaScript基础,介绍了 Eval函数的使用。调用 eval(code) 会运行代码字符串,并返回最后一条语句的结果。

要在全局作用域中 eval 代码,可以使用 window.eval(code) 进行替代。

通过案例的分析,进行详细的讲解。在实际应用中需要注意的点,遇到的难点,提供了详细的解决方法。使用JavaScript语言,能够让读者更好的理解。代码很简单,希望能够帮助读者更好的学习。

**-----**------**-----**---**** End **-----**--------**-----**-****

往期精彩文章推荐:

盘点JavaScript中Eval函数的使用方法

欢迎各位大佬点击链接加入群聊【helloworld开发者社区】:https://jq.qq.com/?_wv=1027&k=mBlk6nzX进群交流IT技术热点。

点赞
收藏
评论区
推荐文章
blmius blmius
2年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
Karen110 Karen110
2年前
一篇文章带你了解JavaScript日期
日期对象允许您使用日期(年、月、日、小时、分钟、秒和毫秒)。一、JavaScript的日期格式一个JavaScript日期可以写为一个字符串:ThuFeb02201909:59:51GMT0800(中国标准时间)或者是一个数字:1486000791164写数字的日期,指定的毫秒数自1970年1月1日00:00:00到现在。1\.显示日期使用
Jacquelyn38 Jacquelyn38
2年前
2020年前端实用代码段,为你的工作保驾护航
有空的时候,自己总结了几个代码段,在开发中也经常使用,谢谢。1、使用解构获取json数据let jsonData  id: 1,status: "OK",data: 'a', 'b';let  id, status, data: number   jsonData;console.log(id, status, number )
皕杰报表之UUID
​在我们用皕杰报表工具设计填报报表时,如何在新增行里自动增加id呢?能新增整数排序id吗?目前可以在新增行里自动增加id,但只能用uuid函数增加UUID编码,不能新增整数排序id。uuid函数说明:获取一个UUID,可以在填报表中用来创建数据ID语法:uuid()或uuid(sep)参数说明:sep布尔值,生成的uuid中是否包含分隔符'',缺省为
Stella981 Stella981
2年前
JS中注入eval, Function等系统函数截获动态代码
正文现在很多网站都上了各种前端反爬手段,无论手段如何,最重要的是要把包含反爬手段的前端javascript代码加密隐藏起来,然后在运行时实时解密动态执行。动态执行js代码无非两种方法,即eval和Function。那么,不管网站加密代码写的多牛,我们只要将这两个方法hook住,即可获取到解密后的可执行js代码。注意,有些网站会检测eval和Functi
Stella981 Stella981
2年前
HIVE 时间操作函数
日期函数UNIX时间戳转日期函数: from\_unixtime语法:   from\_unixtime(bigint unixtime\, string format\)返回值: string说明: 转化UNIX时间戳(从19700101 00:00:00 UTC到指定时间的秒数)到当前时区的时间格式举例:hive   selec
Stella981 Stella981
2年前
Django中Admin中的一些参数配置
设置在列表中显示的字段,id为django模型默认的主键list_display('id','name','sex','profession','email','qq','phone','status','create_time')设置在列表可编辑字段list_editable
Stella981 Stella981
2年前
Python中eval的使用
    eval()官方文档里面给出来的功能解释是:将字符串string对象转化为有效的表达式参与求值运算返回计算结果语法上:调用的是:eval(expression,globalsNone,localsNone)返回的是计算结果其中:    expression是一个参与计算的python表达式    globa
Wesley13 Wesley13
2年前
MySQL部分从库上面因为大量的临时表tmp_table造成慢查询
背景描述Time:20190124T00:08:14.70572408:00User@Host:@Id:Schema:sentrymetaLast_errno:0Killed:0Query_time:0.315758Lock_
Python进阶者 Python进阶者
3个月前
Excel中这日期老是出来00:00:00,怎么用Pandas把这个去除
大家好,我是皮皮。一、前言前几天在Python白银交流群【上海新年人】问了一个Pandas数据筛选的问题。问题如下:这日期老是出来00:00:00,怎么把这个去除。二、实现过程后来【论草莓如何成为冻干莓】给了一个思路和代码如下:pd.toexcel之前把这