Форум программистов, компьютерный форум, киберфорум
JavaScript для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
1 / 1 / 1
Регистрация: 04.08.2019
Сообщений: 19

click this

01.06.2020, 23:57. Показов 497. Ответов 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
function Widget(width,height) {
    this.width = width || 50;
    this.height = height || 50;
    this.$elem = null;
}
Widget.prototype.render = function($where){
    if (this.$elem) {
        this.$elem.css( {
            width: this.width + "px",
            height: this.height + "px"
        } ).appendTo( $where );
    }
};
// дочерний класс
 
function Button(width,height,label) {
    // "super" constructor call
    Widget.call( this, width, height );
    this.label = label || "Default";
    this.$elem = $( "<button>" ).text( this.label );
}
// Заставить `Button` "наследовать" от `Widget`
Button.prototype = Object.create( Widget.prototype );
 
// переопределить базовую "унаследованную" версию `render(..)`
Button.prototype.render = function($where) {
    // вызов "super"
    Widget.prototype.render.call( this, $where );
    this.$elem.click( this.onClick.bind( this ) );
};
 
Button.prototype.onClick = function(evt) {
    console.log( "Button '" + this.label + "' clicked!" );
};
 
$( document ).ready( function(){
    var $body = $( document.body );
    var btn1 = new Button( 125, 30, "Hello" );
    var btn2 = new Button( 150, 40, "World" );
    btn1.render( $body );
    btn2.render( $body );
} );

Вопрос:
Если есть событие "click", то "this" ссылается на элемент который кликнули.
Но тут
JavaScript
1
 this.$elem.click( this.onClick.bind( this ) );
, где
JavaScript
1
 .bind( this )
почемуто ссылается на объект Button

К примеру, если поменять на
JavaScript
1
 this.$elem.click( function(){alert(this)});
, то this будет єлемент по которому кликнули.

Почему так?

Добавлено через 2 часа 11 минут
И еще один вопрос:

JavaScript
1
this.$elem.click( this.onClick.bind( this ) );
здесь обработчик события - метод "click" jquery.

А как поставить обработчик методом JS? Это нужно менять
JavaScript
1
this.$elem = $( "<button>" ).text( this.label );
на "document.createElement" и соответственно добавлять стили методом JS? Потому что я пробовал просто добавить "addEventListener" вместо "click", то ничего не вышло?
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
01.06.2020, 23:57
Ответы с готовыми решениями:

Не работает on click
Добрый день. Только начинаю изучать js Подскажите пожалуйста почему при нажатии на кнопку name-submit в ndex.php не выводит 1 ...

Добавить событие click
Отладчик не ругается на addEventListener, не может прочитать как я понял, подскажите как решить проблему? &lt;!DOCTYPE HTML&gt; ...

Событие keydown + click
хочу сделать Selectable как в jqueryUI, вроде всё работает но при отжати славишу ctrl, продолжаются выделятся блоки &lt;div...

1
Эксперт JS
6496 / 3907 / 2006
Регистрация: 14.06.2018
Сообщений: 6,781
02.06.2020, 14:21
Цитата Сообщение от DiscoN Посмотреть сообщение
Но тут
this.$elem.click( this.onClick.bind( this ) );, где
.bind( this ) почемуто ссылается на объект Button
Потому что метод bind() специально предназначен для того, чтобы подсовывать в функцию любое указанное значение this.
В данном случае подсовывает экземпляр типа Button.
Цитата Сообщение от DiscoN Посмотреть сообщение
К примеру, если поменять на
this.$elem.click( function(){alert(this)});
то this будет єлемент по которому кликнули.
Потому что по умолчанию абсолютно все обработчики события DOM в this имеют ссылку на элемент, по которому кликнули.
bind() как раз меняет поведение по умолчанию на поведение не по умолчанию.

Добавлено через 3 часа 4 минуты
Цитата Сообщение от DiscoN Посмотреть сообщение
И еще один вопрос
Для начала перепишем скрипт с ужасающего синтаксиса ES5 образца 2012 года на синтаксис ES2015 образца 2015 года:
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
class Widget {
    constructor(width, height) {
        this.width = width || 50;
        this.height = height || 50;
        this.$elem = null;
    }
    render($where) {
        if (this.$elem) {
            this.$elem.css({
                width: this.width + "px",
                height: this.height + "px"
            }).appendTo($where);
        }
    }
}
// дочерний класс
class Button extends Widget {
    constructor(width, height, label) {
        // "super" constructor call
        super(width, height);
        this.label = label || "Default";
        this.$elem = $("<button>").text(this.label);
    }
    // переопределить базовую "унаследованную" версию `render(..)`
    render($where) {
        // вызов "super"
        super.render($where);
        this.$elem.click(this.onClick.bind(this));
    }
    onClick(evt) {
        console.log("Button '" + this.label + "' clicked!");
    }
}
$(function () {
    let $body = $(document.body);
    let btn1 = new Button(125, 30, "Hello");
    let btn2 = new Button(150, 40, "World");
    btn1.render($body);
    btn2.render($body);
});
Цитата Сообщение от DiscoN Посмотреть сообщение
А как поставить обработчик методом JS?
Затем перепишем скрипт без использования jQuery:
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
class Widget {
    constructor(width, height) {
        this.width = width || 50;
        this.height = height || 50;
        this.elem = null;
    }
    render(where) {
        if (this.elem) {
            this.elem.style.width = this.width + "px";
            this.elem.style.height = this.height + "px";
            where.appendChild(this.elem);
        }
    }
}
// дочерний класс
class Button extends Widget {
    constructor(width, height, label) {
        // "super" constructor call
        super(width, height);
        this.label = label || "Default";
        this.elem = document.createElement("Button");
        this.elem.textContent = this.label;
    }
    // переопределить базовую "унаследованную" версию `render(..)`
    render(where) {
        // вызов "super"
        super.render(where);
        this.elem.onclick = this.onClick.bind(this);
    }
    onClick(evt) {
        console.log("Button '" + this.label + "' clicked!");
    }
}
document.addEventListener("DOMContentLoaded", function () {
    let body = document.body;
    let btn1 = new Button(125, 30, "Hello");
    let btn2 = new Button(150, 40, "World");
    btn1.render(body);
    btn2.render(body);
});
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
02.06.2020, 14:21
Помогаю со студенческими работами здесь

JS + cookies. Отслеживание события click
Здравствуйте. Подскажите, как правильно проверить, был ли клик? Есть ли что-то, похожее на .click == true? Запись в кукис ...

Click add remove class
&lt;nav class=&quot;header__nav&quot;&gt; &lt;ul class=&quot;nav__list&quot;&gt; &lt;li&gt;&lt;a href=&quot;#&quot; class=&quot;nav__link&quot;&gt;&lt;img...

Не работает click вместе с touch
Я добавляю html-элементу события touch, а его ребёнку click. Но ребёнок не реагирует на нажатия. Почему?

JS, HTML. Имитация пользовательского события click
Есть блок пагинации HTML. Нужно раз в 12 секунд имитировать нажатие кнопки &quot;следующие&quot; скриптом JS. &lt;div...

если .click один - одна функция, .click еще раз и другая
как сделать чтоб она проверило .click первый и если он выполнен, то уже при втором клике, выполнялась другая функция Добавлено через...


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод. Thinkpad X220 Tablet —. . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru