不用循环,不用递归,输出1到100的整数

本文介绍了如何在JavaScript中利用new Function构造函数动态执行代码,以实现不用循环和递归的方式输出从1到100的整数。通过分析dot.js源码中的用法,探讨了new Function的参数body以及它与eval的区别。作者分享了从网上看到的不同解决方案,并提供了自己的尝试,尽管这种方法在实际开发中可能并无太大意义。
摘要由CSDN通过智能技术生成

今天在看dot.js源码的时候注意到,原来dot return的是一段js 字符串然后包装成function, 貌似:

var str = "var out='<p>' + it.key + '</p>'; return out;"

return new Function('it', str);

然后:

div.innerHTML = template(data_obj);

我是在node render的,跟这是有区别的,所以我用了dot-emc,他给出的代码是:

doT.template(template, curOptions.templateSettings, this)(vars);

以前一直用的eval,所以没有注意过new Function,今天特别了解啦一下:

new Function(argument_names…, body): 注意参数中的body. 这样,用new Function(‘body’)(), 也可以像eval一样动态执行代码。

无意中看到啦一个特别有意思的题目:不用循环,不用递归,输出1到100的整数

于是就看到众人给出了一堆的方案,参考

http://www.douban.com/note/274567683/?type=like

http://www.cnblogs.com/cuixiping/archive/2008/07/12/1241388.html

于是自己也写了一段尝试了一下,不能用有意思来形容,毕竟很多时候我们需要解释他的本质。

我的测试代码

var obj = {
    name: 'scope name'
};

var str = "var out=it.name; return out;";

var result = new Function('it', str)(obj);

console.log(result);

// 求和
var i =0;
var sum = eval('0' + new Array(101).join('+(++i)'));

console.log(sum);

// 1 - 100 输出
i = 0;

eval((new Array(101)).join('console.log(this);console.log(++i);'));

eval((new Array(101)).join(','));
这种方式输出1 - 100会快于for吗?感觉每次都在创建一个新数组,开销会不会更大呢?

其实记录个time马上就知道啦,个人感觉没有意义,也不会在代码中这么使用,跑题了,不研究也不这么使用,继续工作。


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值