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

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

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

aResult[i].name + "</A></LI>";

}

var htelResult = elSearchResult.insertHtml("beforeEnd", s); Ext.fly(htelResult). 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);

});

elSearchResult.setDisplayed(true);

}

}

Рассмотрим листинг 21.6 построчно.

ΠŸΠ΅Ρ€Π΅Π΄ поиском Π½Π°ΠΌ Π½ΡƒΠΆΠ½ΠΎ ΡƒΠ΄Π°Π»ΠΈΡ‚ΡŒ всС ΠΏΡƒΠ½ΠΊΡ‚Ρ‹, ΡƒΠΆΠ΅ ΠΏΡ€ΠΈΡΡƒΡ‚ΡΡ‚Π²ΡƒΡŽΡ‰ΠΈΠ΅ Π² спискС search_result. Для этого ΠΌΡ‹ сначала удаляСм всС ΠΎΠ±Ρ€Π°Π±ΠΎΡ‚Ρ‡ΠΈΠΊΠΈ событий, привязанныС ΠΊ гипСрссылкам, находящимся Π² ΠΏΡƒΠ½ΠΊΡ‚Π°Ρ… этого списка, Π° ΠΏΠΎΡ‚ΠΎΠΌ удаляСм сами ΠΏΡƒΠ½ΠΊΡ‚Ρ‹:

var elSearchResult = Ext.get("search_result"); elSearchResult.select("A"). removeAllListeners(); elSearchResult.dom.innerHTML = ""; elSearchResult.setDisplayed(false);

НапослСдок скрываСм список search_result.

ΠžΠ±Ρ€Π°Ρ‚ΠΈΠΌ Π²Π½ΠΈΠΌΠ°Π½ΠΈΠ΅, ΠΊΠ°ΠΊ выполняСтся ΡƒΠ΄Π°Π»Π΅Π½ΠΈΠ΅ ΠΏΡƒΠ½ΠΊΡ‚ΠΎΠ² списка search_result. Из Π³Π»Π°Π²Ρ‹ 15 ΠΌΡ‹ Π·Π½Π°Π΅ΠΌ, Ρ‡Ρ‚ΠΎ ΠΎΠ±ΡŠΠ΅ΠΊΡ‚ Web-обозрСватСля HTMLElement ΠΏΠΎΠ΄Π΄Π΅Ρ€ΠΆΠΈΠ²Π°Π΅Ρ‚ свойство innerHTML, хранящСС HTML-ΠΊΠΎΠ΄, ΡΠΎΠ·Π΄Π°ΡŽΡ‰ΠΈΠΉ содСрТимоС Π΄Π°Π½Π½ΠΎΠ³ΠΎ элСмСнта Web-страницы, Π² Π²ΠΈΠ΄Π΅ строки. Π—Π½Π°Ρ‡ΠΈΡ‚, Ρ‡Ρ‚ΠΎΠ±Ρ‹ ΡƒΠ΄Π°Π»ΠΈΡ‚ΡŒ всС содСрТимоС Π΄Π°Π½Π½ΠΎΠ³ΠΎ элСмСнта, ΠΌΡ‹ ΠΌΠΎΠΆΠ΅ΠΌ ΠΏΠΎΠ»ΡƒΡ‡ΠΈΡ‚ΡŒ ΡΠΎΠΎΡ‚Π²Π΅Ρ‚ΡΡ‚Π²ΡƒΡŽΡ‰ΠΈΠΉ Π΅ΠΌΡƒ экзСмпляр ΠΎΠ±ΡŠΠ΅ΠΊΡ‚Π° HTMLElement (Ρ‡Π΅Ρ€Π΅Π· свойство dom ΠΎΠ±ΡŠΠ΅ΠΊΡ‚Π° Ext Core Element) ΠΈ ΠΏΡ€ΠΈΡΠ²ΠΎΠΈΡ‚ΡŒ Π΅Π³ΠΎ свойству innerHTML ΠΏΡƒΡΡ‚ΡƒΡŽ строку. Π§Ρ‚ΠΎ ΠΌΡ‹ ΠΈ Π΄Π΅Π»Π°Π΅ΠΌ.

Листинг 21.7

var sKeyword = Ext.get("keyword"). getValue(false);

if (sKeyword!= "") {

var iSearchMode = Ext.getDom("search_in"). selectedIndex;

var aResult = [];

searchInArray(sKeyword, aHTML, aResult, iSearchMode); searchInArray(sKeyword, aCSS, aResult, iSearchMode); searchInArray(sKeyword, aSamples, aResult, iSearchMode); if (aResult.length > 0) {

var s = "";

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

s += "<LI><A HREF=\"" + aResult[i].url + "\">" +

aResult[i].name + "</A></LI>";

}

var htelResult = elSearchResult.insertHtml("beforeEnd", s); Ext.fly(htelResult). 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);

});

Π€Ρ€Π°Π³ΠΌΠ΅Π½Ρ‚ ΠΊΠΎΠ΄Π°, ΠΏΡ€ΠΈΠ²Π΅Π΄Π΅Π½Π½Ρ‹ΠΉ Π² листингС 21.7, ΠΏΠ΅Ρ€Π΅ΠΊΠΎΡ‡Π΅Π²Π°Π» ΠΈΠ· ΠΏΡ€Π΅Π΄Ρ‹Π΄ΡƒΡ‰Π΅ΠΉ Ρ€Π΅Π°Π»ΠΈΠ·Π°Ρ†ΠΈΠΈ Ρ„ΡƒΠ½ΠΊΡ†ΠΈΠΈ searchData практичСски Π±Π΅Π· ΠΈΠ·ΠΌΠ΅Π½Π΅Π½ΠΈΠΉ. ΠœΡ‹ ΡƒΠΆΠ΅ Π·Π½Π°Π΅ΠΌ, Ρ‡Ρ‚ΠΎ ΠΎΠ½ Π΄Π΅Π»Π°Π΅Ρ‚. Π‘Ρ„ΠΎΡ€ΠΌΠΈΡ€ΠΎΠ²Π°Π² ΠΏΡƒΠ½ΠΊΡ‚Ρ‹ списка search_result, ΠΎΡ‚ΠΊΡ€Ρ‹Π²Π°Π΅ΠΌ Π΅Π³ΠΎ:

elSearchResult.setDisplayed(true);

}

}

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

Ѐункция cleanupSamples, ΠΊΠΎΡ‚ΠΎΡ€ΡƒΡŽ ΠΌΡ‹ объявили Π² Π³Π»Π°Π²Π΅ 16, удаляСт ΠΎΠ±Ρ€Π°Π±ΠΎΡ‚Ρ‡ΠΈΠΊΠΈ событий, привязанныС ΠΊ гипСрссылкам Ρ€Π°Π·Π΄Π΅Π»Π° "Π‘ΠΌ. Ρ‚Π°ΠΊΠΆΠ΅" ΠΈ Ρ€Π΅Π·ΡƒΠ»ΡŒΡ‚Π°Ρ‚Π°ΠΌ поиска. НайдСм ΠΎΠ±ΡŠΡΠ²Π»ΡΡŽΡ‰ΠΈΠΉ Π΅Π΅ ΠΊΠΎΠ΄ ΠΈ ΡƒΠ΄Π°Π»ΠΈΠΌ выраТСния, ΠΊΠΎΡ‚ΠΎΡ€Ρ‹Π΅ ΡƒΠ±ΠΈΡ€Π°ΡŽΡ‚ ΠΎΠ±Ρ€Π°Π±ΠΎΡ‚Ρ‡ΠΈΠΊΠΈ событий Ρƒ гипСрссылок Ρ€Π΅Π·ΡƒΠ»ΡŒΡ‚Π°Ρ‚ΠΎΠ² поиска, β€” вСдь Ρ€Π°Π½Π΅Π΅ ΠΌΡ‹ помСстили Π²Ρ‹ΠΏΠΎΠ»Π½ΡΡŽΡ‰ΠΈΠΉ это дСйствиС ΠΊΠΎΠ΄ Π² Ρ„ΡƒΠ½ΠΊΡ†ΠΈΡŽ searchData. ПослС этого объявлСниС Ρ„ΡƒΠ½ΠΊΡ†ΠΈΠΈ cleanupSamples Π±ΡƒΠ΄Π΅Ρ‚ Π²Ρ‹Π³Π»ΡΠ΄Π΅Ρ‚ΡŒ Ρ‚Π°ΠΊ, ΠΊΠ°ΠΊ Π² листингС 21.8.

Листинг 21.8

function cleanupSamples() {

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

});

}

Π’Π°ΠΊ, Π±Γ³Π»ΡŒΡˆΡƒΡŽ Ρ‡Π°ΡΡ‚ΡŒ Ρ€Π°Π±ΠΎΡ‚Ρ‹ ΠΌΡ‹ сдСлали. ΠžΡΡ‚Π°Π»ΠΎΡΡŒ Ρ€Π΅Π°Π»ΠΈΠ·ΠΎΠ²Π°Ρ‚ΡŒ скрытиС списка search_result ΠΏΡ€ΠΈ Ρ‰Π΅Π»Ρ‡ΠΊΠ΅ Π½Π° содСрТимом Web-страницы.

ВСрнСмся ΠΊ Ρ‚Π΅Π»Ρƒ Ρ„ΡƒΠ½ΠΊΡ†ΠΈΠΈ, ΠΏΠ΅Ρ€Π΅Π΄Π°Π²Π°Π΅ΠΌΠΎΠΉ ΠΏΠ°Ρ€Π°ΠΌΠ΅Ρ‚Ρ€ΠΎΠΌ ΠΌΠ΅Ρ‚ΠΎΠ΄Ρƒ onReady ΠΎΠ±ΡŠΠ΅ΠΊΡ‚Π° Ext, ΠΈ Π΄ΠΎΠ±Π°Π²ΠΈΠΌ Π² Π΅Π³ΠΎ ΠΊΠΎΠ½Π΅Ρ† Ρ‚Π°ΠΊΠΎΠ΅ Π²Ρ‹Ρ€Π°ΠΆΠ΅Π½ΠΈΠ΅:

Ext.getBody(). on("click",

function(){ Ext.get("search_result"). setDisplayed(false); });

Оно привязываСт ΠΊ ΡΠΎΠ±Ρ‹Ρ‚ΠΈΡŽ click сСкции Ρ‚Π΅Π»Π° Web-страницы ΠΎΠ±Ρ€Π°Π±ΠΎΡ‚Ρ‡ΠΈΠΊ, ΠΊΠΎΡ‚ΠΎΡ€Ρ‹ΠΉ скрываСт список search_result.

Π’ Π³Π»Π°Π²Π΅ 15 ΠΌΡ‹ ΡƒΠ·Π½Π°Π»ΠΈ, Ρ‡Ρ‚ΠΎ Π½Π΅ΠΊΠΎΡ‚ΠΎΡ€Ρ‹Π΅ события, Π² Ρ‚ΠΎΠΌ числС ΠΈ click, ΠΈΠΌΠ΅ΡŽΡ‚ ΠΎΠ±Ρ‹ΠΊΠ½ΠΎΠ²Π΅Π½ΠΈΠ΅ Π²ΡΠΏΠ»Ρ‹Π²Π°Ρ‚ΡŒ ΠΈΠ· элСмСнтов, Π² ΠΊΠΎΡ‚ΠΎΡ€Ρ‹Ρ… ΠΎΠ½ΠΈ ΠΈΠ·Π½Π°Ρ‡Π°Π»ΡŒΠ½ΠΎ Π²ΠΎΠ·Π½ΠΈΠΊΠ»ΠΈ, Π² ΠΈΡ… Ρ€ΠΎΠ΄ΠΈΡ‚Π΅Π»ΠΈ, Π·Π°Ρ‚Π΅ΠΌ β€” Π² Ρ€ΠΎΠ΄ΠΈΡ‚Π΅Π»ΠΈ ΠΈΡ… Ρ€ΠΎΠ΄ΠΈΡ‚Π΅Π»Π΅ΠΉ ΠΈ, Π½Π°ΠΊΠΎΠ½Π΅Ρ†, Π² ΡΠ΅ΠΊΡ†ΠΈΡŽ Ρ‚Π΅Π»Π° Web-страницы. ΠžΠ±Ρ€Π°Π±ΠΎΡ‚Ρ‡ΠΈΠΊ события click, ΠΊΠΎΡ‚ΠΎΡ€Ρ‹ΠΉ ΠΌΡ‹ Ρ‚ΠΎΠ»ΡŒΠΊΠΎ Ρ‡Ρ‚ΠΎ привязали ΠΊ сСкции Ρ‚Π΅Π»Π° Web- страницы, сработаСт нСзависимо ΠΎΡ‚ Ρ‚ΠΎΠ³ΠΎ, Π² ΠΊΠ°ΠΊΠΎΠΌ элСмСнтС Web-страницы Π²ΠΎΠ·Π½ΠΈΠΊΠ»ΠΎ это событиС, ΠΈ список search_result Π² любом случаС Π±ΡƒΠ΄Π΅Ρ‚ скрыт.

Но Ρ‚ΡƒΡ‚ Π²ΠΎΠ·Π½ΠΈΠΊΠ°Π΅Ρ‚ ΠΎΡ‡Π΅Π½ΡŒ нСприятный ΠΌΠΎΠΌΠ΅Π½Ρ‚: событиС click ΠΊΠ½ΠΎΠΏΠΊΠΈ запуска поиска Ρ‚Π°ΠΊΠΆΠ΅ Ρ€Π°Π½ΠΎ ΠΈΠ»ΠΈ ΠΏΠΎΠ·Π΄Π½ΠΎ всплывСт Π² ΡΠ΅ΠΊΡ†ΠΈΡŽ Ρ‚Π΅Π»Π° Web-страницы. Π”Π°Π²Π°ΠΉΡ‚Π΅ посмотрим, Ρ‡Ρ‚ΠΎ получится Π² Ρ€Π΅Π·ΡƒΠ»ΡŒΡ‚Π°Ρ‚Π΅. ΠŸΠΎΡΠ΅Ρ‚ΠΈΡ‚Π΅Π»ΡŒ Π½Π°ΠΆΠΌΠ΅Ρ‚ ΠΊΠ½ΠΎΠΏΠΊΡƒ запуска поиска, функция searchData сформируСт ΠΏΡƒΠ½ΠΊΡ‚Ρ‹ списка Ρ€Π΅Π·ΡƒΠ»ΡŒΡ‚Π°Ρ‚ΠΎΠ² ΠΈ ΠΎΡ‚ΠΊΡ€ΠΎΠ΅Ρ‚ этот список, послС Ρ‡Π΅Π³ΠΎ выполнится ΠΎΠ±Ρ€Π°Π±ΠΎΡ‚Ρ‡ΠΈΠΊ события click, привязанный Π½Π°ΠΌΠΈ ΠΊ сСкции Ρ‚Π΅Π»Π° Web- страницы, ΠΊΠΎΡ‚ΠΎΡ€Ρ‹ΠΉ скроСт список Ρ€Π΅Π·ΡƒΠ»ΡŒΡ‚Π°Ρ‚ΠΎΠ². НСпорядок!

