Π§ΠΈΡ‚Π°ΠΉΡ‚Π΅ ΠΊΠ½ΠΈΠ³ΠΈ ΠΎΠ½Π»Π°ΠΉΠ½ Π½Π° Bookidrom.ru! БСсплатныС ΠΊΠ½ΠΈΠ³ΠΈ Π² ΠΎΠ΄Π½ΠΎΠΌ ΠΊΠ»ΠΈΠΊΠ΅

Π§ΠΈΡ‚Π°Ρ‚ΡŒ ΠΎΠ½Π»Π°ΠΉΠ½ Β«HTML 5, CSS 3 ΠΈ Web 2.0. Π Π°Π·Ρ€Π°Π±ΠΎΡ‚ΠΊΠ° соврСмСнных Web-сайтов». Π‘Ρ‚Ρ€Π°Π½ΠΈΡ†Π° 66

Автор Π’Π»Π°Π΄ΠΈΠΌΠΈΡ€ Π”Ρ€ΠΎΠ½ΠΎΠ²

ΠŸΠ΅Ρ€Π²ΡƒΡŽ Π·Π°Π΄Π°Ρ‡Ρƒ β€” ΡΠΎΠΎΡ‚Π½ΠΎΡˆΠ΅Π½ΠΈΠ΅ ΠΏΡƒΠ½ΠΊΡ‚Π° полосы Π½Π°Π²ΠΈΠ³Π°Ρ†ΠΈΠΈ со списком связанных ΠΌΠ°Ρ‚Π΅Ρ€ΠΈΠ°Π»ΠΎΠ² β€” ΠΌΡ‹ Ρ€Π΅ΡˆΠΈΠ»ΠΈ.

НайдСм объявлСниС Ρ„ΡƒΠ½ΠΊΡ†ΠΈΠΈ prepareSamples, которая ΠΏΠΎΠ΄Π³ΠΎΡ‚Π°Π²Π»ΠΈΠ²Π°Π΅Ρ‚ тСкст ΠΏΡ€ΠΈΠΌΠ΅Ρ€ΠΎΠ² ΠΈ, Ρ‡Ρ‚ΠΎ Π²Π°ΠΆΠ½ΠΎ для нас, выполняСтся послС Π·Π°Π³Ρ€ΡƒΠ·ΠΊΠΈ Ρ„Ρ€Π°Π³ΠΌΠ΅Π½Ρ‚Π° содСрТимого. Π”ΠΎΠ±Π°Π²ΠΈΠΌ Π² ΠΊΠΎΠ½Π΅Ρ† Ρ‚Π΅Π»Π° Ρ„ΡƒΠ½ΠΊΡ†ΠΈΠΈ, ΠΏΠ΅Ρ€Π΅Π΄Π°Π²Π°Π΅ΠΌΠΎΠΉ Π² качСствС ΠΏΠ°Ρ€Π°ΠΌΠ΅Ρ‚Ρ€Π° ΠΌΠ΅Ρ‚ΠΎΠ΄Ρƒ each, Ρ‚Π°ΠΊΠΎΠ΅ Π²Ρ‹Ρ€Π°ΠΆΠ΅Π½ΠΈΠ΅:

generateRelated();

Π­Ρ‚ΠΎ Π²Ρ‹Π·ΠΎΠ² Ρ„ΡƒΠ½ΠΊΡ†ΠΈΠΈ generateRelated, которая ΠΈ создаст Ρ€Π°Π·Π΄Π΅Π» "Π‘ΠΌ. Ρ‚Π°ΠΊΠΆΠ΅" ΠΈ ΠΊΠΎΡ‚ΠΎΡ€ΡƒΡŽ ΠΌΡ‹ сСйчас объявим.

НС Π±ΡƒΠ΄Π΅ΠΌ ΠΎΡ‚ΠΊΠ»Π°Π΄Ρ‹Π²Π°Ρ‚ΡŒ Π΄Π΅Π»ΠΎ Π² Π΄ΠΎΠ»Π³ΠΈΠΉ ящик. Листинг 19.2 содСрТит объявлСниС Ρ„ΡƒΠ½ΠΊΡ†ΠΈΠΈ generateRelated.

Листинг 19.2

