748

在 Perl 中,我可以使用以下语法多次重复一个字符:

$a = "a" x 10; // results in "aaaaaaaaaa"

有没有一种简单的方法可以在 Javascript 中实现这一点?我显然可以使用一个函数,但我想知道是否有任何内置方法或其他一些聪明的技术。

4

24 回答 24

1466

如今,几乎所有地方都实现了repeat字符串方法。(它不在 Internet Explorer 中。)因此,除非您需要支持较旧的浏览器,否则您可以简单地编写:

"a".repeat(10)

之前repeat,我们使用了这个 hack:

Array(11).join("a") // create string with 10 a's: "aaaaaaaaaa"

(请注意,长度为 11 的数组只能得到 10 个“a”,因为Array.join将参数放在数组元素之间。)

Simon 还指出,根据这个基准,在 Safari 和 Chrome(但不是 Firefox)中,通过简单地附加一个 for 循环来重复一个字符的速度似乎更快(虽然有点不简洁)。

于 2009-12-09T22:49:23.723 回答
312

在新的 ES6 和谐中,您将拥有使用repeat执行此操作的本地方式。ES6 现在还只是实验性的,这个特性已经在 Edge、FF、Chrome 和 Safari 中可用

"abc".repeat(3) // "abcabcabc"

当然,如果重复功能不可用,您可以使用 old-goodArray(n + 1).join("abc")

于 2014-05-02T21:16:52.223 回答
54

如果你经常重复自己的话会很方便:

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

alert(  'Are we there yet?\nNo.\n'.repeat(10)  )

于 2009-12-10T02:50:40.710 回答
13

另一种选择是:

for(var word = ''; word.length < 10; word += 'a'){}

如果您需要重复多个字符,请乘以您的条件:

for(var word = ''; word.length < 10 * 3; word += 'foo'){}

注意:您不必像使用 1 那样过冲word = Array(11).join('a')

于 2014-08-21T13:55:44.373 回答
13

最高效的方式是https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/String/repeat

短版如下。

  String.prototype.repeat = function(count) {
    if (count < 1) return '';
    var result = '', pattern = this.valueOf();
    while (count > 1) {
      if (count & 1) result += pattern;
      count >>>= 1, pattern += pattern;
    }
    return result + pattern;
  };
  var a = "a";
  console.debug(a.repeat(10));

来自 Mozilla 的 Polyfill:

if (!String.prototype.repeat) {
  String.prototype.repeat = function(count) {
    'use strict';
    if (this == null) {
      throw new TypeError('can\'t convert ' + this + ' to object');
    }
    var str = '' + this;
    count = +count;
    if (count != count) {
      count = 0;
    }
    if (count < 0) {
      throw new RangeError('repeat count must be non-negative');
    }
    if (count == Infinity) {
      throw new RangeError('repeat count must be less than infinity');
    }
    count = Math.floor(count);
    if (str.length == 0 || count == 0) {
      return '';
    }
    // Ensuring count is a 31-bit integer allows us to heavily optimize the
    // main part. But anyway, most current (August 2014) browsers can't handle
    // strings 1 << 28 chars or longer, so:
    if (str.length * count >= 1 << 28) {
      throw new RangeError('repeat count must not overflow maximum string size');
    }
    var rpt = '';
    for (;;) {
      if ((count & 1) == 1) {
        rpt += str;
      }
      count >>>= 1;
      if (count == 0) {
        break;
      }
      str += str;
    }
    // Could we try:
    // return Array(count + 1).join(this);
    return rpt;
  }
}
于 2014-10-27T13:05:09.813 回答
12
Array(10).fill('a').join('')

尽管投票最多的答案更紧凑,但使用这种方法,您不必添加额外的数组项。

于 2017-08-16T15:41:40.730 回答
11

如果你不反对在你的项目中包含一个库,lodash 有一个重复功能。

_.repeat('*', 3);
// → '***

https://lodash.com/docs#repeat

于 2015-09-08T21:22:31.993 回答
10

适用于所有浏览器

以下功能的执行速度将比已接受答案中建议的选项快得多:

var repeat = function(str, count) {
    var array = [];
    for(var i = 0; i < count;)
        array[i++] = str;
    return array.join('');
}

你会这样使用它:

var repeatedString = repeat("a", 10);

要将此功能的性能与已接受答案中提出的选项的性能进行比较,请参阅此 Fiddle此 Fiddle以获取基准。

仅适用于现代浏览器

在现代浏览器中,您现在可以使用以下String.prototype.repeat方法执行此操作:

var repeatedString = "a".repeat(10);

在MDN上阅读有关此方法的更多信息。

这个选项甚至更快。不幸的是,它不适用于任何版本的 Internet Explorer。表中的数字指定了完全支持该方法的第一个浏览器版本:

在此处输入图像描述

于 2016-02-25T18:23:34.577 回答
7

在 ES2015/ES6 中,您可以使用"*".repeat(n)