НайдСм Π² Ρ‚Π΅Π»Π΅ Ρ„ΡƒΠ½ΠΊΡ†ΠΈΠΈ, ΠΏΠ΅Ρ€Π΅Π΄Π°Π²Π°Π΅ΠΌΠΎΠΉ ΠΏΠ°Ρ€Π°ΠΌΠ΅Ρ‚Ρ€ΠΎΠΌ ΠΌΠ΅Ρ‚ΠΎΠ΄Ρƒ onReady ΠΎΠ±ΡŠΠ΅ΠΊΡ‚Π° Ext, Π²ΠΎΡ‚ это Π²Ρ‹Ρ€Π°ΠΆΠ΅Π½ΠΈΠ΅:

Ext.get("find"). on("click", searchData);

Оно привязываСт ΠΎΠ±Ρ€Π°Π±ΠΎΡ‚Ρ‡ΠΈΠΊ ΠΊ ΡΠΎΠ±Ρ‹Ρ‚ΠΈΡŽ click ΠΊΠ½ΠΎΠΏΠΊΠΈ, Π·Π°ΠΏΡƒΡΠΊΠ°ΡŽΡ‰Π΅ΠΉ поиск. ИзмСним Π΅Π³ΠΎ ΡΠ»Π΅Π΄ΡƒΡŽΡ‰ΠΈΠΌ ΠΎΠ±Ρ€Π°Π·ΠΎΠΌ:

Ext.get("find"). on("click", function(e){

searchData();

e. stopPropagation();

});

Новый ΠΎΠ±Ρ€Π°Π±ΠΎΡ‚Ρ‡ΠΈΠΊ события click сначала Π²Ρ‹Π·ΠΎΠ²Π΅Ρ‚ Ρ„ΡƒΠ½ΠΊΡ†ΠΈΡŽ searchData, собствСнно Π²Ρ‹ΠΏΠΎΠ»Π½ΡΡŽΡ‰ΡƒΡŽ поиск, Π° ΠΏΠΎΡ‚ΠΎΠΌ ΠΏΠΎΠ΄Π°Π²ΠΈΡ‚ всплытиС возникшСго события. Как Π²ΠΈΠ΄ΠΈΠΌ, для этого ΠΈΡΠΏΠΎΠ»ΡŒΠ·ΡƒΠ΅Ρ‚ΡΡ ΠΌΠ΅Ρ‚ΠΎΠ΄ stopPropagation ΠΎΠ±ΡŠΠ΅ΠΊΡ‚Π° Ext Core EventObject (см. Π³Π»Π°Π²Ρƒ 15).

И Π΅Ρ‰Π΅. Π’ ΠΎΠ±Ρ€Π°Π±ΠΎΡ‚Ρ‡ΠΈΠΊΠ΅ события click ΠΏΡƒΠ½ΠΊΡ‚ΠΎΠ² полосы Π½Π°Π²ΠΈΠ³Π°Ρ†ΠΈΠΈ (функция loadFragment) Ρƒ нас подавляСтся всплытиС этого события. Π‘Π»Π΅Π΄ΠΎΠ²Π°Ρ‚Π΅Π»ΡŒΠ½ΠΎ, Ссли ΠΏΠΎΡΠ΅Ρ‚ΠΈΡ‚Π΅Π»ΡŒ Ρ‰Π΅Π»ΠΊΠ½Π΅Ρ‚ Π½Π° ΠΏΡƒΠ½ΠΊΡ‚Π΅ полосы Π½Π°Π²ΠΈΠ³Π°Ρ†ΠΈΠΈ (ΠΈΠ»ΠΈ гипСрссылкС Ρ€Π°Π·Π΄Π΅Π»Π° "Π‘ΠΌ. Ρ‚Π°ΠΊΠΆΠ΅", ΠΈΠ»ΠΈ гипСрссылкС ΠΏΡƒΠ½ΠΊΡ‚Π° Π² спискС Ρ€Π΅Π·ΡƒΠ»ΡŒΡ‚Π°Ρ‚ΠΎΠ² поиска), событиС click Π½Π΅ всплывСт Π² ΡΠ΅ΠΊΡ†ΠΈΡŽ Ρ‚Π΅Π»Π° Web-страницы, привязанный ΠΊ Π½Π΅ΠΌΡƒ ΠΎΠ±Ρ€Π°Π±ΠΎΡ‚Ρ‡ΠΈΠΊ Π½Π΅ выполнится, ΠΈ список search_result скрыт Π½Π΅ Π±ΡƒΠ΄Π΅Ρ‚. Нам Π½ΡƒΠΆΠ½ΠΎ это ΠΈΡΠΏΡ€Π°Π²ΠΈΡ‚ΡŒ.

