Форум программистов, компьютерный форум, киберфорум
jQuery
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.80/5: Рейтинг темы: голосов - 5, средняя оценка - 4.80
 Аватар для KaRaNTiN
44 / 44 / 11
Регистрация: 10.06.2009
Сообщений: 311
Записей в блоге: 2

ООП, наследование методов отца

30.10.2013, 13:40. Показов 968. Ответов 1
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Суток времени доброго!)..

Есть такой вот код:

Кликните здесь для просмотра всего текста
JavaScript
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
function Block(){
    this.width = "50px";
    this.height = "50px";
    this.typeMove = "";
    this.time = 5000;
}
Block.prototype.test = function (xPosition, yPosition){
        if(xPosition == "450px" || xPosition == "650px"){
            this.width = "100px";
            this.height = "100px";
        }
        if(yPosition == "250px" || yPosition == "450px"){
            this.width = "100px";
            this.height = "100px";
        }
    }
function move_block(){
    this.error = function(typeError){
        switch(typeError){
            case 1: alert('no TypeMove');break;
        }
    }
    this.setMove = function(id, object){
        switch(id){
            case 'f1': {
                this.typeMove = function(object){
                    object.animate({
                            "left": "+=450"
                        },
                        this.time, 
                        function(){
                            this.test(object.css("left"), object.css("top"));
                            styles = {
                                width: this.width,
                                height: this.height,
                            }
                            object.css(styles);                     
                        }
                    );
                }; 
            };break;
            case 'f2': this.typeMove = function(object){
                object.animate({
                        "top": "+=250"
                    },
                    this.time, 
                    function(){
                        this.test(object.css("left"), object.css("top"));
                        styles = {
                            width: this.width,
                            height: this.height,
                        }
                        object.css(styles);                     
                    }
                );
            }; break;
            case 'f3': this.typeMove = function(object){
                object.animate({
                        "top": "-=300"
                    },
                    this.time, 
                    function(){
                        this.test(object.css("left"), object.css("top"));
                        styles = {
                            width: this.width,
                            height: this.height,
                        }
                        object.css(styles);                     
                    }
                );
            }; break;
            case 'f4': this.typeMove = function(object){
                object.animate({
                        "left": "-=350"
                    },
                    this.time, 
                    function(){
                        this.test(object.css("left"), object.css("top"));
                        styles = {
                            width: this.width,
                            height: this.height,
                        }
                        object.css(styles);                     
                    }
                );
            }; break;
            default: this.error(1);
        };
        this.typeMove(object);
    }
}
$(document).ready(function(){
    move_block.prototype  = new Block();
    move = new move_block();
    $(".item").each(function(item){
        var className = $(this).attr("class").split(" ");
        move.setMove(className[1], $(this));
    });
})


Осуществляется движение 4х квадратов. Я за сутки перечитал тонну статей, тонну сайтов посетил, но вопрос меня таки мучает:

Почему при такой схеме наследования дочерний класс не может обратиться к родительскому методу test через this?)... К свойствам такой доступ есть. В DOM тоже метод пронаследовался, а вот обратиться к нему через this нельзя.

Подскажите, пожалуйста, почему?..
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
30.10.2013, 13:40
Ответы с готовыми решениями:

ООП, наследование, перегрузка методов
Создать класс квадрат, член класса — длина стороны. Предусмотреть в классе методы вычисления и вывода сведений о фигуре: периметр, площадь,...

Основы ООП. Наследование. Вызов методов
Приветствую! Прошу пояснения и задания вектора поиска в документации :scratch: Разбираюсь с ООП в PHP. Возник вопрос с вызовом...

ООП. Наследование переменных и методов от Базового класса к Дочернему и наоборот
class Money : { public: int Selection() { //Здесь играет роль SumToGrn(double &Sum) которую текущий базовый класс не видит. ...

1
 Аватар для Vovan-VE
13210 / 6599 / 1041
Регистрация: 10.01.2008
Сообщений: 15,069
30.10.2013, 15:44
Цитата Сообщение от KaRaNTiN Посмотреть сообщение
JavaScript
26
27
28
29
30
31
32
this.typeMove = function(object){
    object.animate({
        "left": "+=450"
    },
    this.time, 
    function(){
        this.test(
JavaScript
31
32
    function () {
        console.log(this); // тут уже object, а не то, что Вы ожидали
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
30.10.2013, 15:44
Помогаю со студенческими работами здесь

Наследование методов
Может мне стоит книжку почитать или получше подумать над структурой, но вопрос вот: Есть у нас древо классов: base > s2 > s3 >...

Наследование методов
Можно ли как то классу наследнику запретить наследовать какой то из методов или полей супер класса?

Наследование методов C++
Подскажите, если у меня есть класс, в нём описан метод добавления элемента add_element(int number); который в свою очередь основан на...

Наследование. Перекрытие методов
Нужно создать класс TFigure. В этом классе определить абстрактный метод sq – расчет площади фигуры и конструктор, который задает цвет и...

Наследование параметризованных методов
Всем привет! Нигде не могу найти правильный синтаксис для такой ситуации. Ситуация: Есть класс BaseClass: class BaseClass...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
Установка Emscripten SDK (emsdk) и CMake на Windows для сборки C и C++ приложений в WebAssembly (Wasm)
8Observer8 30.01.2026
Чтобы скачать Emscripten SDK (emsdk) необходимо сначало скачать и уставить Git: Install for Windows. Следуйте стандартной процедуре установки Git через установщик. Система контроля версиями Git. . .
Подключение Box2D v3 к SDL3 для Android: физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования. Часть библиотеки BedvitCOM Использованы. . .
Загрузка PNG с альфа-каналом на SDL3 для Android: с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
Загрузка PNG с альфа-каналом на SDL3 для Android: с помощью SDL3_image
8Observer8 27.01.2026
Содержание блога SDL3_image - это библиотека для загрузки и работы с изображениями. Эта пошаговая инструкция покажет, как загрузить и вывести на экран смартфона картинку с альфа-каналом, то есть с. . .
Влияние грибов на сукцессию
anaschu 26.01.2026
Бифуркационные изменения массы гриба происходят тогда, когда мы уменьшаем массу компоста в 10 раз, а скорость прироста биомассы уменьшаем в три раза. Скорость прироста биомассы может уменьшаться за. . .
Воспроизведение звукового файла с помощью SDL3_mixer при касании экрана Android
8Observer8 26.01.2026
Содержание блога SDL3_mixer - это библиотека я для воспроизведения аудио. В отличие от инструкции по добавлению текста код по проигрыванию звука уже содержится в шаблоне примера. Нужно только. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru