javascript中eval和with用法实例总结


Posted in Javascript onNovember 30, 2015

本文实例讲述了javascript中eval和with用法。分享给大家供大家参考,具体如下:

我们都知道javascript的作用域机制,但是with和eval有时会“破坏”我们对于作用域的常规理解。下面参考网上资源和自己理解总结一下eval和with的用法。

一、eval

1、eval函数:把一个字符串当作一个js表达式一样去执行它.

2、语法:eval(strScript) 注:参数strScript是必填项

3、使用说明

(1)它是有返回值的,如果参数字符串是一个表达式,就会返回表达式的值。如果参数字符串不是表达式,没有值,那么返回“undefined”。
(2)参数字符串作为代码执行时,是和调用eval函数的上下文相关的,即其中出现的变量或函数调用必须在调用eval的上下文环境中可用。

4、示例:

function $(s) { if (document.getElementById) { return eval('document.getElementById("' + s + '")'); } else { return eval('document.all.' + s); } } //eval,这个比较常用
var myTest = function() { return "eval test"; };
function evalTest() {
  //简单数据
  alert(eval("1+1")); //2
  alert(eval("'a'+1")); //a1
  alert(eval("1+'a'")); //1a
  alert(eval("parseInt('a'+1)")); //NaN
  alert(eval("parseInt(1+'a')")); //1
  alert(eval("true")); //true
  alert(eval("0==false")); //true
  alert(eval("1==undefined")); //false
  alert(eval("isNaN(undefined)")); //true
  //函数和对象
  alert(eval("this")); //[object]
  alert(eval("typeof(this)")); //object
  alert(eval("typeof(test)")); //undefined
  alert(eval("evalTest")); //这个显示当前函数的定义语句细节,包含注释
  //alert(eval("evalTest()")); //调用自己并执行,这个会有大问题啊!
  alert(eval("typeof(evalTest)")); //function
  //其他
  var tmpFunc = "{a:1}";
  alert(eval(tmpFunc)); //1
  alert(eval("(" + tmpFunc + ")")); //[object object]
  alert(eval("tmpFunc")); //{a:1}
  //alert(eval("tmpFunc()")); //脚本错误
  alert(myTest());
  eval("alert(myTest())"); //和上面等价
  alert(eval(myTest));
  alert(eval("myTest")); //和上面等价
  //form里的一个input,id=txtUserName
  eval("$('txtUserName').value='jeff wong';"); //等价于 $('txtUserName').value = 'jeff wong';
  eval("alert( $('txtUserName').value);");
}
evalTest();

5、eval和作用域

(1)经典代码分析

a、常见

var str = "global";
function test() {
  alert(str); //undefined
  var str = "local";
}
test();
alert(str); //global

分析:如我们预期的那样,得到指定值。test函数内的str没有var和有var声明,结果也是不一样的,读者可自行验证。

b、eval替代直接声明变量的写法

var str = "global";
function test() {
  alert(str); //??
  eval("var str='local';");//会像我们预期的那样吗?
  //var str = "local";
  alert(str); //这里又是什么结果?
}
test();
alert(str); //??

分析:对比a中的写法,我们只是在test函数里用eval语句替换直接声明var定义变量那一句最后alert一下而已,结果出入很大。

(2)eval定义全局代码

a、兼容ie和ff的通用定义全局代码的eval函数

var nav = new Object();
//通用eval函数
nav.Eval = function(jsCode) {
  if (document.all) //IE下是execScript
   execScript(jsCode);
  else window.eval(jsCode); //FF下是window.eval
}

对于IE浏览器,函数execScript用于在全局空间执行代码。
对于Firefox浏览器,直接调用eval函数,则在调用者的空间执行;如果调用window.eval则在全局空间执行;但是alert(eval==window.eval)的返回值是true,奇怪的ff.

b、调用a的测试代码

var nav = new Object();
//通用eval函数
nav.Eval = function(jsCode) {
  if (document.all) //IE下是execScript
   execScript(jsCode);
  else window.eval(jsCode); //FF下是window.eval
}
function test() {
  nav.Eval("var str = 'global';"); //这里声明变量str,在外面的函数中可以调用变量
  nav.Eval("var tmpFunc = function(){alert('global function');};"); //这里声明函数变量tmpFunc,在外面的函数中可以调用函数
  alert(str); //global
  tmpFunc(); //global function
}
test();
alert(str); //global (调用nav.Eval函数声明的全局变量)
tmpFunc(); // global function (调用nav.Eval函数声明的全局函数)

分析:通过b中的代码,你可能已经发现了eval定义全局代码的一个显而易见的不方便的地方,就是对于全局代码,js智能提示(这里是vs,可能其他工具也会)完全失去提示作用。由此你肯定会问,程序中通过eval这种方式定义了很多全局代码,它的可维护性会不会太那个了?我的看法就是赞成网上的总结,少用eval。毕竟现成的工具都不能很好的提示了,而程序员的视力往往又不是那么好。

二、with

1、with语句:为一个或一组语句指定默认对象,通常用来缩短特定情形下必须写的代码量
2、语法:with (<对象>) <语句>
with (object)
  statements
(1)参数object: 新的默认对象;
(2)statements : 一个或多个语句,object 是该语句的默认对象。

3、示例:

function withTest() {
 with (document) { //document的重复使用
 writeln("Hello,");
 writeln("it's a with keyword test!");
 }
 with (Math) { //Math的重复使用
 alert(random());
 alert(abs(-10));
 }
}
withTest();

