JavaScript随笔——eval

随笔系列:随便写写,可能没什么实际价值,全靠兴趣。
场景:今天一个小伙伴问我,JavaScript里有什么函数可以对数组求和。比如:

var a = [1,2,3,4,5];

想了一下,没有现成的。
那么既然被问了,总不会写一个for循环吧,那样显得太年轻。
于是上网查了一下,发现可以用eval完成。真是错怪eval,以为这家伙只能用来解析JSON,啊哈哈~
具体如下:

var a = [1, 2, 3, 4, 5]
console.log(eval(a.join('+'))) // 15

具体就是把a数组转换成1+2+3+4+5的字符串,然后用转换一段JavaScript源码进行执行。
功能是实现了,但是数组里万一返回字符串,返回其他乱七八糟的比如null,undefined之类的该怎么办。也简单,那就过滤掉。

var test = [1, 2, 3, 4, 5, undefined, null, '1', 'aaaa']
var result = eval($.map(test, function(v) {
    if(typeof v === 'number') return v
}).join('+'))
console.log(result) // 15

当然,上面这些并不是重点,重点在于,终于理解了这个eval的用法。

// 可以这样写
console.log(eval('1+2+3')) // 6

// 可以这样写
var a = 1
console.log(eval('a = a + 1')) // a = 2

// 可以这样写
eval('+function(){alert(1)}()') // 1

// 最常见的还是
eval('({a : 1})') // 这个就是常用的JSON解析

当然eval是不能滥用的,也不倡导使用,原因如下:
1、性能不好
2、不安全
3、产生混乱的代码逻辑

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值