JavaScript 拾碎[五] 使用eval 或者new Function 进行语法检查

简介:

使用代码来实现分析代码的语法,这是一件极其痛苦的事情。

简单的解决办法是:使用脚本引擎自己的语法检查,比方说eval( ) 或者new Function( )。

使用new Function( ) 来进行语法检查

eval( ) 方法是不能乱用的,在不适当的时候使用eval( ) 方法可能导致整个程序都会出问题的;

而new Function( ) 就没这么大问题。虽然new Function( ) 在任何情况下,构造的函数都是在全局作用域下直接工作的,但只作语法检查的话,并不会因为作用域问题而产生意外结果,只要你不直接调用通过它构造的新函数。

在eval( ) 接受的参数前面增加“0,”

其实这是由于IE中存在一个bug。出于某种原因,如果你在IE 中想通过调用eval( ) 来动态地构造一个函数。
例如:

eval('(function(){ /* code here */ })');

在IE 中得到的返回将是undefined,而其它浏览器则会正确地返回这个新构造的函数的引用。

最简单有效的解决办法是:在前边加上“0,”,这样就能在所有主流浏览器中兼容。
例如:

eval('0,function(){ /* code here */ }');

注:在IE9 的Chakra 引擎中,这个问题已经解决。

使用数组对象的concat方法来产生新数组

把单个对象参数转化为只包含一个元素的数组再来处理,可以使用“[ ].concat(o)”的形式。

例如:

var arr1 = [1,2];
var arr2 = [3,4];
var arr3 = arr1.concat(arr2);
alert(arr3.length);

另一种方式是:if (!(o instanceof Array)) o = [o];

// 和ECMAScript 5 中的isArray 相比不够严谨。




本文转自钢钢博客园博客,原文链接:http://www.cnblogs.com/xugang/archive/2010/10/14/1851127.html,如需转载请自行联系原作者

相关文章
|
1月前
|
JavaScript 算法
原生JS完成“一对一、一对多”矩形DIV碰撞检测、碰撞检查,通过计算接触面积(重叠覆盖面积)大小来判断接触对象DOM
原生JS完成“一对一、一对多”矩形DIV碰撞检测、碰撞检查,通过计算接触面积(重叠覆盖面积)大小来判断接触对象DOM
|
2天前
|
前端开发 JavaScript 索引
CSS常见用法 以及JS基础语法
CSS常见用法 以及JS基础语法
10 0
|
4天前
|
JavaScript
JS 基本语法
JS 基本语法
11 1
|
7天前
|
JavaScript 前端开发 C语言
JavaScript编程语法练习
本篇文章是对于javaScript中if ,switch,while ,do-while,,for语法的作业练习.对于我来说也是对自己知识掌握的一种检验.是对js的基础语法进行的一次练习,通过有趣的示例进行练习,使得对于代码能够增加印象,对于知识的掌握更加透彻.
|
9天前
|
JavaScript 前端开发
JavaScript语法(2)
【5月更文挑战第2天】JavaScript语法(2)。
15 3
|
9天前
|
存储 JavaScript 前端开发
JavaScript语法
JavaScript语法。
6 1
|
11天前
|
JavaScript 前端开发 开发者
Vue.js 模板语法
Vue.js 模板语法
|
21天前
|
XML 存储 JavaScript
JavaScript的基本语法是编程的基础
【4月更文挑战第20天】JavaScript的基本语法是编程的基础
17 5
|
24天前
|
JavaScript
【Js】检查Date对象是否为Invalid Date
【Js】检查Date对象是否为Invalid Date
33 0
|
2月前
|
JavaScript 前端开发 Web App开发
JavaScript基础语法(codewhy版本)(一)
JavaScript基础语法(codewhy版本)
92 1
JavaScript基础语法(codewhy版本)(一)

热门文章

最新文章