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 相关文章推荐
表单(FORM)的一些实用效果代码
Mar 25 Javascript
理解 JavaScript 预解析
Oct 25 Javascript
jquery对象和DOM对象的区别介绍
Aug 09 Javascript
javascript 事件处理示例分享
Dec 31 Javascript
jquery读取xml文件实现省市县三级联动的方法
May 29 Javascript
jQuery动态生成不规则表格(前后端)
Feb 21 Javascript
JS排序之选择排序详解
Apr 08 Javascript
详解vue-router 2.0 常用基础知识点之导航钩子
May 10 Javascript
JS+canvas实现的五子棋游戏【人机大战版】
Jul 19 Javascript
微信小程序实现流程进度的图样式功能
Jan 16 Javascript
微信小程序的mpvue框架快速上手指南
May 15 Javascript
es6函数之尾递归用法实例分析
Apr 25 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
PHP 文件上传全攻略
2010/04/28 PHP
destoon二次开发模板及调用语法汇总
2014/06/21 PHP
PHP filesize函数用法浅析
2019/02/15 PHP
Laravel 之url参数,获取路由参数的例子
2019/10/21 PHP
jquery 插件学习(一)
2012/08/06 Javascript
上传文件返回的json数据会被提示下载问题解决方案
2014/12/03 Javascript
jQuery实现简单的文件上传进度条效果
2020/03/26 Javascript
教你如何终止JQUERY的$.AJAX请求
2016/02/23 Javascript
百度地图给map添加右键菜单(判断是否为marker)
2016/03/04 Javascript
微信小程序 标签传入数据
2017/05/08 Javascript
node.js-v6新版安装具体步骤(分享)
2017/09/06 Javascript
分享5个顶级的JavaScript Ajax组件库
2018/09/16 Javascript
通过实例讲解JS如何防抖动
2019/06/15 Javascript
js函数柯里化的方法和作用实例分析
2020/04/11 Javascript
完美解决vue 中多个echarts图表自适应的问题
2020/07/19 Javascript
vue实现从外部修改组件内部的变量的值
2020/07/30 Javascript
Python的函数的一些高阶特性
2015/04/27 Python
python编码最佳实践之总结
2016/02/14 Python
Python+matplotlib实现华丽的文本框演示代码
2018/01/22 Python
基于python的socket实现单机五子棋到双人对战
2020/03/24 Python
Python批量启动多线程代码实例
2020/02/18 Python
如何利用Python识别图片中的文字
2020/05/31 Python
python3从网络摄像机解析mjpeg http流的示例
2020/11/13 Python
举例讲解Python装饰器
2020/12/24 Python
html5默认气泡修改的代码详解
2020/03/13 HTML / CSS
Expedia泰国:预订机票、酒店和旅游包(航班+酒店)
2016/09/27 全球购物
美国时尚大码女装购物网站:Avenue
2019/05/24 全球购物
后勤自我鉴定
2013/10/13 职场文书
采购经理岗位职责
2014/02/16 职场文书
元旦晚会策划方案
2014/02/18 职场文书
护士自我鉴定总结
2014/03/24 职场文书
双拥工作宣传标语
2014/06/26 职场文书
竞选班干部演讲稿500字
2014/08/20 职场文书
90条交通安全宣传标语
2019/10/12 职场文书
MySQL 那些常见的错误设计规范,你都知道吗
2021/07/16 MySQL
SQL实战演练之网上商城数据库商品类别数据操作
2021/10/24 MySQL