function generateRelated() {

var s = "";

var oRelated = elLastItem.dom.related;

if (oRelated) {

for (var i = 0; i < oRelated.length; i++) {

if (s!= "")

s += ", ";

s += "<CODE><A HREF=\"" + oRelated[i].url + "\">" +

oRelated[i].name + "</A></CODE>";

}

var htelRelated = Ext.get("cmain"). insertHtml("beforeEnd", "<P>Π‘ΠΌ. Ρ‚Π°ΠΊΠΆΠ΅: " + s + "</P>"); Ext.fly(htelRelated). select("A"). on("click", function(e, t) {

var href = Ext.fly(this). getAttribute("href");

var elA = Ext.get("navbar"). child("A[href=" + href + "]");

var elItem = elA.parent("LI");

loadFragment(elItem, e);

});

}

Рассмотрим ΠΏΡ€ΠΈΠ²Π΅Π΄Π΅Π½Π½Ρ‹ΠΉ ΠΊΠΎΠ΄ построчно.

ОбъявляСм ΠΏΠ΅Ρ€Π΅ΠΌΠ΅Π½Π½ΡƒΡŽ s, Π² ΠΊΠΎΡ‚ΠΎΡ€ΠΎΠΉ Π±ΡƒΠ΄Π΅Ρ‚ Ρ…Ρ€Π°Π½ΠΈΡ‚ΡŒΡΡ HTML-ΠΊΠΎΠ΄, Ρ„ΠΎΡ€ΠΌΠΈΡ€ΡƒΡŽΡ‰ΠΈΠΉ Ρ€Π°Π·Π΄Π΅Π» "Π‘ΠΌ. Ρ‚Π°ΠΊΠΆΠ΅" Π² Π²ΠΈΠ΄Π΅ строки:

var s = "";

ΠŸΠ΅Ρ€Π²ΠΎΠ΅, Ρ‡Ρ‚ΠΎ Π½Π°ΠΌ Π½ΡƒΠΆΠ½ΠΎ, β€” ΠΏΠΎΠ»ΡƒΡ‡ΠΈΡ‚ΡŒ список ΠΌΠ°Ρ‚Π΅Ρ€ΠΈΠ°Π»ΠΎΠ², связанных с Π·Π°Π³Ρ€ΡƒΠΆΠ΅Π½Π½ΠΎΠΉ Π² Π΄Π°Π½Π½Ρ‹ΠΉ ΠΌΠΎΠΌΠ΅Π½Ρ‚ Web-страницСй (Ρ‚ΠΎΡ‡Π½Π΅Π΅, Ρ„Ρ€Π°Π³ΠΌΠ΅Π½Ρ‚ΠΎΠΌ содСрТимого). Как Π΅Π³ΠΎ ΠΏΠΎΠ»ΡƒΡ‡ΠΈΡ‚ΡŒ? Вспомним, Ρ‡Ρ‚ΠΎ Π΅Ρ‰Π΅ Π² Π³Π»Π°Π²Π΅ 17 ΠΌΡ‹ объявили ΠΏΠ΅Ρ€Π΅ΠΌΠ΅Π½Π½ΡƒΡŽ elLastItem. Она Ρ…Ρ€Π°Π½ΠΈΡ‚ ΠΏΡƒΠ½ΠΊΡ‚ полосы Π½Π°Π²ΠΈΠ³Π°Ρ†ΠΈΠΈ, Π½Π° ΠΊΠΎΡ‚ΠΎΡ€ΠΎΠΌ ΠΏΠΎΡΠ΅Ρ‚ΠΈΡ‚Π΅Π»ΡŒ Ρ‰Π΅Π»ΠΊΠ½ΡƒΠ» ΠΌΡ‹ΡˆΡŒΡŽ ΠΈ ΠΊΠΎΡ‚ΠΎΡ€Ρ‹ΠΉ ΠΊΠ°ΠΊ Ρ€Π°Π· ΠΈ соотвСтствуСт Π·Π°Π³Ρ€ΡƒΠΆΠ΅Π½Π½ΠΎΠΌΡƒ Π² Π΄Π°Π½Π½Ρ‹ΠΉ ΠΌΠΎΠΌΠ΅Π½Ρ‚ Ρ„Ρ€Π°Π³ΠΌΠ΅Π½Ρ‚Ρƒ содСрТимого. Π’ΠΎΡ‚ ΠΈ Ρ€Π΅ΡˆΠ΅Π½ΠΈΠ΅:

var oRelated = elLastItem.dom.related;

Π—Π½Π°Ρ‡Π΅Π½ΠΈΠ΅ ΠΏΠ΅Ρ€Π΅ΠΌΠ΅Π½Π½ΠΎΠΉ elLastItem β€” это экзСмпляр ΠΎΠ±ΡŠΠ΅ΠΊΡ‚Π° Element. Π‘ΠΎΠΎΡ‚Π²Π΅Ρ‚ΡΡ‚Π²ΡƒΡŽΡ‰ΠΈΠΉ Π΅ΠΌΡƒ экзСмпляр ΠΎΠ±ΡŠΠ΅ΠΊΡ‚Π° HTMLElement ΠΌΡ‹ ΠΌΠΎΠΆΠ΅ΠΌ ΠΏΠΎΠ»ΡƒΡ‡ΠΈΡ‚ΡŒ Ρ‡Π΅Ρ€Π΅Π· свойство dom. А ΠΏΠΎΠ»ΡƒΡ‡Π΅Π½Π½Ρ‹ΠΉ экзСмпляр ΠΎΠ±ΡŠΠ΅ΠΊΡ‚Π° HTMLElement, Π² свою ΠΎΡ‡Π΅Ρ€Π΅Π΄ΡŒ, содСрТит свойство related, ΠΊΠΎΡ‚ΠΎΡ€ΠΎΠ΅ ΠΈ Ρ…Ρ€Π°Π½ΠΈΡ‚ массив ΠΊΠΎΠ½Ρ„ΠΈΠ³ΡƒΡ€Π°Ρ‚ΠΎΡ€ΠΎΠ², ΠΏΡ€Π΅Π΄ΡΡ‚Π°Π²Π»ΡΡŽΡ‰ΠΈΡ… Web-страницы со связанными ΠΌΠ°Ρ‚Π΅Ρ€ΠΈΠ°Π»Π°ΠΌΠΈ; ΠΌΡ‹ сами создали это свойство ΠΏΡ€ΠΈ Ρ„ΠΎΡ€ΠΌΠΈΡ€ΠΎΠ²Π°Π½ΠΈΠΈ ΠΏΡƒΠ½ΠΊΡ‚ΠΎΠ² Π²Π»ΠΎΠΆΠ΅Π½Π½Ρ‹Ρ… списков (исправлСнная функция generateInnerList).

ΠŸΡ€ΠΎΠ²Π΅Ρ€ΡΠ΅ΠΌ, присутствуСт Π»ΠΈ это свойство Π² экзСмплярС ΠΎΠ±ΡŠΠ΅ΠΊΡ‚Π° HTMLElement, Ρ‚. Π΅. сущСствуСт Π»ΠΈ Ρƒ Π΄Π°Π½Π½ΠΎΠΉ Web-страницы список связанных ΠΌΠ°Ρ‚Π΅Ρ€ΠΈΠ°Π»ΠΎΠ²:

if (oRelated) {

Если сущСствуСт, запускаСм Ρ†ΠΈΠΊΠ» со счСтчиком, ΠΊΠΎΡ‚ΠΎΡ€Ρ‹ΠΉ ΠΎΠ±Ρ€Π°Π±ΠΎΡ‚Π°Π΅Ρ‚ всС элСмСнты этого массива:

for (var i = 0; i < oRelated.length; i++) {

Π€Ρ€Π°Π³ΠΌΠ΅Π½Ρ‚Ρ‹ HTML-ΠΊΠΎΠ΄Π°, Ρ„ΠΎΡ€ΠΌΠΈΡ€ΡƒΡŽΡ‰ΠΈΠ΅ ΠΎΡ‚Π΄Π΅Π»ΡŒΠ½Ρ‹Π΅ гипСрссылки Ρ€Π°Π·Π΄Π΅Π»Π° "Π‘ΠΌ.

Ρ‚Π°ΠΊΠΆΠ΅", ΠΌΡ‹ Π±ΡƒΠ΄Π΅ΠΌ Π΄ΠΎΠ±Π°Π²Π»ΡΡ‚ΡŒ Π² строку, Ρ…Ρ€Π°Π½ΡΡ‰ΡƒΡŽΡΡ Π² ΠΏΠ΅Ρ€Π΅ΠΌΠ΅Π½Π½ΠΎΠΉ s:

if (s!= "")

s += ", ";

Π­Ρ‚ΠΈ гипСрссылки слСдуСт Ρ€Π°Π·Π΄Π΅Π»ΠΈΡ‚ΡŒ запятыми, Ρ‡Ρ‚ΠΎ ΠΈ выполняСт ΠΏΡ€ΠΈΠ²Π΅Π΄Π΅Π½Π½ΠΎΠ΅ Π²Ρ‹Ρ€Π°ΠΆΠ΅Π½ΠΈΠ΅. Оно провСряСт, Π΅ΡΡ‚ΡŒ Π»ΠΈ Π² ΠΏΠ΅Ρ€Π΅ΠΌΠ΅Π½Π½ΠΎΠΉ s нСпустая строка, Ρ‚. Π΅. сформирована Π»ΠΈ Π² Π½Π΅ΠΉ хотя Π±Ρ‹ ΠΎΠ΄Π½Π° гипСрссылка, ΠΈ, Ссли это Ρ‚Π°ΠΊ, добавляСт ΠΊ Π½Π΅ΠΉ Π·Π°ΠΏΡΡ‚ΡƒΡŽ β€” Ρ€Π°Π·Π΄Π΅Π»ΠΈΡ‚Π΅Π»ΡŒ гипСрссылок.

Π€ΠΎΡ€ΠΌΠΈΡ€ΡƒΠ΅ΠΌ HTML-ΠΊΠΎΠ΄, ΡΠΎΠ·Π΄Π°ΡŽΡ‰ΠΈΠΉ гипСрссылку Π½Π° ΠΎΡ‡Π΅Ρ€Π΅Π΄Π½ΡƒΡŽ Web-страницу ΠΈΠ· списка связанных ΠΌΠ°Ρ‚Π΅Ρ€ΠΈΠ°Π»ΠΎΠ², ΠΈ добавляСм Π΅Π³ΠΎ ΠΊ Π·Π½Π°Ρ‡Π΅Π½ΠΈΡŽ ΠΏΠ΅Ρ€Π΅ΠΌΠ΅Π½Π½ΠΎΠΉ s:

s += "<CODE><A HREF=\"" + oRelated[i].url + "\">" + oRelated[i].name + "</A></CODE>";

}

На этом Ρ‚Π΅Π»ΠΎ Ρ†ΠΈΠΊΠ»Π° Π·Π°Π²Π΅Ρ€ΡˆΠ°Π΅Ρ‚ΡΡ.

Π”Π°Π»Π΅Π΅ создаСм Π½Π° основС сформированного HTML-ΠΊΠΎΠ΄Π° Π°Π±Π·Π°Ρ†, ΠΊΠΎΡ‚ΠΎΡ€Ρ‹ΠΉ ΠΈ станСт Ρ€Π°Π·Π΄Π΅Π»ΠΎΠΌ "Π‘ΠΌ. Ρ‚Π°ΠΊΠΆΠ΅". ДобавляСм Π΅Π³ΠΎ Π² самый ΠΊΠΎΠ½Π΅Ρ† ΠΊΠΎΠ½Ρ‚Π΅ΠΉΠ½Π΅Ρ€Π° cmain (ΠΏΠ΅Ρ€Π΅Π΄ Π΅Π³ΠΎ Π·Π°ΠΊΡ€Ρ‹Π²Π°ΡŽΡ‰ΠΈΠΌ Ρ‚Π΅Π³ΠΎΠΌ):

var htelRelated = Ext.get("cmain"). insertHtml("beforeEnd", "<P>Π‘ΠΌ. Ρ‚Π°ΠΊΠΆΠ΅: " + s + "</P>");

Π’Ρ‹Π±ΠΈΡ€Π°Π΅ΠΌ ΠΈΠ· сформированного Π² ΠΏΡ€Π΅Π΄Ρ‹Π΄ΡƒΡ‰Π΅ΠΌ Π²Ρ‹Ρ€Π°ΠΆΠ΅Π½ΠΈΠΈ Π°Π±Π·Π°Ρ†Π° всС гипСрссылки ΠΈ привязываСм ΠΊ Π½ΠΈΠΌ Ρ„ΡƒΠ½ΠΊΡ†ΠΈΡŽ β€” ΠΎΠ±Ρ€Π°Π±ΠΎΡ‚Ρ‡ΠΈΠΊ события click, ΠΊΠΎΡ‚ΠΎΡ€ΡƒΡŽ Ρ‚Π°ΠΌ ΠΆΠ΅ ΠΈ объявляСм:

Ext.fly(htelRelated). select("A"). on("click", function(e, t) {

ΠŸΠ΅Ρ€Π²Ρ‹ΠΌ Π΄Π΅Π»ΠΎΠΌ эта функция ΠΏΠΎΠ»ΡƒΡ‡ΠΈΡ‚ Π·Π½Π°Ρ‡Π΅Π½ΠΈΠ΅ Π°Ρ‚Ρ€ΠΈΠ±ΡƒΡ‚Π° HREF β€” ΠΈΠ½Ρ‚Π΅Ρ€Π½Π΅Ρ‚-адрСс β€” гипСрссылки, Π½Π° ΠΊΠΎΡ‚ΠΎΡ€ΠΎΠΉ Ρ‰Π΅Π»ΠΊΠ½ΡƒΠ»ΠΈ ΠΌΡ‹ΡˆΡŒΡŽ:

var href = Ext.fly(this). getAttribute("href");

Π”Π°Π»Π΅Π΅ ΠΎΠ½Π° ΠΈΡ‰Π΅Ρ‚ Π² спискС navbar гипСрссылку с Ρ‚Π΅ΠΌ ΠΆΠ΅ ΠΈΠ½Ρ‚Π΅Ρ€Π½Π΅Ρ‚-адрСсом:

var elA = Ext.get("navbar"). child("A[href=" + href + "]");

ΠŸΡƒΠ½ΠΊΡ‚Ρ‹ нашСй полосы Π½Π°Π²ΠΈΠ³Π°Ρ†ΠΈΠΈ Π½Π΅ содСрТат ΠΏΠΎΠ²Ρ‚ΠΎΡ€ΡΡŽΡ‰ΠΈΡ…ΡΡ ΠΈΠ½Ρ‚Π΅Ρ€Π½Π΅Ρ‚-адрСсов, поэтому Ρ‚Π°ΠΊΠΎΠΉ ΠΏΡ€ΠΈΠ΅ΠΌ Π±ΡƒΠ΄Π΅Ρ‚ Ρ€Π°Π±ΠΎΡ‚Π°Ρ‚ΡŒ.

Найдя Ρ‚Π°ΠΊΡƒΡŽ гипСрссылку, ΠΎΠ½Π° ΠΏΠΎΠ»ΡƒΡ‡Π°Π΅Ρ‚ Π΅Π΅ родитСля β€” сам ΠΏΡƒΠ½ΠΊΡ‚:

var elItem = elA.parent("LI");

ΠΊΠΎΡ‚ΠΎΡ€Ρ‹ΠΉ, вмСстС с экзСмпляром ΠΎΠ±ΡŠΠ΅ΠΊΡ‚Π° EventObject, ΠΏΡ€Π΅Π΄ΡΡ‚Π°Π²Π»ΡΡŽΡ‰ΠΈΠΌ возникшСС событиС, "скармливаСт" объявлСнной Π½Π°ΠΌΠΈ Π² Π³Π»Π°Π²Π΅ 17 Ρ„ΡƒΠ½ΠΊΡ†ΠΈΠΈ loadFragment. ПослСдняя Π²Ρ‹ΠΏΠΎΠ»Π½ΠΈΡ‚ Π·Π°Π³Ρ€ΡƒΠ·ΠΊΡƒ ΡΠΎΠΎΡ‚Π²Π΅Ρ‚ΡΡ‚Π²ΡƒΡŽΡ‰Π΅Π³ΠΎ Ρ„Ρ€Π°Π³ΠΌΠ΅Π½Ρ‚Π° содСрТимого ΠΈ Π²Ρ‹Π΄Π΅Π»ΠΈΡ‚ ΡΠΎΠΎΡ‚Π²Π΅Ρ‚ΡΡ‚Π²ΡƒΡŽΡ‰ΠΈΠΉ ΠΏΡƒΠ½ΠΊΡ‚ полосы Π½Π°Π²ΠΈΠ³Π°Ρ†ΠΈΠΈ:


loadFragment(elItem, e);

});

}

На этом Π²Ρ‹ΠΏΠΎΠ»Π½Π΅Π½ΠΈΠ΅ Ρ„ΡƒΠ½ΠΊΡ†ΠΈΠΈ generateRelated заканчиваСтся.

Π’Π΅ΠΏΠ΅Ρ€ΡŒ ΠΎΡ‚Ρ‹Ρ‰Π΅ΠΌ ΠΊΠΎΠ΄, ΠΎΠ±ΡŠΡΠ²Π»ΡΡŽΡ‰ΠΈΠΉ Ρ„ΡƒΠ½ΠΊΡ†ΠΈΡŽ cleanupSamples. Она, ΠΊΠ°ΠΊ ΠΌΡ‹ ΠΏΠΎΠΌΠ½ΠΈΠΌ, удаляСт ΠΎΠ±Ρ€Π°Π±ΠΎΡ‚Ρ‡ΠΈΠΊΠΈ событий Ρƒ тСкста ΠΏΡ€ΠΈΠΌΠ΅Ρ€ΠΎΠ² ΠΏΠ΅Ρ€Π΅Π΄ Π·Π°Π³Ρ€ΡƒΠ·ΠΊΠΎΠΉ Π΄Ρ€ΡƒΠ³ΠΎΠ³ΠΎ Ρ„Ρ€Π°Π³ΠΌΠ΅Π½Ρ‚Π° содСрТимого. Π­Ρ‚ΠΎ Π½ΡƒΠΆΠ½ΠΎ, Ρ‡Ρ‚ΠΎΠ±Ρ‹ Π½Π΅ Π·Π°ΡΠΎΡ€ΡΡ‚ΡŒ Π²Π½ΡƒΡ‚Ρ€Π΅Π½Π½ΠΈΠ΅ структуры Π΄Π°Π½Π½Ρ‹Ρ… Π±ΠΈΠ±Π»ΠΈΠΎΡ‚Π΅ΠΊΠΈ Ext Core свСдСниями ΠΎ привязкС ΠΎΠ±Ρ€Π°Π±ΠΎΡ‚Ρ‡ΠΈΠΊΠΎΠ² событий ΠΊ ΡƒΠΆΠ΅ Π½Π΅ ΡΡƒΡ‰Π΅ΡΡ‚Π²ΡƒΡŽΡ‰ΠΈΠΌ элСмСнтам Web-страницы.

Нам Π½ΡƒΠΆΠ½ΠΎ Π΄ΠΎΠΏΠΎΠ»Π½ΠΈΡ‚ΡŒ этот ΠΊΠΎΠ΄, Ρ‡Ρ‚ΠΎΠ±Ρ‹ ΠΎΠ½ Ρ‚Π°ΠΊΠΆΠ΅ удалял ΠΎΠ±Ρ€Π°Π±ΠΎΡ‚Ρ‡ΠΈΠΊΠΈ событий Ρƒ гипСрссылок Ρ€Π°Π·Π΄Π΅Π»Π° "Π‘ΠΌ. Ρ‚Π°ΠΊΠΆΠ΅". Π‘Π΄Π΅Π»Π°Π΅ΠΌ ΠΏΡ€ΠΎΡ‰Π΅ β€” Π±ΡƒΠ΄Π΅ΠΌ Π²Ρ‹Π±ΠΈΡ€Π°Ρ‚ΡŒ всС гипСрссылки Π² ΠΊΠΎΠ½Ρ‚Π΅ΠΉΠ½Π΅Ρ€Π΅ cmain ΠΈ ΡƒΠ΄Π°Π»ΡΡ‚ΡŒ Ρƒ Π½ΠΈΡ… ΠΎΠ±Ρ€Π°Π±ΠΎΡ‚Ρ‡ΠΈΠΊΠΈ событий.

Листинг 19.3 содСрТит Π΄ΠΎΠΏΠΎΠ»Π½Π΅Π½Π½ΠΎΠ΅ объявлСниС Ρ„ΡƒΠ½ΠΊΡ†ΠΈΠΈ cleanupSamples.

Листинг 19.3

function cleanupSamples() {

var ceSamples = Ext.select(".sample");

ceSamples.each(function(el, cl, ind){ var elH6 = el.child(":first"); elH6.removeAllListeners();

});

var ceA = Ext.get("cmain"). select("A");

ceA.removeAllListeners();

}

Π’Π°ΠΊ, вторая ΠΈ Ρ‚Ρ€Π΅Ρ‚ΡŒΡ Π·Π°Π΄Π°Ρ‡ΠΈ Ρ€Π΅ΡˆΠ΅Π½Ρ‹. ΠœΡ‹ сформировали Ρ€Π°Π·Π΄Π΅Π» "Π‘ΠΌ. Ρ‚Π°ΠΊΠΆΠ΅" ΠΈ Ρ€Π΅Π°Π»ΠΈΠ·ΠΎΠ²Π°Π»ΠΈ Π·Π°Π³Ρ€ΡƒΠ·ΠΊΡƒ Web-страницы ΠΏΡ€ΠΈ Ρ‰Π΅Π»Ρ‡ΠΊΠ΅ Π½Π° гипСрссылкС этого Ρ€Π°Π·Π΄Π΅Π»Π°.

Π’Π΅ΠΏΠ΅Ρ€ΡŒ прСдставим сСбС Ρ‚Π°ΠΊΡƒΡŽ ΡΠΈΡ‚ΡƒΠ°Ρ†ΠΈΡŽ. ΠŸΠΎΡΠ΅Ρ‚ΠΈΡ‚Π΅Π»ΡŒ Ρ‰Π΅Π»ΠΊΠ°Π΅Ρ‚ Π½Π° ΠΊΠ°ΠΊΠΎΠΌ-Π»ΠΈΠ±ΠΎ ΠΏΡƒΠ½ΠΊΡ‚Π΅ полосы Π½Π°Π²ΠΈΠ³Π°Ρ†ΠΈΠΈ, Web-ΠΎΠ±ΠΎΠ·Ρ€Π΅Π²Π°Ρ‚Π΅Π»ΡŒ Π²Ρ‹Π²ΠΎΠ΄ΠΈΡ‚ ΡΠΎΠΎΡ‚Π²Π΅Ρ‚ΡΡ‚Π²ΡƒΡŽΡ‰ΡƒΡŽ Web-страницу ΠΈ Ρ„ΠΎΡ€ΠΌΠΈΡ€ΡƒΠ΅Ρ‚ Π½Π° Π½Π΅ΠΉ Ρ€Π°Π·Π΄Π΅Π» "Π‘ΠΌ. Ρ‚Π°ΠΊΠΆΠ΅". Π­Ρ‚ΠΎΡ‚ Ρ€Π°Π·Π΄Π΅Π» содСрТит нСсколько гипСрссылок, ΡƒΠΊΠ°Π·Ρ‹Π²Π°ΡŽΡ‰ΠΈΡ… Π½Π° Web-страницы с описаниями Ρ‚Π΅Π³ΠΎΠ² HTML (ΠΏΠ΅Ρ€Π²Ρ‹ΠΉ Ρ€Π°Π·Π΄Π΅Π» β€” "HTML"), ΠΈ нСсколько гипСрссылок, ΡƒΠΊΠ°Π·Ρ‹Π²Π°ΡŽΡ‰ΠΈΡ… Π½Π° Web-страницы с описаниями Π°Ρ‚Ρ€ΠΈΠ±ΡƒΡ‚ΠΎΠ² стиля CSS (Π²Ρ‚ΠΎΡ€ΠΎΠΉ Ρ€Π°Π·Π΄Π΅Π» β€” "CSS"). ΠŸΡ€Π΅Π΄ΠΏΠΎΠ»ΠΎΠΆΠΈΠΌ, Ρ‡Ρ‚ΠΎ загруТСнная Π² Π΄Π°Π½Π½Ρ‹ΠΉ ΠΌΠΎΠΌΠ΅Π½Ρ‚ Web-страница Ρ‚Π°ΠΊΠΆΠ΅ содСрТит описаниС Ρ‚Π΅Π³Π° HTML (ΠΏΡ€ΠΈΠ½Π°Π΄Π»Π΅ΠΆΠΈΡ‚ ΠΊ ΠΏΠ΅Ρ€Π²ΠΎΠΌΡƒ Ρ€Π°Π·Π΄Π΅Π»Ρƒ); Π·Π½Π°Ρ‡ΠΈΡ‚, ΠΏΠ΅Ρ€Π²Ρ‹ΠΉ, ΠΏΡ€Π΅Π΄ΡΡ‚Π°Π²Π»ΡΡŽΡ‰ΠΈΠΉ Web-страницы ΠΈΠ· ΠΏΠ΅Ρ€Π²ΠΎΠ³ΠΎ Ρ€Π°Π·Π΄Π΅Π»Π°, Π²Π»ΠΎΠΆΠ΅Π½Π½Ρ‹ΠΉ список Π² полосС Π½Π°Π²ΠΈΠ³Π°Ρ†ΠΈΠΈ ΠΎΡ‚ΠΊΡ€Ρ‹Ρ‚, ΠΎΡΡ‚Π°Π»ΡŒΠ½Ρ‹Π΅ β€” скрыты.

Π’ этот ΠΌΠΎΠΌΠ΅Π½Ρ‚ ΠΏΠΎΡΠ΅Ρ‚ΠΈΡ‚Π΅Π»ΡŒ Ρ‰Π΅Π»ΠΊΠ°Π΅Ρ‚ Π½Π° гипСрссылкС Ρ€Π°Π·Π΄Π΅Π»Π° "Π‘ΠΌ. Ρ‚Π°ΠΊΠΆΠ΅", Π²Π΅Π΄ΡƒΡ‰Π΅ΠΉ Π½Π° Web-страницу с описаниСм Π°Ρ‚Ρ€ΠΈΠ±ΡƒΡ‚Π° стиля CSS (ΠΏΡ€ΠΈΠ½Π°Π΄Π»Π΅ΠΆΠ°Ρ‰Π΅ΠΉ Π²Ρ‚ΠΎΡ€ΠΎΠΌΡƒ Ρ€Π°Π·Π΄Π΅Π»Ρƒ), ΠΈ Web-страница ΡƒΡΠΏΠ΅ΡˆΠ½ΠΎ загруТаСтся. По ΠΈΠ΄Π΅Π΅, Π²Ρ‚ΠΎΡ€ΠΎΠΉ Π²Π»ΠΎΠΆΠ΅Π½Π½Ρ‹ΠΉ список (ΠΊΠΎΡ‚ΠΎΡ€Ρ‹ΠΉ прСдставляСт всС Web-страницы Π²Ρ‚ΠΎΡ€ΠΎΠ³ΠΎ Ρ€Π°Π·Π΄Π΅Π»Π°) Π² полосС Π½Π°Π²ΠΈΠ³Π°Ρ†ΠΈΠΈ Π΄ΠΎΠ»ΠΆΠ΅Π½ Π±Ρ‹Ρ‚ΡŒ ΠΎΡ‚ΠΊΡ€Ρ‹Ρ‚, Π° ΠΏΠ΅Ρ€Π²Ρ‹ΠΉ, ΠΎΡ‚ΠΊΡ€Ρ‹Ρ‚Ρ‹ΠΉ Ρ€Π°Π½Π΅Π΅, β€” скрыт. НичСго ΠΏΠΎΠ΄ΠΎΠ±Π½ΠΎΠ³ΠΎ! ΠŸΠ΅Ρ€Π²Ρ‹ΠΉ Π²Π»ΠΎΠΆΠ΅Π½Π½Ρ‹ΠΉ список Ρ‚Π°ΠΊ ΠΈ останСтся ΠΎΡ‚ΠΊΡ€Ρ‹Ρ‚Ρ‹ΠΌ.

Π”Π΅Π»ΠΎ Π² Ρ‚ΠΎΠΌ, Ρ‡Ρ‚ΠΎ, создавая Π² Π³Π»Π°Π²Π΅ 17 Web-сцСнарий, ΡƒΠΏΡ€Π°Π²Π»ΡΡŽΡ‰ΠΈΠΉ скрытиСм ΠΈ раскрытиСм Π²Π»ΠΎΠΆΠ΅Π½Π½Ρ‹Ρ… списков Π² полосС Π½Π°Π²ΠΈΠ³Π°Ρ†ΠΈΠΈ ΠΈ Π²Ρ‹Π΄Π΅Π»Π΅Π½ΠΈΠ΅ΠΌ Π΅Π΅ ΠΏΡƒΠ½ΠΊΡ‚ΠΎΠ², ΠΌΡ‹ ΠΏΠΎΠ»Π°Π³Π°Π»ΠΈ, Ρ‡Ρ‚ΠΎ Ρ‰Π΅Π»ΠΊΠ°Ρ‚ΡŒ Π½Π° ΠΏΡƒΠ½ΠΊΡ‚Π°Ρ… полосы Π½Π°Π²ΠΈΠ³Π°Ρ†ΠΈΠΈ Π±ΡƒΠ΄Π΅Ρ‚ Ρ‡Π΅Π»ΠΎΠ²Π΅ΠΊ. А ΠΎΠ½ Π² ΠΏΡ€ΠΈΠ½Ρ†ΠΈΠΏΠ΅ Π½Π΅ ΠΌΠΎΠΆΠ΅Ρ‚ Ρ‰Π΅Π»ΠΊΠ½ΡƒΡ‚ΡŒ Π½Π° ΠΏΡƒΠ½ΠΊΡ‚Π΅, находящСмся Π² скрытом спискС, β€” вСдь скрытый список Π²ΠΎΠΎΠ±Ρ‰Π΅ Π½Π΅ присутствуСт Π½Π° Web-страницС. ΠŸΠΎΡΡ‚ΠΎΠΌΡƒ ΠΌΡ‹ Π½Π΅ Ρ€Π΅Π°Π»ΠΈΠ·ΠΎΠ²Π°Π»ΠΈ Π² Ρ„ΡƒΠ½ΠΊΡ†ΠΈΠΈ loadFragment Π²ΠΎΠ·ΠΌΠΎΠΆΠ½ΠΎΡΡ‚ΡŒ открытия Π²Π»ΠΎΠΆΠ΅Π½Π½ΠΎΠ³ΠΎ списка, Π½Π° ΠΏΡƒΠ½ΠΊΡ‚Π΅ ΠΊΠΎΡ‚ΠΎΡ€ΠΎΠ³ΠΎ Ρ‰Π΅Π»ΠΊΠ½ΡƒΠ» ΠΏΠΎΡΠ΅Ρ‚ΠΈΡ‚Π΅Π»ΡŒ, β€” это Π±Ρ‹Π»ΠΎ просто Π½Π΅Π·Π°Ρ‡Π΅ΠΌ.

БСйчас ΠΆΠ΅ ΠΌΡ‹ написали Ρ„ΡƒΠ½ΠΊΡ†ΠΈΡŽ generateRelated, которая создаСт Ρ€Π°Π·Π΄Π΅Π» "Π‘ΠΌ. Ρ‚Π°ΠΊΠΆΠ΅" Ρ Π½Π°Π±ΠΎΡ€ΠΎΠΌ гипСрссылок ΠΈ привязываСт ΠΊ Π½ΠΈΠΌ ΠΎΠ±Ρ€Π°Π±ΠΎΡ‚Ρ‡ΠΈΠΊ события click. Π­Ρ‚ΠΎΡ‚ ΠΎΠ±Ρ€Π°Π±ΠΎΡ‚Ρ‡ΠΈΠΊ Π½Π°Ρ…ΠΎΠ΄ΠΈΡ‚ Π² полосС Π½Π°Π²ΠΈΠ³Π°Ρ†ΠΈΠΈ ΠΏΡƒΠ½ΠΊΡ‚, ΠΊΠΎΡ‚ΠΎΡ€Ρ‹ΠΉ ΠΈΠΌΠ΅Π΅Ρ‚ гипСрссылку с Ρ‚Π΅ΠΌ ΠΆΠ΅ ΠΈΠ½Ρ‚Π΅Ρ€Π½Π΅Ρ‚-адрСсом, ΠΈ, Ссли ΠΌΠΎΠΆΠ½ΠΎ Ρ‚Π°ΠΊ ΡΠΊΠ°Π·Π°Ρ‚ΡŒ, ΠΏΡ€ΠΎΠ³Ρ€Π°ΠΌΠΌΠ½ΠΎ "Ρ‰Π΅Π»ΠΊΠ°Π΅Ρ‚" Π½Π° Π½Π΅ΠΌ. А ΠΎΠ½ вСдь ΠΌΠΎΠΆΠ΅Ρ‚ "Ρ‰Π΅Π»ΠΊΠ½ΡƒΡ‚ΡŒ" ΠΈ Π½Π° ΠΏΡƒΠ½ΠΊΡ‚Π΅ скрытого списка!

Π’Ρ‹Π²ΠΎΠ΄: Π½Π°ΠΌ потрСбуСтся Π΄ΠΎΠΏΠΎΠ»Π½ΠΈΡ‚ΡŒ объявлСниС Ρ„ΡƒΠ½ΠΊΡ†ΠΈΠΈ loadFragment Ρ‚Π°ΠΊ, Ρ‡Ρ‚ΠΎΠ±Ρ‹ ΠΎΠ½Π° ΠΎΡ‚ΠΊΡ€Ρ‹Π²Π°Π»Π° Π²Π»ΠΎΠΆΠ΅Π½Π½Ρ‹ΠΉ список, Π½Π° ΠΏΡƒΠ½ΠΊΡ‚Π΅ ΠΊΠΎΡ‚ΠΎΡ€ΠΎΠ³ΠΎ "Ρ‰Π΅Π»ΠΊΠ½ΡƒΠ»ΠΈ", Ссли, ΠΊΠΎΠ½Π΅Ρ‡Π½ΠΎ, ΠΎΠ½ Π΅Ρ‰Π΅ Π½Π΅ ΠΎΡ‚ΠΊΡ€Ρ‹Ρ‚. НайдСм это объявлСниС ΠΈ ΠΎΡ‚Ρ‹Ρ‰Π΅ΠΌ Π² Π½Π΅ΠΌ Ρ„Ρ€Π°Π³ΠΌΠ΅Π½Ρ‚ ΠΊΠΎΠ΄Π°, ΠΏΡ€ΠΈΠ²Π΅Π΄Π΅Π½Π½Ρ‹ΠΉ Π² листингС 19.4.

Листинг 19.4

.

} else {

if ((elLastItem) && (elLastItem.dom!= elLI.dom))

elLastItem.removeClass("selected");

elLI.addClass("selected");

elLastItem = elLI;

}

