Javascript.RU

Способы добавления обработчиков в сравнении

Update: Более новый материал по этой теме находится по адресу https://learn.javascript.ru/introduction-browser-events.

В статье приводится сравнение способов добавления обработчиков через on(click), addEventListener и attachEvent.

Рассмотрены особенности, плюсы и минусы разных способов.

Считается, что вы знакомы с основными свойствами объекта события и порядком их обработки.

Самый универсальный метод. У него есть, пожалуй, только один существенный недостаток: можно повесить лишь один обработчик.

Кроме того, есть глюк с iframe: в Firefox не будет работать обработчик, назначенный так:

iframeElement.onclick = function(event) { .... }

Но будет прекрасно работать addEventListener:

iframeElement.addEventListener( "click", ... )
  1. Полная кросс-браузерность
  2. Только один обработчик на событие
  3. Глюк с iframe в браузерах от Mozilla

Методы attachEvent/addEventListener имеют ряд общих недостатков.

Во-первых, ни W3C ни Microsoft не определяют порядок срабатывания обработчиков. Несколько обработчиков одного события на элементе могут сработать в любом порядке.

На текущий момент (март 2010) addEventListener сохраняет порядок назначения обработчиков, а attachEvent в IE - нет.

elem.attachEvent("onclick", handler);
elem.attachEvent("onclick", handler2);
// может быть так, что handler2 сработает раньше handler. 
// так, судя по демке ниже, ведет себя IE.
// а может быть, handler сработает раньше handler2.
// так в демо ниже ведет себя Opera
// ... вообще, порядок неопределен

На одну и ту же кнопку вешаются пять обработчиков onclick: первый выдает "1", второй выдает "2" и т.п.

Есть еще одна проблема, с которой можно столкнуться при управлении событиями: нельзя точно сказать установлен ли определённый обработчик, или нет, и какие обработчики установлены на данный момент.

В спецификации DOM 3 существует объект eventListenerList, но он слишком новый и на данный момент не поддерживается ни одним из браузеров.

Обработчик ставится как:

element.attachEvent( "on"+имя_события, обработчик)

Основной недостаток attachEvent заключается в том, что функция-обработчик не получает текущий элемент, на котором сработало событие, ни в каком виде.

Значение this указывает на window, а свойство event.currentTarget отсутствует.

И это достаточно важная особенность!

Например, пусть мы хотим подсвечивать divElem при клике.

Элемент divElem с разным текстом и различными ссылками, и даже с жирным текстом внутри тага <b>

Конечно, же мы повесим обработчик на divElem:

divElem.attachEvent("onclick", handler)

Но при клике из объекта события event в IE можно получить только srcElement, то есть самый глубокий кликнутый элемент. Он может быть ссылкой <a> или элементом <b>, но нам-то нужны не они, а сам divElem, чтобы его подсветить.

Обработчик, добавленный при помощи attachEvent никак не может выяснить объект, на который подвешен.

Впрочем, это легко обойти при помощи небольшого замыкания, корректно передающего указатель this:

divElem.attachEvent("onclick", function() { handler.call(divElem) })

Но этот код порождает утечку памяти в Internet Explorer 6, на который не установлено исправляющее обновление, вышедшее в июне 2007 года, из-за круговой ссылки DOM <-> JS.

  • Можно повесить несколько обработчиков на одно событие
  • Не передается текущий элемент.
  • Поддерживается только IE/Opera.

Решение W3C работает во всех современных браузерах, кроме Internet Explorer.

Установка обработчика:

element.addEventListener( имя_события, обработчик, фаза)

Пожалуй, особенных недостатков, кроме общих с attachEvent, у этого способа нет.

  • Можно повесить несколько обработчиков на одно событие
  • Умеет вешать обработчики на фазу погружения события
  • Стандарт W3C
  • Не поддерживается IE.

В следующей статье разобран способ, позволяющий добавлять обработчики кроссбраузерно и свободный от описанных недостатков.


Автор: airfly (не зарегистрирован), дата: 1 мая, 2010 - 18:19
#permalink