НайдСм ΠΊΠΎΠ΄, ΠΎΠ±ΡŠΡΠ²Π»ΡΡŽΡ‰ΠΈΠΉ Ρ„ΡƒΠ½ΠΊΡ†ΠΈΡŽ loadFragment, ΠΈ Π΄ΠΎΠ±Π°Π²ΠΈΠΌ Π² самый Π΅Π³ΠΎ ΠΊΠΎΠ½Π΅Ρ† Ρ‚Π°ΠΊΠΎΠ΅ Π²Ρ‹Ρ€Π°ΠΆΠ΅Π½ΠΈΠ΅:

Ext.get("search_result"). setDisplayed(false);

Π§Ρ‚ΠΎ ΠΎΠ½ΠΎ Π΄Π΅Π»Π°Π΅Ρ‚, ΠΌΡ‹ ΡƒΠΆΠ΅ Π·Π½Π°Π΅ΠΌ.

Π‘ΠΎΡ…Ρ€Π°Π½ΠΈΠΌ всС исправлСнныС Ρ„Π°ΠΉΠ»Ρ‹ ΠΈ ΠΏΡ€ΠΎΠ²Π΅Ρ€ΠΈΠΌ поиск Π² дСйствии. Π’ΠΎΡ‚ Ρ‚Π΅ΠΏΠ΅Ρ€ΡŒ ΠΎΠ½ выглядит Π²ΠΏΠΎΠ»Π½Π΅ ΠΏΡ€ΠΎΡ„Π΅ΡΡΠΈΠΎΠ½Π°Π»ΡŒΠ½ΠΎ!..

Π§Ρ‚ΠΎ дальшС?

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

Π’ ΡΠ»Π΅Π΄ΡƒΡŽΡ‰Π΅ΠΉ, послСднСй, Π³Π»Π°Π²Π΅ ΠΌΡ‹ познакомимся с Π΅Ρ‰Π΅ ΠΎΠ΄Π½ΠΎΠΉ Π²ΠΎΠ·ΠΌΠΎΠΆΠ½ΠΎΡΡ‚ΡŒΡŽ HTML 5 β€” ΠΏΡ€ΠΎΠ³Ρ€Π°ΠΌΠΌΠΈΡ€ΡƒΠ΅ΠΌΠΎΠΉ Π³Ρ€Π°Ρ„ΠΈΠΊΠΎΠΉ. ΠœΡ‹ научимся Ρ€ΠΈΡΠΎΠ²Π°Ρ‚ΡŒ ΠΏΡ€ΠΎΠΈΠ·Π²ΠΎΠ»ΡŒΠ½Ρ‹Π΅ Ρ„ΠΈΠ³ΡƒΡ€Ρ‹ Π½Π° Web-страницС. А Π΅Ρ‰Π΅ ΠΌΡ‹ Π½Π°Π΄Π΅Π»ΠΈΠΌ наш Web-сайт графичСским Π»ΠΎΠ³ΠΎΡ‚ΠΈΠΏΠΎΠΌ.

ГЛАВА 22. ΠŸΡ€ΠΎΠ³Ρ€Π°ΠΌΠΌΠΈΡ€ΡƒΠ΅ΠΌΠ°Ρ Π³Ρ€Π°Ρ„ΠΈΠΊΠ° 

Π’ ΠΏΡ€Π΅Π΄Ρ‹Π΄ΡƒΡ‰Π΅ΠΉ Π³Π»Π°Π²Π΅ ΠΌΡ‹ познакомились со свободно ΠΏΠΎΠ·ΠΈΡ†ΠΈΠΎΠ½ΠΈΡ€ΡƒΠ΅ΠΌΡ‹ΠΌΠΈ элСмСнтами Web-страницы ΠΈ использовали ΠΈΡ…, Ρ‡Ρ‚ΠΎΠ±Ρ‹ ΡƒΠ»ΡƒΡ‡ΡˆΠΈΡ‚ΡŒ систСму поиска Π½Π° нашСм Web-сайтС. ΠŸΠΎΠ»ΡƒΡ‡ΠΈΠ»ΠΎΡΡŒ Π½Π΅ΠΏΠ»ΠΎΡ…ΠΎ, ΠΏΡ€Π°Π²Π΄Π°?