4、with会暂时修改作用域链

function withTest() {
 var userName = "jeff wong";
 //暂时修改作用域链
 with (document) {
 writeln("Hello,");
 writeln(userName);
 }//with内的语句执行完之后,作用域链恢复原状
 alert(userName);
}
withTest();

分析: 函数withTest在定义的时候,就确定了withTest的作用域链,我们暂且认为这条作用域链的最顶端是window对象,当withTest被执行的时候,js引擎生成了一个call object(调用对象)并将其添加到作用域链尾部上(window对象之后),语句运行到with(document)时,将生成新的作用域(实质上这个作用域和普通function的作用域一样,只不过它在with子句执行完,该作用域也随之消失)并添加到作用域链的尾部,所以with之内的变量查找,就会优先从这条链的with(document)作用域上查找,然后从withTest的call object中查找,最后查找window。with内的语句执行完之后,作用域链恢复原状(with(document)生成的作用域被移出作用域链)。

ps:with是不被推荐的,因为需要操作作用域链(移进、移出作用域),执行效率低下。

希望本文所述对大家JavaScript程序设计有所帮助。

Javascript 相关文章推荐
jquery提示 &quot;object expected&quot;的解决方法
Dec 13 Javascript
基于jquery的3d效果实现代码
Mar 23 Javascript
非常强大的 jQuery.AsyncBox 弹出对话框插件
Aug 29 Javascript
dojo学习第二天 ajax异步请求之绑定列表
Aug 29 Javascript
Js 时间函数getYear()的使用问题探讨
Apr 01 Javascript
javascript仿php的print_r函数输出json数据
Sep 13 Javascript
简单介绍JavaScript中字符串创建的基本方法
Jul 07 Javascript
js实现商城星星评分的效果
Dec 29 Javascript
探讨AngularJs中ui.route的简单应用
Nov 16 Javascript
JavaScript碎片—函数闭包(模拟面向对象)
Mar 13 Javascript
javascript实现点亮灯泡特效示例
Oct 15 Javascript
浅谈layui 绑定form submit提交表单的注意事项
Oct 25 Javascript
JavaScript基础篇(3)之Object、Function等引用类型
Nov 30 #Javascript
全面解析Bootstrap排版使用方法(标题)
Nov 30 #Javascript
javascript作用域链(Scope Chain)用法实例解析
Nov 30 #Javascript
Bootstrap每天必学之js插件
Nov 30 #Javascript
Bootstrap每天必学之面板
Nov 30 #Javascript
Bootstrap每天必学之媒体对象
Nov 30 #Javascript
javascript针对cookie的基本操作实例详解
Nov 30 #Javascript
You might like
收音机玩机评测 406 篇视频合集
2020/03/11 无线电
PHP产生随机字符串函数
2006/12/06 PHP
php判断正常访问和外部访问的示例
2014/02/10 PHP
美图秀秀web开放平台--PHP流式上传和表单上传示例分享
2014/06/22 PHP
php中HTTP_REFERER函数用法实例
2014/11/21 PHP
php实现的树形结构数据存取类实例
2014/11/29 PHP
php一个文件搞定微信jssdk配置
2016/12/12 PHP
Autocomplete Textbox Example javascript实现自动完成成功
2007/08/17 Javascript
jquery 获取自定义属性(attr和prop)的实现代码
2012/06/27 Javascript
获取div编辑框,textarea,input text的光标位置 兼容IE,FF和Chrome的方法介绍
2012/11/08 Javascript
Function.prototype.bind用法示例
2013/09/16 Javascript
js中通过父级进行查找定位元素
2014/06/15 Javascript
js操作IE浏览器弹出浏览文件夹可以返回目录路径
2014/07/14 Javascript
node.js中的buffer.write方法使用说明
2014/12/10 Javascript
jQuery实现给页面换肤的方法
2015/05/30 Javascript
node.js基于mongodb的搜索分页示例
2017/01/22 Javascript
从零开始学习Node.js系列教程之SQLite3和MongoDB用法分析
2017/04/13 Javascript
微信小程序 scroll-view实现锚点滑动的示例
2017/12/06 Javascript
vue数据传递--我有特殊的实现技巧
2018/03/20 Javascript
详解webpack4升级指南以及从webpack3.x迁移
2018/06/12 Javascript
基于Vue 2.0 监听文本框内容变化及ref的使用说明介绍
2018/08/24 Javascript
微信小程序时间标签和时间范围的联动效果
2019/02/15 Javascript
jQuery实现的鼠标拖动画矩形框示例【可兼容IE8】
2019/05/17 jQuery
three.js 将图片马赛克化的示例代码
2020/07/31 Javascript
js利用iframe实现选项卡效果
2020/08/09 Javascript
Python实现矩阵加法和乘法的方法分析
2017/12/19 Python
python爬虫自动创建文件夹的功能
2018/08/01 Python
欧洲高端品牌直销店:Fashionesta
2016/08/31 全球购物
班委竞选演讲稿
2014/04/28 职场文书
法制宣传月活动总结
2014/04/29 职场文书
学校节能宣传周活动总结
2014/07/09 职场文书
党员教师自我剖析材料
2014/09/29 职场文书
龙潭大峡谷导游词
2015/02/10 职场文书
办公经费申请报告
2015/05/15 职场文书
Python爬虫实战之爬取京东商品数据并实实现数据可视化
2021/06/07 Python
Java实战之用Swing实现通讯录管理系统
2021/06/13 Java/Android