Π­Ρ‚ΠΎΡ‚ ΠΊΠΎΠ΄ управляСт Π²Ρ‹Π΄Π΅Π»Π΅Π½ΠΈΠ΅ΠΌ ΠΏΡƒΠ½ΠΊΡ‚Π° Π²Π»ΠΎΠΆΠ΅Π½Π½ΠΎΠ³ΠΎ списка, Π½Π° ΠΊΠΎΡ‚ΠΎΡ€ΠΎΠΌ Ρ‰Π΅Π»ΠΊΠ½ΡƒΠ»ΠΈ ΠΌΡ‹ΡˆΡŒΡŽ ΠΈΠ»ΠΈ "Ρ‰Π΅Π»ΠΊΠ½ΡƒΠ»ΠΈ" ΠΏΡ€ΠΎΠ³Ρ€Π°ΠΌΠΌΠ½ΠΎ. Π”ΠΎΠΏΠΎΠ»Π½ΠΈΠΌ Π΅Π³ΠΎ Ρ‚Π°ΠΊ, ΠΊΠ°ΠΊ ΠΏΠΎΠΊΠ°Π·Π°Π½ΠΎ Π² листингС 19.5.

Листинг 19.5

} else {

var elInnerList = elLI.parent("UL");

if ((elLastInnerList) && (elLastInnerList.dom!= elInnerList.dom))

elLastInnerList.setDisplayed(false); elInnerList.setDisplayed(true); elLastInnerList = elInnerList;

if ((elLastItem) && (elLastItem.dom!= elLI.dom))

elLastItem.removeClass("selected");

elLI.addClass("selected");

elLastItem = elLI;

}