На этом ΠΌΡ‹ Π·Π°ΠΊΠΎΠ½Ρ‡ΠΈΠΌ с поиском ΠΈ ΠΎΠ±Ρ€Π°Ρ‚ΠΈΠΌ Π²Π½ΠΈΠΌΠ°Π½ΠΈΠ΅ Π½Π° Π·Π°Π³ΠΎΠ»ΠΎΠ²ΠΎΠΊ нашСго Web-сайта. Как-Ρ‚ΠΎ нСказисто ΠΎΠ½ выглядит β€” ΠΎΠ±Ρ‹Ρ‡Π½Ρ‹ΠΉ тСкст Π±Π΅Π· всяких изысков. И это Π² Ρ‚ΠΎ врСмя, ΠΊΠΎΠ³Π΄Π° Π±ΠΎΠ»ΡŒΡˆΠΈΠ½ΡΡ‚Π²ΠΎ Web-сайтов Ρ‰Π΅Π³ΠΎΠ»ΡΡŽΡ‚ ΡˆΠΈΠΊΠ°Ρ€Π½Ρ‹ΠΌΠΈ графичСскими Π»ΠΎΠ³ΠΎΡ‚ΠΈΠΏΠ°ΠΌΠΈ. ΠŸΠΎΡ‡Π΅ΠΌΡƒ Ρƒ нас Ρ‚Π°ΠΊΠΎΠ³ΠΎ Π½Π΅Ρ‚?

ΠŸΠΎΡ‚ΠΎΠΌΡƒ Ρ‡Ρ‚ΠΎ ΠΌΡ‹ этим Π΅Ρ‰Π΅ Π½Π΅ занимались. Π’ΠΎΠΎΠ±Ρ‰Π΅, ΡΠ΄Π΅Π»Π°Ρ‚ΡŒ графичСский Π»ΠΎΠ³ΠΎΡ‚ΠΈΠΏ Web-сайта ΠΏΡ€ΠΎΡ‰Π΅ простого β€” достаточно Π½Π°Ρ€ΠΈΡΠΎΠ²Π°Ρ‚ΡŒ Π΅Π³ΠΎ Π² ΠΊΠ°ΠΊΠΎΠΌ-Π»ΠΈΠ±ΠΎ графичСском Ρ€Π΅Π΄Π°ΠΊΡ‚ΠΎΡ€Π΅ ΠΈ ΡΠΎΡ…Ρ€Π°Π½ΠΈΡ‚ΡŒ Π² любом Ρ„ΠΎΡ€ΠΌΠ°Ρ‚Π΅, примСняСмом Π² Π˜Π½Ρ‚Π΅Ρ€Π½Π΅Ρ‚Π΅. А ΠΊΠ°ΠΊ ΠΏΠΎΠΌΠ΅ΡΡ‚ΠΈΡ‚ΡŒ Π½Π° Web-страницу графичСскоС ΠΈΠ·ΠΎΠ±Ρ€Π°ΠΆΠ΅Π½ΠΈΠ΅, ΠΌΡ‹ ΡƒΠΆΠ΅ Π·Π½Π°Π΅ΠΌ β€” ΠΈΠ·ΡƒΡ‡Π°Π»ΠΈ Π΅Ρ‰Π΅ Π² Π³Π»Π°Π²Π΅ 4.

БущСствуСт ΠΈ Π΄Ρ€ΡƒΠ³ΠΎΠΉ ΠΏΡƒΡ‚ΡŒ β€” Π·Π°Π΄Π΅ΠΉΡΡ‚Π²ΠΎΠ²Π°Ρ‚ΡŒ возмоТности ΠΏΡ€ΠΎΠ³Ρ€Π°ΠΌΠΌΠΈΡ€ΡƒΠ΅ΠΌΠΎΠΉ Π³Ρ€Π°Ρ„ΠΈΠΊΠΈ, ΠΏΡ€Π΅Π΄Π»Π°Π³Π°Π΅ΠΌΡ‹Π΅ HTML 5. Они ΠΏΠΎΠ·Π²ΠΎΠ»ΡΡŽΡ‚ Π½Π°Ρ€ΠΈΡΠΎΠ²Π°Ρ‚ΡŒ Π»ΡŽΠ±ΡƒΡŽ, Π΄Π°ΠΆΠ΅ вСсьма ΡΠ»ΠΎΠΆΠ½ΡƒΡŽ Ρ„ΠΈΠ³ΡƒΡ€Ρƒ ΠΏΡ€ΠΎΠ³Ρ€Π°ΠΌΠΌΠ½ΠΎ, ΠΈΠ· Web-сцСнария. ΠŸΡ€ΠΈΡ‡Π΅ΠΌ ΠΏΠΎΠ»ΡŒΠ·ΠΎΠ²Π°Ρ‚ΡŒΡΡ этими возмоТностями Π½Π΅ Ρ‚Π°ΠΊ ΠΈ слоТно β€” достаточно ΡƒΡΡΠ½ΠΈΡ‚ΡŒ ΠΏΠ°Ρ€Ρƒ ΠΊΠΎΠ½Ρ†Π΅ΠΏΡ†ΠΈΠΉ ΠΈ Π²Ρ‹ΡƒΡ‡ΠΈΡ‚ΡŒ нСсколько дСсятков ΠΌΠ΅Ρ‚ΠΎΠ΄ΠΎΠ².

