68 lines
3.5 KiB
Markdown
68 lines
3.5 KiB
Markdown
# Начало строки ^ и конец $
|
||
|
||
Знак каретки <code class="pattern">'^'</code> и доллара <code class="pattern">'$'</code> имеют в регулярном выражении особый смысл. Их называют "якорями" (anchor - англ.).
|
||
[cut]
|
||
|
||
Каретка <code class="pattern">^</code> совпадает в начале текста, а доллар <code class="pattern">$</code> -- в конце.
|
||
|
||
**Якоря являются не символами, а проверками.**
|
||
|
||
До этого мы говорили о регулярных выражениях, которые ищут один или несколько символов. Если совпадение есть -- эти символы включаются в результат.
|
||
|
||
А якоря -- не такие. Когда поиск ходит до якоря -- он проверяет, есть ли соответствие, если есть -- продолжает идти по шаблону, не прибавляя ничего к результату.
|
||
|
||
Каретку <code class="pattern">^</code> обычно используют, чтобы указать, что регулярное выражение необходимо проверить именно с начала текста.
|
||
|
||
Например, без каретки найдёт все числа:
|
||
|
||
```js
|
||
//+ run
|
||
var str = '100500 попугаев съели 500100 бананов!';
|
||
alert( str.match(/\d+/ig) ); // 100500, 500100 (нашло все числа)
|
||
```
|
||
|
||
А с кареткой -- только первое:
|
||
|
||
```js
|
||
//+ run
|
||
var str = '100500 попугаев съели 500100 бананов!';
|
||
alert( str.match(/^\d+/ig) ); // 100500 (только в начале строки)*!*
|
||
```
|
||
|
||
Знак доллара <code class="pattern">$</code> используют, чтобы указать, что паттерн должен заканчиваться в конце текста.
|
||
|
||
Аналогичный пример с долларом для поиска числа в конце:
|
||
|
||
```js
|
||
//+ run
|
||
var str = '100500 попугаев съели 500100';
|
||
alert( str.match(/\d+$/ig) ); // 500100
|
||
```
|
||
|
||
Оба якоря используют одновременно, если требуется, чтобы шаблон охватывал текст с начала и до конца. Обычно это требуется при валидации.
|
||
|
||
Например, мы хотим проверить, что в переменной `num` хранится именно десятичная дробь.
|
||
|
||
Ей соответствует регэксп <code class="pattern">\d+\.\d+</code>. Но простой поиск найдёт дробь в любом тексте:
|
||
|
||
```js
|
||
//+ run
|
||
var num = "ля-ля 12.34";
|
||
alert( num.match(/\d+\.\d+/ig) ); // 12.34
|
||
```
|
||
|
||
Наша же задача -- проверить, что `num` *целиком* соответствует паттерну <code class="pattern">\d+\.\d+</code>.
|
||
|
||
Для этого обернём шаблон в якоря <code class="pattern">^...$</code>:
|
||
|
||
```js
|
||
//+ run
|
||
var num = "ля-ля 12.34";
|
||
alert( num.match(/^\d+\.\d+$/ig) ); // null, не дробь
|
||
|
||
var num = "12.34";
|
||
alert( num.match(/^\d+\.\d+$/ig) ); // 12.34, дробь!
|
||
```
|
||
|
||
Теперь поиск ищет начало текста, за которым идёт число, затем точка, ещё число и конец текста. Это как раз то, что нужно.
|
||
|