Вот я только одного не могу понять:
какой толк в attachEvent и addEventListener, если все всеравно все они выполняются по одному событию? Ну напишу я 10 раз attachEvent, перечислив 10 разных функций. И что? Где это пригодится на практике? Проще объявить onclick, адрес функции и в ней уже перечислить список тех 10 функций. Разве так не проще?
На практике одно и тоже. Я не вижу ВООБЩЕ никаких плючов у attachEvent, за исключением примера с iframe


Автор: Гость (не зарегистрирован), дата: 3 мая, 2010 - 01:26
#permalink

Скачал ты чей-то скрипт, а он ставит обработчик через elem.on(событие). И убил все твои обработчики на это событие.


Автор: Castigo (не зарегистрирован), дата: 8 июня, 2010 - 12:09
#permalink

разовый обработчик не всегда есть возможность написать. Ибо элемент может не существовать, а появляться в результете каких-либо действий пользователя. Тут и поможет создание такого обработчика.


Автор: Гость (не зарегистрирован), дата: 10 июля, 2014 - 15:32
#permalink

И в правду, зачем вешать onclick'и через addEventListener и attachEvent, эсли
можно сделать проще:

function alertgroup()
{
alert('1');
alert('2');
alert('3');
alert('4');
alert('5');
}
//или свой список функций

И тем более, attachEvent нестабильно работает в Опере и IE.


Автор: slovenlythole (не зарегистрирован), дата: 15 ноября, 2022 - 12:17
#permalink

If I push the button once, can I submit the form twice? happy wheels


Автор: THERE (не зарегистрирован), дата: 3 июня, 2010 - 09:13
#permalink

Демо: порядок срабатывания

На одну и ту же кнопку вешаются пять обработчиков onclick: первый выдает "1", второй выдает "2" и т.п.

у меня по кнопке addEventListener выдаются алерты с 1 по 7 на FF.
это чей-то глюк или опечатка?


Автор: Гость (не зарегистрирован), дата: 13 июня, 2010 - 12:42
#permalink

Видимо это можно отнести к недостутку этого способа - когда алертишь 5 раз он алертится 7 раз :-))))

ps: если открыть исходник страницы, то можно увидить

var b = document.getElementById('2ff')
if (b.addEventListener) {
b.addEventListener('click', function() { alert(1) }, false)
b.addEventListener('click', function() { alert(2) }, false)
b.addEventListener('click', function() { alert(3) }, false)
b.addEventListener('click', function() { alert(4) }, false)
b.addEventListener('click', function() { alert(5) }, false)
b.addEventListener('click', function() { alert(6) }, false)
b.addEventListener('click', function() { alert(7) }, false)
}

Автор: Гость (не зарегистрирован), дата: 5 сентября, 2010 - 11:05
#permalink

Исходники страниц браузер делает сам, поэтому не верь ему.
Если на сайте при входе будет работать сценарий, который выводит "Привет (Ваш ник(Допустим proVIDec))!", то при просмотре исходного кода браузер даст не php скрипт, а текст "Превет proVIDec".


Автор: B@rmaley.e><e, дата: 5 сентября, 2010 - 12:50
#permalink

Браузер ничего с исходниками страниц не делает. Он рендерит то, что отдаст сервер.

