JavaScript 字符串乘法


Posted in Javascript onAugust 20, 2009

原文地址:http://www.davidflanagan.com/2009/08/string-multipli.html
原作者:David Flanagan
在Ruby中,“*”操作符用一个字符串作为左边参数,一个数字作为右边参数,来实现字符串重复。例如,"Ruby" * 2 的值为 "RubyRuby"。这仅在少数地方有用(例如,生成一张由连字符等ASCII 码字符构成的表格),但是非常简洁。而且好过写一个循环来连接n次字符串——这样显得很没效率。

我刚刚发现在JavaScript中有个聪明的技巧来实现字符串的乘法:

String.prototype.times = function(n) { 
return Array.prototype.join.call({length:n+1}, this); 
}; 
"js".times(5) // => "jsjsjsjsjs"

这个方法是调用一个由元素全为“undefined”的数组的Array.join()行为。但是它并没有真正创建一个包含 n+1 个“undefined”元素的数组。它利用一个包含 length 属性的匿名对象,依靠 Array 对象的原型函数 join()。因为 “Object” 不是数组,不能直接调用 join(),因此不得不通过原型的 call() 来实现。下面给出一个同样效果的简单版本:

String.prototype.times = function(n) { return (new Array(n+1)).join(this);};

当我们调用 Array 的带一个参数的构造器时,仅仅是设置了数组的长度,实际上并没有创建数组的元素。

我仅在 Firefox 下对其做了测试,我估计它会比普通的循环更加有效,但我并没有进行基准测试。

作者简介
David Flanagan 是一个醉心于Java写作的计算机程序员,他的大部分时间都致力于编写Java相关图书。David 在麻省理工学院获得了计算机科学于工程学位。他生活在地处西雅图和温哥华之间的美国太平洋西北海岸。他在O'Reilly出版的畅销书有《Java in a Nutshell》、《Java Foundation Classes in a Nutshell》、《Java Enterprise in a Nutshell》、《JavaScript: The Definitive Guide》、《JavaScript Pocket Reference》以及《The Ruby Programming Language》等。

我的评论
如果要考虑效率的话,对循环迭代稍作优化可能效率更高。比如下面这段递归调用,算法复杂度是O(log2n)。在Google Chrome下测试结果是比 David 的方法执行更快,但不得不承认他的方法很优雅!

String.prototype.times = function(n) { 
if ( n == 1 ) { 
return this; 
} 
var midRes = this.times(Math.floor(n/2)); 
midRes += midRes; 
if ( n % 2 ) { 
midRes += this; 
} 
return midRes; 
}

后记
David 采纳了我的建议,他又为我们写了一段非递归的版本。请参看他的博客原文:http://www.davidflanagan.com/2009/08/good-algorithms.html
联系方式
我的邮箱,欢迎来信(redraiment@gmail.com)
Javascript 相关文章推荐
图片自动更新(说明)
Oct 02 Javascript
双击滚屏-常用推荐
Nov 29 Javascript
一个js实现的所谓的滑动门
May 23 Javascript
Javascript中自动切换焦点实现代码
Dec 15 Javascript
jquery实现省市select下拉框的替换(示例代码)
Feb 22 Javascript
JS获取几种URL地址的方法小结
Feb 26 Javascript
利用Keydown事件阻止用户输入实现代码
Mar 11 Javascript
无限树Jquery插件zTree的常用功能特性总结
Sep 11 Javascript
js表格排序实例分析(支持int,float,date,string四种数据类型)
May 06 Javascript
JavaScript模板引擎用法实例
Jul 10 Javascript
vue-axios使用详解
May 10 Javascript
使用js实现一个简单的滚动条过程解析
Sep 10 Javascript
javascript 短路法代码精简
Aug 20 #Javascript
斜45度寻路实现函数
Aug 20 #Javascript
javascript 多级checkbox选择效果
Aug 20 #Javascript
调用js时ie6和ie7,ff的区别
Aug 19 #Javascript
jquery 入门教程 [翻译] 推荐
Aug 17 #Javascript
jQuery select控制插件
Aug 17 #Javascript
javascript 无提示关闭窗口脚本
Aug 17 #Javascript
You might like
PHP5.3的垃圾回收机制(动态存储分配方案)深入理解
2012/12/10 PHP
Linux下手动编译安装PHP扩展的例子分享
2014/07/15 PHP
php过滤HTML标签、属性等正则表达式汇总
2014/09/22 PHP
PHP简单生成缩略图相册的方法
2015/07/29 PHP
php 获取文件行数的方法总结
2016/10/11 PHP
thinkphp关于简单的权限判定方法
2017/04/03 PHP
thinkphp中U方法按路由规则生成url的方法
2018/03/12 PHP
jQuery $.each的用法说明
2010/03/22 Javascript
有趣的JavaScript数组长度问题代码说明
2011/01/20 Javascript
使用jQuery+HttpHandler+xml模拟一个三级联动的例子
2011/08/09 Javascript
jquery $.getJSON()跨域请求
2011/12/21 Javascript
清除div下面的所有标签的方法
2014/02/17 Javascript
js获取浏览器基本信息大全
2014/11/27 Javascript
创建你的第一个AngularJS应用的方法
2015/06/16 Javascript
详解nodejs与javascript中的aes加密
2016/05/22 NodeJs
Vue EventBus自定义组件事件传递
2018/06/25 Javascript
element-ui组件table实现自定义筛选功能的示例代码
2019/03/15 Javascript
WEB前端性能优化的7大手段详解
2020/02/04 Javascript
[55:35]DOTA2-DPC中国联赛 正赛 CDEC vs Dragon BO3 第二场 1月22日
2021/03/11 DOTA
Windows系统下PhantomJS的安装和基本用法
2018/10/21 Python
浅谈Python采集网页时正则表达式匹配换行符的问题
2018/12/20 Python
在python中实现强制关闭线程的示例
2019/01/22 Python
python使用docx模块读写docx文件的方法与docx模块常用方法详解
2020/02/17 Python
Django {{ MEDIA_URL }}无法显示图片的解决方式
2020/04/07 Python
基于plt.title无法显示中文的快速解决
2020/05/16 Python
洲际酒店集团大中华区:IHG中国
2016/08/17 全球购物
美国第一香水网站:Perfume.com
2017/01/23 全球购物
印度网上药店:1mg
2017/10/13 全球购物
英国最大的海报商店:GB Posters
2018/03/20 全球购物
德国BA保镖药房中文网:Bodyguard Apotheke
2021/03/09 全球购物
置业顾问岗位职责
2014/03/02 职场文书
网络技术专业求职信
2014/05/02 职场文书
计算机软件专业求职信
2014/06/10 职场文书
党员批评与自我批评总结
2014/10/15 职场文书
中小学生学籍证明
2014/10/25 职场文书
《我和小伙伴》教学反思
2016/02/20 职场文书