Отправляет email-рассылки с помощью сервиса Sendsay
  Все выпуски  

Web-программирование - это просто!


Новое на сайте Программирование - это просто! (www.easyprog.ru):

В платном разделе

В бесплатном разделе

WEB-программирование. "Java Script(JS): Регулярные выражение. Продолжение-2".

Продолжаем изучать регулярные выражения. На уроке WEB-Программирование: "Java Script(JS): Регулярные выражения. Метасимволы. Продолжение" мы закончили тему метасимволов. Сейчас займемся работой с регулярными выражениями. Мы уже изучили метод test() объекта регулярных выражений. Еще есть search. Если первый просто выдает true или false, в зависимости от того, соответствует или нет строка регулярному выражению, то второй метод возвращает позицию соответствующей строки.  Проиллюстрируем работу и того и другого.

Пример проверки адреса электронной почты:

 

<html>

    <head>

        <meta charset="UTF-8">

        <title>Урок 127. Java Script (JS): Работа с регулярными выражениями</title>

        <SCRIPT Language="JavaScript" type="text/javascript" src="myapp.js">

        </SCRIPT>      

        <SCRIPT LANGUAGE="JavaScript" TYPE="text/javascript">      

            function isEmail() {

                item=document.myform.email

                var str=item.value;

                var re=/^[\w-]+(\.[\w-]+)*@([\w-]+\.)+[a-zA-Z]{2,7}$/;

                if(!re.test(str))

                {

                    alert("Неверно введен email");

                    item.focus();

                    item.select();

                }

            }          

        </SCRIPT>

    </head>

    <body>

        <form name="myform" method="GET">

            <input type="button" value="OK" name="ok" ONCLICK="return isEmail()">

            <input type="text" name="email">

        </form>

    </body>

</html>

 

Испытаем его, введя верный емайл, например:  proba@rambler.ru. Программа ничего не ответит (все правильно). А теперь сдаем ошибку, например, забудем поставить .ru, введем два знака "@", либо запрещенный символ, или еще что-то вроде этого, и получим сообщение об ошибке.

Теперь разберем это выражение более подробно. Сначала у нас идет \w- в квадратных скобках. Символа "\w", как вы помните, это буква, цифра или знак подчеркивания. Знак "-" обознает интервал. В принципе, можно смело написать и так /^[\w]+(\.[\w]+)*@([\w]+\.)+[a-zA-Z]{2,7}$/, ничего не изменится. Этот знак у нас в квадратных скобках после него идет модификатор +, обозначающий, что таких знаков должно быть один или больше. То есть, выражение типа "@rambler.ru" где пропущено имя почты, уже не пройдет через жтот фильтр.

Затем у нас идет группа (\.[\w-]+) - может быть точка и буквы после нее (но не несколько точек подряд!). То есть, верным окажется, например, такой email: 1.1ddd.2@rambler.ru?, а вот такой 1..1ddd.2@rambler.ru - уже ошибка. Что характерно, и с точки емайл тоже не может начинаться - не пройдет по первому фильтру. У группы значок "*", который означает, что данная группа может встречаться 0 или любое число раз. То есть, точки могут и отсутствовать. 

Потом в емайле должен стоять знак "@" - он у нас обозначен явно. Затем снова та же конструкция "([\w]+\.)+" для ввода доменного имени (сколь угодно повторений комбинаций из символов и точек), затем обязательно точка и домен не менее чем из двух букв, но не более, чем из семи  - "[a-zA-Z]{2,7}"

Еще один примерщик, проверка идентификаторов переменных, которые могу начинаться только с буквы или знака "_", но далее могут идти буквы, цифры и знаки "_":

<html>

    <head>

        <meta charset="UTF-8">

        <title>Урок 127. Java Script (JS): Работа с регулярными выражениями</title>

        <SCRIPT Language="JavaScript" type="text/javascript" src="myapp.js">

        </SCRIPT>      

        <SCRIPT LANGUAGE="JavaScript" TYPE="text/javascript">      

            function isVar() {

                item=document.myform.email

                var str=item.value;

                var re=/^[\a-zA-Z_]+[\w]*$/;

                if(!re.test(str))

                {

                    alert("Неверно введен идентификатор переменной");

                    item.focus();

                    item.select();

                }

            }          

        </SCRIPT>

    </head>

    <body>

        <form name="myform" method="GET">

            <input type="button" value="OK" name="ok" ONCLICK="return isVar()">

            <input type="text" name="email">

        </form>

    </body>

</html>

 


В избранное