Π”ΠΎΠ±Π°Π²Π»Π΅Π½Π½Ρ‹Π΅ Π½Π°ΠΌΠΈ выраТСния находят Π²Π»ΠΎΠΆΠ΅Π½Π½Ρ‹ΠΉ список, Π² ΠΊΠΎΡ‚ΠΎΡ€ΠΎΠΌ присутствуСт Π΄Π°Π½Π½Ρ‹ΠΉ ΠΏΡƒΠ½ΠΊΡ‚, ΠΏΡ€ΠΎΠ²Π΅Ρ€ΡΡŽΡ‚, ΠΎΡ‚ΠΊΡ€Ρ‹Ρ‚ Π»ΠΈ ΠΎΠ½ Π² Ρ‚Π΅ΠΊΡƒΡ‰ΠΈΠΉ ΠΌΠΎΠΌΠ΅Π½Ρ‚, ΠΈ, Ссли Π½Π΅ ΠΎΡ‚ΠΊΡ€Ρ‹Ρ‚, ΠΎΡ‚ΠΊΡ€Ρ‹Π²Π°ΡŽΡ‚, скрывая ΠΏΡ€ΠΈ этом Ρ€Π°Π½Π΅Π΅ ΠΎΡ‚ΠΊΡ€Ρ‹Ρ‚Ρ‹ΠΉ список.