Π”Π°Π²Π°ΠΉΡ‚Π΅ Ρ‚Π°ΠΊ ΠΈ сдСлаСм. Π’Π΅Π΄ΡŒ Ссли ΠΌΡ‹ взялись ΠΈΠ·ΡƒΡ‡Π°Ρ‚ΡŒ HTML 5, Ρ‚Π°ΠΊ ΡƒΠΆ Π±ΡƒΠ΄Π΅ΠΌ ΠΈΠ΄Ρ‚ΠΈ Π΄ΠΎ ΠΊΠΎΠ½Ρ†Π°.

Канва

НачнСм сразу с ΠΏΠ΅Ρ€Π²ΠΎΠΉ ΠΊΠΎΠ½Ρ†Π΅ΠΏΡ†ΠΈΠΈ, Π½Π° основС ΠΊΠΎΡ‚ΠΎΡ€ΠΎΠΉ Ρ€Π°Π±ΠΎΡ‚Π°Π΅Ρ‚ программируСмая Π³Ρ€Π°Ρ„ΠΈΠΊΠ° HTML 5 ΠΈ ΠΊΠΎΡ‚ΠΎΡ€ΡƒΡŽ Π½Π°ΠΌ Π½ΡƒΠΆΠ½ΠΎ ΡƒΡΡΠ½ΠΈΡ‚ΡŒ. ВсС рисованиС выполняСтся Π² особом элСмСнтС Web-страницы, Π΅Ρ‰Π΅ Π½Π°ΠΌ Π½Π΅ Π²ΡΡ‚Ρ€Π΅Ρ‡Π°Π²ΡˆΠ΅ΠΌΡΡ, β€” Π² ΠΊΠ°Π½Π²Π΅ (Π΅Π΅ Π΅Ρ‰Π΅ Π½Π°Π·Ρ‹Π²Π°ΡŽΡ‚ холстом). Π’ Π΄Ρ€ΡƒΠ³ΠΈΡ… элСмСнтах (Π°Π±Π·Π°Ρ†Π°Ρ…, Π·Π°Π³ΠΎΠ»ΠΎΠ²ΠΊΠ°Ρ…, Ρ‚Π°Π±Π»ΠΈΡ†Π°Ρ…, графичСских изобраТСниях ΠΈ ΠΏΡ€.) ΠΏΡ€ΠΎΠ³Ρ€Π°ΠΌΠΌΠ½ΠΎΠ΅ рисованиС Π½Π΅ Ρ€Π°Π±ΠΎΡ‚Π°Π΅Ρ‚.

ΠšΠ°Π½Π²Ρƒ ΡΠΎΠ·Π΄Π°ΡŽΡ‚ с ΠΏΠΎΠΌΠΎΡ‰ΡŒΡŽ ΠΏΠ°Ρ€Π½ΠΎΠ³ΠΎ Ρ‚Π΅Π³Π° <CANVAS>:

<CANVAS ID="<имя>" [WIDTH="<ΡˆΠΈΡ€ΠΈΠ½Π°>"] [HEIGHT="<высота>"]></CANVAS>

ΠœΡ‹ ΡƒΠΆΠ΅ Π·Π½Π°Π΅ΠΌ, Ρ‡Ρ‚ΠΎ рисованиС Π² ΠΊΠ°Π½Π²Π΅ выполняСтся ΠΏΡ€ΠΎΠ³Ρ€Π°ΠΌΠΌΠ½ΠΎ, Π² Web-сцСнарии. А ΠΏΠ΅Ρ€Π΅Π΄ Ρ‚Π΅ΠΌ ΠΊΠ°ΠΊ Ρ‡Ρ‚ΠΎ-Ρ‚ΠΎ Π½Π°Ρ€ΠΈΡΠΎΠ²Π°Ρ‚ΡŒ, Π½Π°ΠΌ придСтся ΠΏΠΎΠ»ΡƒΡ‡ΠΈΡ‚ΡŒ доступ ΠΊ ΠΊΠ°Π½Π²Π΅. Π‘Π΄Π΅Π»Π°Ρ‚ΡŒ это ΠΏΡ€ΠΎΡ‰Π΅ всСго Ρ‡Π΅Ρ€Π΅Π· имя, Π·Π°Π΄Π°Π½Π½ΠΎΠ΅ Π°Ρ‚Ρ€ΠΈΠ±ΡƒΡ‚ΠΎΠΌ Ρ‚Π΅Π³Π° ID. ИмСнно поэтому Π΄Π°Π½Π½Ρ‹ΠΉ Π°Ρ‚Ρ€ΠΈΠ±ΡƒΡ‚ Ρ‚Π΅Π³Π° ΠΏΠΎΠΌΠ΅Ρ‡Π΅Π½ здСсь ΠΊΠ°ΠΊ ΠΎΠ±ΡΠ·Π°Ρ‚Π΅Π»ΡŒΠ½Ρ‹ΠΉ.

