From 074785cea106179cb3305637055ab0a009ca74f2 Mon Sep 17 00:00:00 2001 From: Peter Bengtsson Date: Tue, 8 Dec 2020 14:42:52 -0500 Subject: initial commit --- .../global_objects/regexp/@@search/index.html | 116 +++++++++++++++++++++ 1 file changed, 116 insertions(+) create mode 100644 files/ru/web/javascript/reference/global_objects/regexp/@@search/index.html (limited to 'files/ru/web/javascript/reference/global_objects/regexp/@@search') diff --git a/files/ru/web/javascript/reference/global_objects/regexp/@@search/index.html b/files/ru/web/javascript/reference/global_objects/regexp/@@search/index.html new file mode 100644 index 0000000000..ee37017a2a --- /dev/null +++ b/files/ru/web/javascript/reference/global_objects/regexp/@@search/index.html @@ -0,0 +1,116 @@ +--- +title: 'RegExp.prototype[@@search]()' +slug: Web/JavaScript/Reference/Global_Objects/RegExp/@@search +tags: + - JavaScript + - Prototype + - Reference + - RegExp + - метод + - регулярные выражения +translation_of: Web/JavaScript/Reference/Global_Objects/RegExp/@@search +--- +
{{JSRef}}
+ +

Метод [@@search]() выполняет поиск совпадения между регулярным выражением this и строкой.

+ +

Синтаксис

+ +
regexp[Symbol.search](str)
+ +

Параметры

+ +
+
str
+
{{jsxref("String")}}, являющийся объектом поиска.
+
+ +

Возвращаемое значение

+ +
+
integer
+
В случае успеха, [@@search]() вернёт индекс первого совпадения регулярного выражения внутри строки. В противном случае, он вернёт -1.
+
+ +

Описание

+ +

Этот метод вызывается внутрнее в {{jsxref("String.prototype.search()")}}. Например, два следующих примера вернут один и тот же результат.

+ +
'abc'.search(/a/);
+
+/a/[Symbol.search]('abc');
+ +

Этот метод существует для настройки поведения поиска в подклассах RegExp.

+ +

Примеры

+ +

Прямой вызов

+ +

Этот метод можно использовать почти так же, как {{jsxref("String.prototype.search()")}}, за исключением другого this и другого порядка аргументов.

+ +
var re = /-/g;
+var str = '2016-01-02';
+var result = re[Symbol.search](str);
+console.log(result);  // 4
+
+ +

Используя @@search в подклассах

+ +

Подкласс {{jsxref("RegExp")}} может быть перезаписан с помощью метода [@@search]() для изменения поведения.

+ +
class MyRegExp extends RegExp {
+  constructor(str) {
+    super(str)
+    this.pattern = str;
+  }
+  [Symbol.search](str) {
+    return str.indexOf(this.pattern);
+  }
+}
+
+var re = new MyRegExp('a+b');
+var str = 'ab a+b';
+var result = str.search(re); // String.prototype.search calls re[@@search].
+console.log(result); // 3
+
+ +

Спецификации

+ + + + + + + + + + + + + + + + + + + +
СпецификацияСтатусКомментарий
{{SpecName('ES6', '#sec-regexp.prototype-@@search', 'RegExp.prototype[@@search]')}}{{Spec2('ES6')}}Изначальное определение.
{{SpecName('ESDraft', '#sec-regexp.prototype-@@search', 'RegExp.prototype[@@search]')}}{{Spec2('ESDraft')}} 
+ +

Совместимость с браузерами

+ +
+ + +

{{Compat("javascript.builtins.RegExp.@@search")}}

+
+ +

Смотрите также

+ + -- cgit v1.2.3-54-g00ecf