Π’ΠΎΡ‚ Ρ€Π΅ΡˆΠ΅Π½Π° ΠΈ чСтвСртая задача… Π£Ρ„-Ρ„-Ρ„!

Π‘ΠΎΡ…Ρ€Π°Π½ΠΈΠΌ всС исправлСнныС Ρ„Π°ΠΉΠ»Ρ‹ ΠΈ ΠΏΡ€ΠΎΠ²Π΅Ρ€ΠΈΠΌ Π³ΠΎΡ‚ΠΎΠ²ΡƒΡŽ Web-страницу index.htm Π² дСйствии. ΠžΡ‚ΠΊΡ€ΠΎΠ΅ΠΌ Web-ΠΎΠ±ΠΎΠ·Ρ€Π΅Π²Π°Ρ‚Π΅Π»ΡŒ, Π½Π°Π±Π΅Ρ€Π΅ΠΌ Π² ΠΏΠΎΠ»Π΅ Π²Π²ΠΎΠ΄Π° ΠΈΠ½Ρ‚Π΅Ρ€Π½Π΅Ρ‚-адрСс http://localhost, ΠΏΠΎΡ‰Π΅Π»ΠΊΠ°Π΅ΠΌ Π½Π° ΠΏΡƒΠ½ΠΊΡ‚Π°Ρ… полосы Π½Π°Π²ΠΈΠ³Π°Ρ†ΠΈΠΈ ΠΈ гипСрссылках Ρ€Π°Π·Π΄Π΅Π»Π° "Π‘ΠΌ. Ρ‚Π°ΠΊΠΆΠ΅" ΠΈ посмотрим Π½Π° ΡΠΌΠ΅Π½ΡΡŽΡ‰ΠΈΠ΅ Π΄Ρ€ΡƒΠ³ Π΄Ρ€ΡƒΠ³Π° Web-страницы ΠΈ ΡΠΊΡ€Ρ‹Π²Π°ΡŽΡ‰ΠΈΠ΅ΡΡ ΠΈ ΠΎΡ‚ΠΊΡ€Ρ‹Π²Π°ΡŽΡ‰ΠΈΠ΅ΡΡ Π²Π»ΠΎΠΆΠ΅Π½Π½Ρ‹Π΅ списки. ΠšΡ€Π°ΡΠΎΡ‚Π°!