А обработкой php скриптов (как и любых других server-side'овых) как раз занимается сервер.


Автор: Гость (не зарегистрирован), дата: 9 января, 2011 - 01:02
#permalink

Впрочем, это легко обойти при помощи небольшого замыкания, корректно передающего указатель this:

divElem.attachEvent("onclick", function() { handler.call(divElem) })

А вот так

divElem.attachEvent("onclick", handler.call(divElem) )

передать получится?


Автор: Гость (не зарегистрирован), дата: 24 января, 2011 - 12:53
#permalink

Третий параметр в addEventListener совсем не понятен Sad Что за "фаза погружения"?


Автор: Гость (не зарегистрирован), дата: 26 января, 2011 - 16:37
#permalink

Этот параметр объяснялся в главе введение в события:

Установка по стандарту W3C
Решение W3C работает во всех современных браузерах, кроме Internet Explorer.
Установка обработчика:element.addEventListener( имя_события, обработчик, фаза)
Удаление обработчика:element.removeEventListener( имя_события, обработчик, фаза)

Еще одно отличие от решения Microsoft это третий параметр – фаза.
Если он установлен в true, то при срабатывании события во вложенном элементе, обработчик будет вызван на фазе "перехвата", а если значение будет false, то - на фазе "всплывания". Подробнее об этом будет написано далее, в разделе этой статьи "Порядок срабатывания событий".


Автор: demoniqus, дата: 16 мая, 2012 - 18:17
#permalink

Немного дополню данный пост. Зачастую в функцию требуется передать некоторые параметры. Как вариант, можно расплодить глобальные переменные или создать один глобальный массив, из которого и вытягивать нужные значения. А можно решить данный вопрос и другим способом. Приведу свою функцию:

function select_country(country_id, step) {
    request = 'some request';
    rslt = GenerateXMLHttpRequest(request, 'php/some_file.php');
    rslt = rslt.match(/([^;]+);([^\|]+)\|(.+)/);
/*
Нулевой элемент - тип возвращенного ответа
Первый элемент - текст надписи
Второй - элементы списка (options'ы)
*/
    document.getElementById('div_region').innerHTML = document.getElementById('div_city').innerHTML = '';    
    if (rslt[1] == 'regions') {
        
        rsl = "<select id='region'>" + rslt[3] + "</select>";        
        document.getElementById('div_region').innerHTML = rsl;
        select_city = '';
        select_region = '';
 
        eval("select_city = function () {step = " + step +
                ";if (document.getElementById(\"city\").value != \"\") {" +
                    "document.getElementById(\"city\").setAttribute(\"correct\", 1);" +
                "} " +
                "else {" +
                    "document.getElementById(\"city\").setAttribute(\"correct\", 0);" +
                "}" +
                "is_fields_correct(" + step + ")" +
            "}")
        
        eval('select_region = function () {step = ' + step + 
            ';if (document.getElementById("region").value != "") {' +
                'document.getElementById("region").setAttribute("correct", 1);' +
            '} ' +
            'else {' +
                'document.getElementById("region").setAttribute("correct", 0);' +
            '}' +
            'is_fieldsvalue_correct(' + step + ');' +
            'request = "lang=" + LANG + "&doit=is_select_region&id_country=" ' +
                '+ document.getElementById("country").value + "&id_region=" + ' +
                'document.getElementById("region").value;' +
            'rslt = GenerateXMLHttpRequest(request, "php/doit.php");' +
            'rslt = rslt.match(/([^;]+);([^\\|]+)\\|(.+)/);' +
            'document.getElementById("div_city").innerHTML = "";' +
            'if (rslt[1] == "cities") {' +
                'rsl = "<div id=\'caption_select_city\'>" + rslt[2] + "</div>";' +
                'rsl += "<select id=\'city\'>" + rslt[3] + "</select>";' +
                'document.getElementById("div_city").innerHTML = rsl;' +
                
                
                
                'if (document.getElementById("city").addEventListener) {' +
                    'document.getElementById("city").addEventListener("change", ' + select_city + ', false);' +
                '}' +
                'else if (document.getElementById("city").attachEvent) {' +
                    'document.getElementById("city").attachEvent("onChange", ' + select_city + ');' +
                '}' +
            '}' +
        '}')
        


        
        if (document.getElementById('region').addEventListener) {
            document.getElementById('region').addEventListener('change', select_region, false);
        }
        else if (document.getElementById('region').attachEvent) {
            document.getElementById('region').attachEvent('onChange', select_region);
        }
    }
    if (rslt[1] == 'cities') {
        rsl = "<div id='caption_select_city'>" + rslt[2] + "</div>";
        rsl += "<select id='city'>" + rslt[3] + "</select>";
        document.getElementById('div_city').innerHTML = rsl;
    }
    
    
}

В данной функции генерится код двух других функций с подстановкой значений необходимых параметров в текстовом виде, после чего он прогоняется через eval - в результате мы имеем две функции select_region и select_city со всеми параметрами, которые им требовалось передать.


Автор: Гость (не зарегистрирован), дата: 23 мая, 2012 - 18:25
#permalink

Плохое решение. Лучше сделать это с использованием замыкания.


Автор: Гость (не зарегистрирован), дата: 6 марта, 2013 - 17:46
#permalink

Придётся делать свой луна-парк.. Всем одна функция, в функции лист обработчиков. В принципе если сесть и подумать то легко, только как не дать убить никогда свой универсальный on<событие>?


Автор: Vladimir M (не зарегистрирован), дата: 16 марта, 2013 - 18:59
#permalink
Впрочем, это легко обойти при помощи небольшого замыкания, корректно передающего указатель this:
divElem.attachEvent("onclick", function() { handler.call(divElem) })

Вот только не всегда знаешь, какой это "divElem". А если есть список элементов, на который надо циклом назначить один обработчик, то здесь ваше решение не поможет.


Автор: koeshiro, дата: 14 июля, 2013 - 08:43
#permalink

Где можно найти имена всех событий?


Автор: Hank (не зарегистрирован), дата: 16 июня, 2020 - 21:58
#permalink

i am not sure...fencing pensacola fl


Автор: Гость (не зарегистрирован), дата: 25 марта, 2014 - 12:30
#permalink

Узнал про Greasemonkey. Тренируюсь. Почему-то нижеследующий скрипт работает практически всюду, кроме "e.mail.ru", подскажите почему?

window.addEventListener('load',function(e){
alert('alert [10-33-12]');
},true);


Автор: iamxaoc (не зарегистрирован), дата: 29 декабря, 2014 - 10:25
#permalink

"Особенности addEventListener

Решение W3C работает во всех современных браузерах, кроме Internet Explorer."

Работает в IE 9 >

Только что проверил в IE 11 - все ок


Автор: Мизар (не зарегистрирован), дата: 10 июля, 2015 - 16:19
#permalink

Подскажите пожалуста кто нибуть!
Имеем опредиленый код формы:

<div id="content">
<form action="game.php" onsubmit="return CheckTarget()" method="post">
<input type="hidden" name="token" value="miska">
   	<table class="table519">
		<tr class="left top">
			<td style="width:50%;margin:0;padding:0;">
        		<table border="0" cellpadding="0" cellspacing="0" width="259" style="margin:0;padding:0;">
					<tr style="height:20px;">
						<td class="transparent left">
						<input id="radio_8" type="radio" name="mission" value="8"  style="width:60px;">
						<label for="radio_8">Перемешать</label>
						</td>
					</tr>
				</table>
        	</td>
        	<td class="top">
				<table border="0" cellpadding="0" cellspacing="0" width="259">
                    <tr style="height:20px;">
        				<td class="transparent">Капуста</td>
        				<td class="transparent"><a href="javascript:maxResource('metal');">все</a></th>
        				<td class="transparent"><input name="metal" size="10" onchange="calculateCapacity();" type="text"></td>
        			</tr>
                    <tr style="height:20px;">
        				<td class="transparent">Моркофь</td>
        				<td class="transparent"><a href="javascript:maxResource('crystal');">все</a></th>
        				<td class="transparent"><input name="crystal" size="10" onchange="calculateCapacity();" type="text"></td>
        			</tr>
                    <tr style="height:20px;">
        				<td class="transparent">Огурец</td>
        				<td class="transparent"><a href="javascript:maxResource('deuterium');">все</a></td>
        				<td class="transparent"><input name="deuterium" size="10" onchange="calculateCapacity();" type="text"></td>
        			</tr>
				</table>
			</td>
		</tr>
		        <tr style="height:20px;">
        	<td colspan="2"><input class="submit" value="Дальше" type="submit"></input></td>
        </tr>
    </table>
</form>
<script type="text/javascript">
data	= {"fleetroom":"5460000000","consumption":"4"};
</script>
</div>

Как правильно добавить обработчик (и вожможно ли такое) так чтоб при нажатии кнопки "Дальше" На сервер отправлялась информация не раз, а три раза с интервалом в одну секунду (с задержкой)!


Автор: Мизар (не зарегистрирован), дата: 10 июля, 2015 - 16:30
#permalink

Или скажу по проще:
Можна продублировать как-то отправку формы, от нажатия только одногораза на кнопку!?


Автор: Разработчик (не зарегистрирован), дата: 12 июня, 2018 - 21:23
#permalink

Вот это то, что надо!


Автор: matthewgrace (не зарегистрирован), дата: 7 октября, 2020 - 11:57
#permalink

Большой! Объясните подробно и по существу, могу я поделиться вашей статьей? Многим будет полезно прочитать эту вашу статью. cookie clicker


Автор: Гость (не зарегистрирован), дата: 22 декабря, 2020 - 20:58
#permalink

Stan Smith’s are like the Air Jordans of Adidas. They look so iconic to look at. When you look at them out in public, you would instantly recognize that it was a Stan Smith shoe. That kind of recognition is very rare to find these days. Nothing ever really stands out, as everyone just copies everyone else just to ride a fad or a trend so that they can make a quick buck. Unlike the old days where people would compete who would wow the crowd more and who would grab the attention of the consumers. Back then, it was like roblox on pc where you would be transported to different worlds fashion. And every among us pc was valued for what it truly was.


Автор: minion89 (не зарегистрирован), дата: 19 января, 2022 - 12:53
#permalink

Thanks for sharing this information. I am facing the same problem and I am very happy to be here! Glad you shared this topic for everyone to discuss.
coloring pages


Автор: ZaneHelen (не зарегистрирован), дата: 14 июня, 2022 - 12:11
#permalink

Why am I just now reading your latest post? Obviously, I selected the option to follow you. However, you do not use as many components in this article as you have in earlier articles. If you're feeling stressed, try playing basketball stars It's a game I like to play to unwind, and I hope it may help you as well.


Автор: mytom2, дата: 12 июля, 2022 - 18:08
#permalink

wordle is a word cloud generator that lets you create a word cloud from any text. The tool has been around for years and has been used by thousands of people.

Wordle is a great tool for brainstorming or just to get your creative juices flowing. It's also great for presentations, as it provides an easy way to show off your knowledge or to share information with your audience in an engaging way.

You should also join fnaf world, the best horror game out there!


Автор: dilloutrageous (не зарегистрирован), дата: 6 октября, 2022 - 06:48
#permalink

I am grateful basket random for the information and the suggestions that you have provided. I will make an effort to understand it better for more.


Автор: Muraos (не зарегистрирован), дата: 7 октября, 2022 - 06:39
#permalink

Many internet games are amusing. I often play stumble guys, a knockout game to test boys' brains.


Автор: Danny Norman (не зарегистрирован), дата: 10 октября, 2022 - 11:12
#permalink

Возможно ли (и как правильно добавить обработчик), чтобы данные передавались на сервер не один раз, а три раза с задержкой в одну секунду между каждой отправкой mario games?


Автор: kemmer (не зарегистрирован), дата: 11 октября, 2022 - 10:26
#permalink

In any case, I appreciate your contribution. The way you wrote about the issue piqued my curiosity. Quite a few other individuals, I'm sure, share my enthusiasm for them. I was wondering how long it would take to write this piece. I've tried reading some other blogs, but I found them too difficult to follow. I really appreciate you providing such informative content for free. geometry dash


Автор: nukamsa (не зарегистрирован), дата: 11 ноября, 2022 - 11:58
#permalink

This is so amazing, great minds think alike I just wrote a similar post on this topic! You should check it out. basketball legends


Автор: tomusa, дата: 14 ноября, 2022 - 11:57
#permalink

It's great that I read your post, the information you share is new and very useful to me. wordle


Автор: Jessy Mark (не зарегистрирован), дата: 28 ноября, 2022 - 12:03
#permalink

I like your article, it helps me understand more things I don't know apk mod.


Автор: fouad whatsapp download (не зарегистрирован), дата: 21 декабря, 2022 - 06:15
#permalink

Thank you for sharing this amazing Blog fouad whatsapp download


Автор: shadow fight pc (не зарегистрирован), дата: 26 декабря, 2022 - 20:35
#permalink

you can explore the new and unique things on the shadow fight arena pc


Автор: gggg (не зарегистрирован), дата: 26 декабря, 2022 - 20:37
#permalink

and also check the basketball hoop for driveway


Автор: Гость (не зарегистрирован), дата: 31 января, 2023 - 06:10
#permalink

I'm glad I read your article since the knowledge you provide is fresh and helpful to me. 1v1 lol


Автор: abel1303 (не зарегистрирован), дата: 9 марта, 2023 - 05:40
#permalink

The way you framed the drift hunters topic was unique and made me see it in a new light.


Автор: Гость (не зарегистрирован), дата: 29 марта, 2023 - 11:37
#permalink

Although I am not knowledgeable heardle game about this topic, but through your article I have gained some useful information for myself. It is very effective for my work.


Автор: lunadam (не зарегистрирован), дата: 20 апреля, 2023 - 07:47
#permalink

Your article is really squidward awesome. Thank you for bringing such a useful article to everyone


Автор: Гость (не зарегистрирован), дата: 3 мая, 2023 - 21:56
#permalink

Si tu cherches un plan cul regarde par ici !


Автор: Don Holloway (не зарегистрирован), дата: 9 мая, 2023 - 05:53
#permalink

this is an informative post and it is very beneficial and knowledgeable. free games


Автор: Гость (не зарегистрирован), дата: 10 мая, 2023 - 23:52
#permalink

Pour trouver votre adresse IP, vous pouvez suivre ces étapes :

Sur un ordinateur Windows :

Ouvrez le menu Démarrer.
Recherchez et ouvrez l'application "Invite de commandes" ou "cmd".
Dans la fenêtre de l'invite de commandes, tapez "ipconfig" puis appuyez sur Entrée.
Vous verrez une liste d'informations réseau. Recherchez la ligne qui indique "Adresse IPv4" ou "IPv4 Address". À côté de cette ligne, vous trouverez votre adresse IP.
Sur un ordinateur Mac :

Cliquez sur l'icône Apple dans le coin supérieur gauche de l'écran.
Sélectionnez "Préférences Système".
Choisissez "Réseau".
Dans la colonne de gauche, sélectionnez votre connexion réseau active (Wi-Fi ou Ethernet).
Vous verrez votre adresse IP affichée à droite, à côté de "Adresse IP".
Sur un smartphone ou une tablette (iOS ou Android) :

Ouvrez les paramètres de votre appareil.
Recherchez l'option "Wi-Fi" ou "Réseau" et appuyez dessus.
Trouvez le réseau Wi-Fi auquel vous êtes connecté et appuyez sur le "i" ou l'icône d'information à côté de ce réseau.
Vous verrez votre adresse IP répertoriée sous "Adresse IP" ou "IP Address".
Gardez à l'esprit que votre adresse IP peut changer en fonction de votre connexion et du réseau auquel vous êtes connecté.


Автор: damdam (не зарегистрирован), дата: 17 мая, 2023 - 05:11
#permalink

Please accept my heartfelt thanks for the author's meticulous fnaf attention to detail, ensuring the accuracy and reliability of the information presented, and establishing this article as a trustworthy source for knowledge and understanding.


Автор: 메이저놀이터 (не зарегистрирован), дата: 19 мая, 2023 - 08:51
#permalink

Your blog gives me a lot of particularly good inspiration. I think more and more people will see your blog because you write really well. I hope your blog will be seen and liked by more people.https://totowho.com


Автор: 메이저사이트 (не зарегистрирован), дата: 19 мая, 2023 - 08:51
#permalink

It's really a very literary post.I feel your happiness and positive attitude towards life from your blog. What I want to tell you is that I learned a lot from your excellent writing skills. I will study harder like you.I want to write my opinion based on your writing.https://totowho.com


Автор: 토토사이트추천 (не зарегистрирован), дата: 19 мая, 2023 - 08:52
#permalink

You're really a good hand, you write clear thinking, deep feelings, more people will feel your sincerity because you're good enough, your posts are sharing seriously, that's why you're successful, you're convincing, hope you keep your enthusiasm, I'll learn everything you say.https://totowho.com


Автор: Гость (не зарегистрирован), дата: 5 июня, 2023 - 04:58
#permalink

Thank you very much for this article. This information is really helpful to me tunnel rush


Автор: Гость (не зарегистрирован), дата: 14 июня, 2023 - 06:09
#permalink

Can I share it? geometry dash


Автор: Адреса (не зарегистрирован), дата: 18 июля, 2023 - 15:37
#permalink

Great contribution! Also for the Snus bestellen a javascript is used as far as I know.


Автор: 토토사이트 (не зарегистрирован), дата: 19 июля, 2023 - 09:37
#permalink

There's no doubt about it It's fantastic All these smaller facts are made using digital and credential techniques I actually like the best value of reasoning.토토사이트


Автор: swimresolve (не зарегистрирован), дата: 19 июля, 2023 - 14:04
#permalink

I get a lot of great ideas from your blog. Because of how wonderfully you write, I predict that more and more people will visit your blog. I really hope more people read and enjoy your blog. coreball


Автор: cassian andor jacket (не зарегистрирован), дата: 22 июля, 2023 - 17:12
#permalink

Great blog! Can you explain me more?


Автор: Гость (не зарегистрирован), дата: 28 июля, 2023 - 13:43
#permalink

Thank you very much for the useful information that the blogs have shared Pizza Tower.


Автор: bulkyanticipate (не зарегистрирован), дата: 10 августа, 2023 - 10:46
#permalink

this is an informative post and it is very beneficial and knowledgeable. gorilla tag


Автор: mikasa23 (не зарегистрирован), дата: 29 августа, 2023 - 07:30
#permalink

I feel it is well worth spending a few fnf minutes reading the useful information you provide. I appreciate it.


Автор: Гость (не зарегистрирован), дата: 31 августа, 2023 - 12:36
#permalink

I can't thank the author heardle 60s enough for bringing this crucial topic to the forefront of our minds. Exceptional work!


Автор: Гость (не зарегистрирован), дата: 7 сентября, 2023 - 06:33
#permalink

Thank you for producing such a fascinating essay on this subject pizza tower. This has sparked a lot of thought in me, and I'm looking forward to reading more.


Автор: Гость (не зарегистрирован), дата: 13 сентября, 2023 - 07:10
#permalink

Dinosaur games have become a bonding activity for our family. We play together and have a blast.


Автор: 먹튀검증 (не зарегистрирован), дата: 24 сентября, 2023 - 09:39
#permalink

This article provides us with the light to observe reality. We really appreciate your blog post. After visiting your post you will find many ways.먹튀검증


Автор: sofiacarson (не зарегистрирован), дата: 10 ноября, 2023 - 06:58
#permalink

This is the special method applied for tap tap shots


Отправить комментарий

Приветствуются комментарии:
  • Полезные.
  • Дополняющие прочитанное.
  • Вопросы по прочитанному. Именно по прочитанному, чтобы ответ на него помог другим разобраться в предмете статьи. Другие вопросы могут быть удалены.
    Для остальных вопросов и обсуждений есть форум.
P.S. Лучшее "спасибо" - не комментарий, как все здорово, а рекомендация или ссылка на статью.
Содержание этого поля является приватным и не предназначено к показу.
  • Адреса страниц и электронной почты автоматически преобразуются в ссылки.
  • Разрешены HTML-таги: <strike> <a> <em> <strong> <cite> <code> <ul> <ol> <li> <dl> <dt> <dd> <u> <i> <b> <pre> <img> <abbr> <blockquote> <h1> <h2> <h3> <h4> <h5> <p> <div> <span> <sub> <sup>
  • Строки и параграфы переносятся автоматически.
  • Текстовые смайлы будут заменены на графические.

Подробнее о форматировании

CAPTCHA
Антиспам
7 + 8 =
Введите результат. Например, для 1+3, введите 4.
 
Текущий раздел
Поиск по сайту
Содержание

Учебник javascript

Основные элементы языка

Сундучок с инструментами

Интерфейсы

Все об AJAX

Оптимизация

Разное

Дерево всех статей

Последние комментарии
Последние темы на форуме
Forum