因此,只需将其添加到您的项目中,您就可以开始了。

  String.prototype.repeat = String.prototype.repeat || 
    function(n) {
      if (n < 0) throw new RangeError("invalid count value");
      if (n == 0) return "";
      return new Array(n + 1).join(this.toString()) 
    };
于 2016-03-16T21:01:11.273 回答
6
/**  
 * Repeat a string `n`-times (recursive)
 * @param {String} s - The string you want to repeat.
 * @param {Number} n - The times to repeat the string.
 * @param {String} d - A delimiter between each string.
 */

var repeat = function (s, n, d) {
    return --n ? s + (d || "") + repeat(s, n, d) : "" + s;
};

var foo = "foo";
console.log(
    "%s\n%s\n%s\n%s",

    repeat(foo),        // "foo"
    repeat(foo, 2),     // "foofoo"
    repeat(foo, "2"),   // "foofoo"
    repeat(foo, 2, "-") // "foo-foo"
);
于 2013-05-09T02:29:00.917 回答
4

另一种快速重复 n 个字符的有趣方法是使用快速求幂算法中的思想:

var repeatString = function(string, n) {
    var result = '', i;

    for (i = 1; i <= n; i *= 2) {
        if ((n & i) === i) {
            result += string;
        }
        string = string + string;
    }

    return result;
};
于 2015-01-06T12:17:45.920 回答
2

为了在我的项目中重复一个值,我使用重复

例如:

var n = 6;
for (i = 0; i < n; i++) {
    console.log("#".repeat(i+1))
}

但要小心,因为此方法已添加到 ECMAScript 6 规范中。

于 2016-03-09T12:12:54.883 回答
2
function repeatString(n, string) {
  var repeat = [];
  repeat.length = n + 1;
  return repeat.join(string);
}

repeatString(3,'x'); // => xxx
repeatString(10,''); // => ""
于 2017-03-16T03:35:36.383 回答
1

这是我使用的:

function repeat(str, num) {
        var holder = [];
        for(var i=0; i<num; i++) {
            holder.push(str);
        }
        return holder.join('');
    }
于 2016-01-16T05:35:15.523 回答
1

右填充零,没有数组或循环。只需repeat()使用 ES6 2015,它现在得到了广泛的支持。如果切换串联,则左焊盘。

function pad(text, maxLength){ 
  var res = text + "0".repeat(maxLength - text.length);
  return res;
}

console.log(pad('hello', 8)); //hello000
于 2020-09-12T14:48:13.103 回答
0

我将扩展@bonbon 的答案。他的方法是“将 N 个字符附加到现有字符串”的简单方法,以防万一有人需要这样做。例如,因为"a google" 是 1 后跟 100 个 zeros

for(var google = '1'; google.length < 1 + 100; google += '0'){}
document.getElementById('el').innerText = google;
<div>This is "a google":</div>
<div id="el"></div>

注意:您必须将原始字符串的长度添加到条件中。

于 2015-04-25T07:02:37.510 回答
0

Lodash提供了与Javascript repeat()函数类似的功能,但并非在所有浏览器中都可用。它被称为_.repeat并且从版本 3.0.0 开始可用:

_.repeat('a', 10);
于 2016-12-13T17:23:02.997 回答
0
var stringRepeat = function(string, val) {
  var newString = [];
    for(var i = 0; i < val; i++) {
      newString.push(string);
  }
  return newString.join('');
}

var repeatedString = stringRepeat("a", 1);
于 2016-12-23T11:31:51.097 回答
0

也可以用作单线:

function repeat(str, len) {
    while (str.length < len) str += str.substr(0, len-str.length);
    return str;
}
于 2017-05-17T03:32:34.120 回答
0

在 CoffeeScript 中:

( 'a' for dot in [0..10]).join('')
于 2017-06-01T13:03:42.387 回答
0

这就是您可以通过 Array() 和 join() 调用函数并获取结果的方式

function repeatStringNumTimes(str, num) {
  // repeat after me
  return num > 0 ? Array(num+1).join(str) : "";
}

console.log(repeatStringNumTimes("a",10))

于 2020-03-09T17:22:37.033 回答
0

只是为了好玩,这里是另一种使用toFixed()的方法,用于格式化浮点数。

通过做

(0).toFixed(2)
(0).toFixed(3)
(0).toFixed(4)

我们得到

0.00
0.000
0.0000

如果前两个字符0.被删除,我们可以使用这种重复模式来生成任何重复。

function repeat(str, nTimes) {
  return (0).toFixed(nTimes).substr(2).replaceAll('0', str);
}

console.info(repeat('3', 5));
console.info(repeat('hello ', 4));

于 2021-06-18T17:40:22.257 回答
-1
String.prototype.repeat = function (n) { n = Math.abs(n) || 1; return Array(n + 1).join(this || ''); };

// console.log("0".repeat(3) , "0".repeat(-3))
// return: "000" "000"
于 2016-10-24T01:18:18.483 回答
-3

这是一个 ES6 版本

const repeat = (a,n) => Array(n).join(a+"|$|").split("|$|");
repeat("A",20).forEach((a,b) => console.log(a,b+1))

于 2017-08-18T10:53:58.107 回答