aboutsummaryrefslogtreecommitdiff
path: root/files/uk/web/javascript/reference/global_objects/string/repeat/index.html
blob: 101776ad15de2bf14c8178198b814fbd547d78ac (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
---
title: String.prototype.repeat()
slug: Web/JavaScript/Reference/Global_Objects/String/repeat
tags:
  - ECMAScript 2015
  - JavaScript
  - String
  - метод
  - рядок
translation_of: Web/JavaScript/Reference/Global_Objects/String/repeat
---
<div>{{JSRef}}</div>

<p>Метод <strong><code>repeat()</code></strong> створює та повертає новий рядок, що містить вказану кількість об'єднаних разом копій рядка, на якому він був викликаний.</p>

<div>{{EmbedInteractiveExample("pages/js/string-repeat.html","shorter")}}</div>



<h2 id="Синтаксис">Синтаксис</h2>

<pre class="syntaxbox"><code><var>str</var>.repeat(<var>count</var>)</code>
</pre>

<h3 id="Параметри">Параметри</h3>

<dl>
 <dt><code><var>count</var></code></dt>
 <dd>Ціле число в діапазоні між <code>0</code> та {{jsxref("Global_Objects/Number/POSITIVE_INFINITY", "+Infinity")}}, що вказує кількість повторів рядка.</dd>
</dl>

<h3 id="Значення_що_повертається">Значення, що повертається</h3>

<p>Новий рядок, що містить вказану кількість копій наданого рядка.</p>

<h3 id="Винятки">Винятки</h3>

<ul>
 <li>{{jsxref("Errors/Negative_repetition_count", "RangeError")}}: число повторів має бути невід'ємним.</li>
 <li>{{jsxref("Errors/Resulting_string_too_large", "RangeError")}}: число повторів має бути меншим за нескінченість та не перевищувати максимальний розмір рядка.</li>
</ul>

<h2 id="Приклади">Приклади</h2>

<pre class="brush: js">'абв'.repeat(-1)    // RangeError
'абв'.repeat(0)     // ''
'абв'.repeat(1)     // 'абв'
'абв'.repeat(2)     // 'абвабв'
'абв'.repeat(3.5)   // 'абвабвабв' (count буде перетворений на ціле число)
'абв'.repeat(1/0)   // RangeError

({ toString: () =&gt; 'абв', repeat: String.prototype.repeat }).repeat(2)
// 'абвабв' (repeat() є загальним методом)
</pre>

<h2 id="Поліфіл">Поліфіл</h2>

<p>Цей метод був доданий у специфікацію ECMAScript 2015 та може поки не бути доступним в усіх реалізаціях JavaScript. Однак, ви можете створити поліфіл <code>String.prototype.repeat()</code> за допомогою наступного коду:</p>

<pre class="brush: js" dir="rtl">if (!String.prototype.repeat) {
  String.prototype.repeat = function(count) {
    'use strict';
    if (this == null)
      throw new TypeError('неможливо перетворити ' + this + ' на об\'єкт');

    var str = '' + this;
    // Щоб перетворити рядок на ціле число.
    count = +count;
    // Перевірка на NaN
    if (count != count)
      count = 0;

    if (count &lt; 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 '';

    // Гарантія того, що count є цілим 31-бітним числом, дозволяє значно оптимізувати
    // головну частину. Але, все ж, найновіші (серпень 2014) переглядачі не можуть
    // впоратись з рядками з 1 &lt;&lt; 28 символів чи довше, а отже:
    if (str.length * count &gt;= 1 &lt;&lt; 28)
      throw new RangeError('repeat count must not overflow maximum string size');

    var maxCount = str.length * count;
    count = Math.floor(Math.log(count) / Math.log(2));
    while (count) {
       str += str;
       count--;
    }
    str += str.substring(0, maxCount - str.length);
    return str;
  }
}</pre>

<h2 id="Специфікації">Специфікації</h2>

<table class="standard-table">
 <thead>
  <tr>
   <th scope="col">Специфікація</th>
  </tr>
 </thead>
 <tbody>
  <tr>
   <td>{{SpecName('ESDraft', '#sec-string.prototype.repeat', 'String.prototype.repeat')}}</td>
  </tr>
 </tbody>
</table>

<h2 id="Сумісність_з_веб-переглядачами">Сумісність з веб-переглядачами</h2>

<p class="hidden">The compatibility table in this page is generated from structured data. If you'd like to contribute to the data, please check out <a href="https://github.com/mdn/browser-compat-data">https://github.com/mdn/browser-compat-data</a> and send us a pull request.</p>

<p>{{Compat("javascript.builtins.String.repeat")}}</p>