ΠΠ΅ΠΎΠ±ΡΠ·Π°Ρ‚Π΅Π»ΡŒΠ½Ρ‹Π΅ Π°Ρ‚Ρ€ΠΈΠ±ΡƒΡ‚Ρ‹ Ρ‚Π΅Π³Π° WIDTH ΠΈ HEIGHT Π·Π°Π΄Π°ΡŽΡ‚, соотвСтствСнно, ΡˆΠΈΡ€ΠΈΠ½Ρƒ ΠΈ высоту ΠΊΠ°Π½Π²Ρ‹ Π² пиксСлах (ΠΏΠΎ ΡƒΠΌΠΎΠ»Ρ‡Π°Π½ΠΈΡŽ 300 150 пиксСлов).

Π’ΠΠ˜ΠœΠΠΠ˜Π•!

Π—Π°Π΄Π°Π²Π°Ρ‚ΡŒ Ρ€Π°Π·ΠΌΠ΅Ρ€Ρ‹ ΠΊΠ°Π½Π²Ρ‹ с ΠΏΠΎΠΌΠΎΡ‰ΡŒΡŽ стилСй CSS Π½Π΅ рСкомСндуСтся.

Π’ΠΎΡ‚ HTML-ΠΊΠΎΠ΄, ΡΠΎΠ·Π΄Π°ΡŽΡ‰ΠΈΠΉ Π½Π° страницС ΠΊΠ°Π½Π²Ρƒ cnv Ρ€Π°Π·ΠΌΠ΅Ρ€ΠΎΠΌ 400 300 пиксСлов:

<CANVAS ID="cnv" WIDTH="400" HEIGHT="300"></CANVAS>

Канва прСдставляСтся ΠΊΠ°ΠΊ экзСмпляр ΠΎΠ±ΡŠΠ΅ΠΊΡ‚Π° Web-обозрСватСля HTMLCanvasElement, ΠΏΡ€ΠΎΠΈΠ·Π²ΠΎΠ΄Π½Ρ‹ΠΉ ΠΎΡ‚ ΠΎΠ±ΡŠΠ΅ΠΊΡ‚Π° HTMLElement. Для нас Π±ΡƒΠ΄Π΅Ρ‚ ΠΏΠΎΠ»Π΅Π·Π΅Π½ Ρ‚ΠΎΠ»ΡŒΠΊΠΎ СдинствСнный ΠΌΠ΅Ρ‚ΠΎΠ΄ этого ΠΎΠ±ΡŠΠ΅ΠΊΡ‚Π°, ΠΊΠΎΡ‚ΠΎΡ€Ρ‹ΠΉ ΠΌΡ‹ скоро рассмотрим.

ΠšΠΎΠ½Ρ‚Π΅ΠΊΡΡ‚ рисования

РисованиС Π½Π° ΠΊΠ°Π½Π²Π΅ выполняСтся с ΠΏΠΎΠΌΠΎΡ‰ΡŒΡŽ особых свойств ΠΈ ΠΌΠ΅Ρ‚ΠΎΠ΄ΠΎΠ² ΠΎΠ±ΡŠΠ΅ΠΊΡ‚Π°β€¦ Π½Π΅Ρ‚, Π½Π΅ HTMLCanvasElement, Π° CanvasRenderingContext2D. Π­Ρ‚ΠΎΡ‚ ΠΎΠ±ΡŠΠ΅ΠΊΡ‚ прСдставляСт Ρ‚Π°ΠΊ Π½Π°Π·Ρ‹Π²Π°Π΅ΠΌΡ‹ΠΉ контСкст рисования, ΠΊΠΎΡ‚ΠΎΡ€Ρ‹ΠΉ ΠΌΠΎΠΆΠ½ΠΎ Ρ€Π°ΡΡΠΌΠ°Ρ‚Ρ€ΠΈΠ²Π°Ρ‚ΡŒ ΠΊΠ°ΠΊ Π½Π°Π±ΠΎΡ€ инструмСнтов, ΠΈΡΠΏΠΎΠ»ΡŒΠ·ΡƒΠ΅ΠΌΡ‹ΠΉ для рисования Π½Π° Π΄Π°Π½Π½ΠΎΠΉ ΠΊΠ°Π½Π²Π΅.