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

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


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

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

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

Web-программирование: "Java Script(JS): Сильные стороны JS. Продолжение".

 

Продолжаем изучать методику правильного программирования на JS. На прошлом уроке мы остановились на объектах. Продолжим изучать их.

Каждый объект связан с объектом прототипом, от которого он может наследовать свойства. При создании нового объекта можно выбрать объект,  который будет его прототипом. Механизм такого наследования в JavaScript реализован довольно геморойно, но его можно значительно упростить. Для этого нужно реализовать метод create у функции Object:

 

                if(typeof(Object.create)!=='function')

                {

                    Object.create=function(obj)

                    {

                        var F=function() {};

                        F.prototype=o;

                        return new F;

                    }

                }

 

Данная функция будет создавать копию объекта, и изменение полей копии никак не скажется на полях объекта прототипа. Давайте проверим это на примере:

 

<html>

    <head>

        <meta charset="UTF-8">

        <title>Урок 124. Java Script (JS): Прототипы объектов</title>

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

            function test() {

                var test_object={

                    name:"Александр",

                    passport: {

                        ser:123,

                        number:123456

                    },

                    age:41};

               

                if(typeof(Object.create)!=='function')

                {

                    Object.create=function(obj)

                    {

                        var F=function() {};

                        F.prototype=o;

                        return new F;

                    }

                }

               

                var test_object1=Object.create(test_object);

                test_object1.name="Иван";

                alert(test_object.name+" "+test_object.age+" "+test_object.passport.ser);

                alert(test_object1.name+" "+test_object1.age+" "+test_object1.passport.ser);

            }

        </SCRIPT>

    </head>

    <body>

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

            <input type="submit" value="OK" name="ok" ONCLICK="return test()">

        </form>

    </body>

</html>

 

Что характерно, добавляя к прототипу новое поле, мы добавляем его ко всем объектам, созданным на базе этого протитипа. Рассмотримпример:

<html>

    <head>

        <meta charset="UTF-8">

        <title>Урок 124. Java Script (JS): Прототипы объектов</title>

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

            function test() {

                var test_object={

                    name:"Александр",

                    passport: {

                        ser:123,

                        number:123456

                    },

                    age:41};

               

                if(typeof(Object.create)!=='function')

                {

                    Object.create=function(obj)

                    {

                        var F=function() {};

                        F.prototype=o;

                        return new F;

                    }

                }

               

                var test_object1=Object.create(test_object);

                test_object.new_property="123";

                alert(test_object.new_property+" "+test_object1.new_property);

            }

        </SCRIPT>

    </head>

    <body>

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

            <input type="submit" value="OK" name="ok" ONCLICK="return test()">

        </form>

    </body>

</html>

 

Результатом его работы будет два раза по 123:

Web-программирование: "Java Script(JS): Сильные стороны JS. Продолжение".

 

Но, тем не менее, поля объектов, созданных на основе прототипа, меняются независимо:

 

                test_object.new_property="123";

                test_object1.new_property="22222";

 

Web-программирование: "Java Script(JS): Сильные стороны JS. Продолжение".

 

Создание поля у копии не приводит к созданию поля у прототипа:

                test_object1.new_property="ццццц";

 

Web-программирование: "Java Script(JS): Сильные стороны JS. Продолжение".

 

Таким образом, у объектов могут существовать свои независимые от прототипа поля. Если мы попытаемся обратиться к полю, которого нет у объекта, он будет искать их у прототипа. Если не нашел и у него - то у прототипа прототипа и так далее.

Как проверить наличие свойства? Можно воспользоваться функцией typeof, для несуществующего свойства он вернет undefined. Другой способ проверить - это использовать hasOwnProperty, но только в том случае, когда вам необходимо проверить собственное свойство объектов, так как эта функция не учитывает свойства, наследуемые от прототипов.

Перебрать все поля объекта можно вот таким вот образом:

                for (name in test_object1)

                {

                    document.writeln(name+": "+test_object1[name]+"<br>");

                }

 

В выборку попадут как поля прототипа, так и самого объекта. Различить их можно методом hasOwnProperty. И имейте в виду, что порядок полей может быть произвольным (как попало).

 

С уважением, Шуравин Александр, e-mail: megabax@rambler.ru, автор оставляет за собой право публиковать в рассылках ваши письма, если в письме прямо неоговорено нежелание его публиковать.

 


В избранное