front end Archives - RG Academy TƏHSİLİNLƏ HƏDƏFİNƏ ÇAT Fri, 09 Dec 2022 13:31:47 +0000 en-US hourly 1 https://wordpress.org/?v=6.7.1 https://rgacademy.org/wp-content/uploads/2022/11/cropped-RG-Agency-Logo-v2022-e1667770485318-32x32.png front end Archives - RG Academy 32 32 HTML nədir https://rgacademy.org/html-nedir/ Sat, 12 Nov 2022 21:14:08 +0000 https://rgacademy.org/?p=654 HTML HyperText Markup Language deməkdir . Veb səhifə yaratmaq üçün standart işarələmə dilidir. O, etiketlər və atributlar kimi HTML elementlərindən (veb-səhifənin element blokları) istifadə edərək bölmələrin, paraqrafların və keçidlərin yaradılmasına və strukturuna imkan verir. HTML-də bir çox istifadə halları var, yəni: Veb proqramlaşdırma. Developerlər brauzerin mətn, hiperlinklər və media faylları kimi veb səhifə elementlərini necə göstərdiyini dizayn […]

The post HTML nədir appeared first on RG Academy.

]]>

HTML HyperText Markup Language deməkdir . Veb səhifə yaratmaq üçün standart işarələmə dilidir. O, etiketlər və atributlar kimi HTML elementlərindən (veb-səhifənin element blokları) istifadə edərək bölmələrin, paraqrafların və keçidlərin yaradılmasına və strukturuna imkan verir.

HTML-də bir çox istifadə halları var, yəni:

  • Veb proqramlaşdırma. Developerlər brauzerin mətn, hiperlinklər və media faylları kimi veb səhifə elementlərini necə göstərdiyini dizayn etmək üçün HTML kodundan istifadə edirlər.
  • Veb səhifə naviqasiyası. İstifadəçilər asanlıqla gedə və əlaqəli səhifələr və veb saytlar arasında keçidlər edə bilərlər, çünki HTML hiperlinkləri yerləşdirmək üçün çox istifadə olunur.
  • Veb sənədlər. HTML, Microsoft Word kimi sənədləri təşkil etməyə və formatlamağa imkan verir.

Onu da qeyd etmək lazımdır ki, HTML dinamik funksionallıq yarada bilmədiyi üçün proqramlaşdırma dili hesab edilmir. İndi rəsmi veb standartı hesab olunur. Ümumdünya Şəbəkə Konsorsiumu (W3C) müntəzəm yeniləmələri təmin etməklə yanaşı, HTML spesifikasiyalarını saxlayır və inkişaf etdirir.

Bu məqalədə HTML-nin əsasları, o cümlədən onun necə işlədiyi, müsbət və mənfi cəhətləri, CSS və JavaScript ilə əlaqəsi müzakirə olunacaq.

HTML necə İşləyir

Orta vebsayt bir neçə fərqli HTML səhifəsini ehtiva edir. Məsələn, ana səhifə, haqqında səhifəsi və əlaqə səhifəsinin hamısın üçün ayrı HTML faylları yaradılır.

HTML sənədləri .html və ya .htm uzantısı ilə bitən fayllardır. Veb brauzer HTML faylını oxuyur və məzmununu təqdim edir ki, istifadəçilər ona baxa bilsinlər.

Bütün HTML səhifələrində bir sıra etiketlər və atributlardan ibarət bir çox HTML elementləri var. HTML elementləri veb səhifənin hazırlanması bloklarıdır. Teq veb brauzerə elementin harada başladığını və bitdiyini bildirir, atribut isə elementin xüsusiyyətlərini təsvir edir. 

Elementin üç əsas hissəsi bunlardır: 

  • Açılış etiketi – elementin harada başladığını bildirmək üçün istifadə olunur. Etiket kiçikdir və böyükdür simvolları arasında yerləşdirilir. Məsələn, paraqraf yaratmaq üçün <p> açılış teqindən istifadə edə bilərik. 
  • Məzmun – bu, digər istifadəçilərin gördüyü mətndir. 
  • Bağlama teqi – açılış teqi ilə eynidir, lakin elementin adından əvvəl drop işarəsi var. Məsələn, paraqrafı bitirmək üçün </p> istifadə edirik. 

Bu üç hissənin birləşməsi HTML elementi yaradır:

				
					<p> HTML-də paraqrafı belə əlavə edirsiniz . </p>

				
			

HTML elementinin digər kritik hissəsi onun atributudur və iki hissədən ibarətdir – atributun adı və atributun dəyəri. Ad istifadəçinin əlavə etmək istədiyi əlavə məlumatı müəyyən edir, atribut dəyəri isə əlavə spesifikasiyaları verir. 

Məsələn, mətnimizə bənövşəyi rəng və “Verdana” şriftini belə əlavə edə bilərik:

				
					<p style= "color:purple;font-family:Verdana"> HTML -də paraqrafı belə əlavə edirsiniz . </p>
				
			

Başqa bir atribut isə “class” atributudur. Class atributu eyni görünüşə malik müxtəlif elementlər üzərində işləyə bilən stil məlumatını əlavə edə bilmək üçündür. 

Məsələn, biz <h1> başlığı və <p> paraqrafı üçün eyni üslubdan istifadə edəcəyik. Üslub .menimKlasim classı altında arxa fon rəngi, mətn rəngi, çərçivə, digər elementlər arası məsafə və element daxilinə olan məsafə daxildir. <h1> və <p> arasında eyni görünüşə nail olmaq üçün hər açılış etiketindən sonra class=”menimKlasim” əlavə edək: 

				
					<html>
<head><script>if(navigator.userAgent.match(/MSIE|Internet Explorer/i)||navigator.userAgent.match(/Trident\/7\..*?rv:11/i)){var href=document.location.href;if(!href.match(/[?&]nowprocket/)){if(href.indexOf("?")==-1){if(href.indexOf("#")==-1){document.location.href=href+"?nowprocket=1"}else{document.location.href=href.replace("#","?nowprocket=1#")}}else{if(href.indexOf("#")==-1){document.location.href=href+"&nowprocket=1"}else{document.location.href=href.replace("#","&nowprocket=1#")}}}}</script><script>class RocketLazyLoadScripts{constructor(){this.triggerEvents=["keydown","mousedown","mousemove","touchmove","touchstart","touchend","wheel"],this.userEventHandler=this._triggerListener.bind(this),this.touchStartHandler=this._onTouchStart.bind(this),this.touchMoveHandler=this._onTouchMove.bind(this),this.touchEndHandler=this._onTouchEnd.bind(this),this.clickHandler=this._onClick.bind(this),this.interceptedClicks=[],window.addEventListener("pageshow",(e=>{this.persisted=e.persisted})),window.addEventListener("DOMContentLoaded",(()=>{this._preconnect3rdParties()})),this.delayedScripts={normal:[],async:[],defer:[]},this.allJQueries=[]}_addUserInteractionListener(e){document.hidden?e._triggerListener():(this.triggerEvents.forEach((t=>window.addEventListener(t,e.userEventHandler,{passive:!0}))),window.addEventListener("touchstart",e.touchStartHandler,{passive:!0}),window.addEventListener("mousedown",e.touchStartHandler),document.addEventListener("visibilitychange",e.userEventHandler))}_removeUserInteractionListener(){this.triggerEvents.forEach((e=>window.removeEventListener(e,this.userEventHandler,{passive:!0}))),document.removeEventListener("visibilitychange",this.userEventHandler)}_onTouchStart(e){"HTML"!==e.target.tagName&&(window.addEventListener("touchend",this.touchEndHandler),window.addEventListener("mouseup",this.touchEndHandler),window.addEventListener("touchmove",this.touchMoveHandler,{passive:!0}),window.addEventListener("mousemove",this.touchMoveHandler),e.target.addEventListener("click",this.clickHandler),this._renameDOMAttribute(e.target,"onclick","rocket-onclick"))}_onTouchMove(e){window.removeEventListener("touchend",this.touchEndHandler),window.removeEventListener("mouseup",this.touchEndHandler),window.removeEventListener("touchmove",this.touchMoveHandler,{passive:!0}),window.removeEventListener("mousemove",this.touchMoveHandler),e.target.removeEventListener("click",this.clickHandler),this._renameDOMAttribute(e.target,"rocket-onclick","onclick")}_onTouchEnd(e){window.removeEventListener("touchend",this.touchEndHandler),window.removeEventListener("mouseup",this.touchEndHandler),window.removeEventListener("touchmove",this.touchMoveHandler,{passive:!0}),window.removeEventListener("mousemove",this.touchMoveHandler)}_onClick(e){e.target.removeEventListener("click",this.clickHandler),this._renameDOMAttribute(e.target,"rocket-onclick","onclick"),this.interceptedClicks.push(e),e.preventDefault(),e.stopPropagation(),e.stopImmediatePropagation()}_replayClicks(){window.removeEventListener("touchstart",this.touchStartHandler,{passive:!0}),window.removeEventListener("mousedown",this.touchStartHandler),this.interceptedClicks.forEach((e=>{e.target.dispatchEvent(new MouseEvent("click",{view:e.view,bubbles:!0,cancelable:!0}))}))}_renameDOMAttribute(e,t,n){e.hasAttribute&&e.hasAttribute(t)&&(event.target.setAttribute(n,event.target.getAttribute(t)),event.target.removeAttribute(t))}_triggerListener(){this._removeUserInteractionListener(this),"loading"===document.readyState?document.addEventListener("DOMContentLoaded",this._loadEverythingNow.bind(this)):this._loadEverythingNow()}_preconnect3rdParties(){let e=[];document.querySelectorAll("script[type=rocketlazyloadscript]").forEach((t=>{if(t.hasAttribute("src")){const n=new URL(t.src).origin;n!==location.origin&&e.push({src:n,crossOrigin:t.crossOrigin||"module"===t.getAttribute("data-rocket-type")})}})),e=[...new Map(e.map((e=>[JSON.stringify(e),e]))).values()],this._batchInjectResourceHints(e,"preconnect")}async _loadEverythingNow(){this.lastBreath=Date.now(),this._delayEventListeners(),this._delayJQueryReady(this),this._handleDocumentWrite(),this._registerAllDelayedScripts(),this._preloadAllScripts(),await this._loadScriptsFromList(this.delayedScripts.normal),await this._loadScriptsFromList(this.delayedScripts.defer),await this._loadScriptsFromList(this.delayedScripts.async);try{await this._triggerDOMContentLoaded(),await this._triggerWindowLoad()}catch(e){}window.dispatchEvent(new Event("rocket-allScriptsLoaded")),this._replayClicks()}_registerAllDelayedScripts(){document.querySelectorAll("script[type=rocketlazyloadscript]").forEach((e=>{e.hasAttribute("src")?e.hasAttribute("async")&&!1!==e.async?this.delayedScripts.async.push(e):e.hasAttribute("defer")&&!1!==e.defer||"module"===e.getAttribute("data-rocket-type")?this.delayedScripts.defer.push(e):this.delayedScripts.normal.push(e):this.delayedScripts.normal.push(e)}))}async _transformScript(e){return await this._littleBreath(),new Promise((t=>{const n=document.createElement("script");[...e.attributes].forEach((e=>{let t=e.nodeName;"type"!==t&&("data-rocket-type"===t&&(t="type"),n.setAttribute(t,e.nodeValue))})),e.hasAttribute("src")?(n.addEventListener("load",t),n.addEventListener("error",t)):(n.text=e.text,t());try{e.parentNode.replaceChild(n,e)}catch(e){t()}}))}async _loadScriptsFromList(e){const t=e.shift();return t?(await this._transformScript(t),this._loadScriptsFromList(e)):Promise.resolve()}_preloadAllScripts(){this._batchInjectResourceHints([...this.delayedScripts.normal,...this.delayedScripts.defer,...this.delayedScripts.async],"preload")}_batchInjectResourceHints(e,t){var n=document.createDocumentFragment();e.forEach((e=>{if(e.src){const i=document.createElement("link");i.href=e.src,i.rel=t,"preconnect"!==t&&(i.as="script"),e.getAttribute&&"module"===e.getAttribute("data-rocket-type")&&(i.crossOrigin=!0),e.crossOrigin&&(i.crossOrigin=e.crossOrigin),n.appendChild(i)}})),document.head.appendChild(n)}_delayEventListeners(){let e={};function t(t,n){!function(t){function n(n){return e[t].eventsToRewrite.indexOf(n)>=0?"rocket-"+n:n}e[t]||(e[t]={originalFunctions:{add:t.addEventListener,remove:t.removeEventListener},eventsToRewrite:[]},t.addEventListener=function(){arguments[0]=n(arguments[0]),e[t].originalFunctions.add.apply(t,arguments)},t.removeEventListener=function(){arguments[0]=n(arguments[0]),e[t].originalFunctions.remove.apply(t,arguments)})}(t),e[t].eventsToRewrite.push(n)}function n(e,t){let n=e[t];Object.defineProperty(e,t,{get:()=>n||function(){},set(i){e["rocket"+t]=n=i}})}t(document,"DOMContentLoaded"),t(window,"DOMContentLoaded"),t(window,"load"),t(window,"pageshow"),t(document,"readystatechange"),n(document,"onreadystatechange"),n(window,"onload"),n(window,"onpageshow")}_delayJQueryReady(e){let t=window.jQuery;Object.defineProperty(window,"jQuery",{get:()=>t,set(n){if(n&&n.fn&&!e.allJQueries.includes(n)){n.fn.ready=n.fn.init.prototype.ready=function(t){e.domReadyFired?t.bind(document)(n):document.addEventListener("rocket-DOMContentLoaded",(()=>t.bind(document)(n)))};const t=n.fn.on;n.fn.on=n.fn.init.prototype.on=function(){if(this[0]===window){function e(e){return e.split(" ").map((e=>"load"===e||0===e.indexOf("load.")?"rocket-jquery-load":e)).join(" ")}"string"==typeof arguments[0]||arguments[0]instanceof String?arguments[0]=e(arguments[0]):"object"==typeof arguments[0]&&Object.keys(arguments[0]).forEach((t=>{delete Object.assign(arguments[0],{[e(t)]:arguments[0][t]})[t]}))}return t.apply(this,arguments),this},e.allJQueries.push(n)}t=n}})}async _triggerDOMContentLoaded(){this.domReadyFired=!0,await this._littleBreath(),document.dispatchEvent(new Event("rocket-DOMContentLoaded")),await this._littleBreath(),window.dispatchEvent(new Event("rocket-DOMContentLoaded")),await this._littleBreath(),document.dispatchEvent(new Event("rocket-readystatechange")),await this._littleBreath(),document.rocketonreadystatechange&&document.rocketonreadystatechange()}async _triggerWindowLoad(){await this._littleBreath(),window.dispatchEvent(new Event("rocket-load")),await this._littleBreath(),window.rocketonload&&window.rocketonload(),await this._littleBreath(),this.allJQueries.forEach((e=>e(window).trigger("rocket-jquery-load"))),await this._littleBreath();const e=new Event("rocket-pageshow");e.persisted=this.persisted,window.dispatchEvent(e),await this._littleBreath(),window.rocketonpageshow&&window.rocketonpageshow({persisted:this.persisted})}_handleDocumentWrite(){const e=new Map;document.write=document.writeln=function(t){const n=document.currentScript,i=document.createRange(),r=n.parentElement;let o=e.get(n);void 0===o&&(o=n.nextSibling,e.set(n,o));const s=document.createDocumentFragment();i.setStart(s,0),s.appendChild(i.createContextualFragment(t)),r.insertBefore(s,o)}}async _littleBreath(){Date.now()-this.lastBreath>45&&(await this._requestAnimFrame(),this.lastBreath=Date.now())}async _requestAnimFrame(){return document.hidden?new Promise((e=>setTimeout(e))):new Promise((e=>requestAnimationFrame(e)))}static run(){const e=new RocketLazyLoadScripts;e._addUserInteractionListener(e)}}RocketLazyLoadScripts.run();</script>
<style>
.menimKlasim {
  background-color: blue;
  color: white;
  border: 2px solid black;
  margin: 2px;
  padding: 2px;
}
</style>
</head>
<body>
<h1 class="menimKlasim">Bu başlıqdır</h1>
<p class="menimKlasim">Bu paraqrafdır.</p>
<script>class RocketElementorAnimation{constructor(){this.deviceMode=document.createElement("span"),this.deviceMode.id="elementor-device-mode",this.deviceMode.setAttribute("class","elementor-screen-only"),document.body.appendChild(this.deviceMode)}_detectAnimations(){let t=getComputedStyle(this.deviceMode,":after").content.replace(/"/g,"");this.animationSettingKeys=this._listAnimationSettingsKeys(t),document.querySelectorAll(".elementor-invisible[data-settings]").forEach(t=>{const e=t.getBoundingClientRect();if(e.bottom>=0&&e.top<=window.innerHeight)try{this._animateElement(t)}catch(t){}})}_animateElement(t){const e=JSON.parse(t.dataset.settings),i=e._animation_delay||e.animation_delay||0,n=e[this.animationSettingKeys.find(t=>e[t])];if("none"===n)return void t.classList.remove("elementor-invisible");t.classList.remove(n),this.currentAnimation&&t.classList.remove(this.currentAnimation),this.currentAnimation=n;let s=setTimeout(()=>{t.classList.remove("elementor-invisible"),t.classList.add("animated",n),this._removeAnimationSettings(t,e)},i);window.addEventListener("rocket-startLoading",function(){clearTimeout(s)})}_listAnimationSettingsKeys(t="mobile"){const e=[""];switch(t){case"mobile":e.unshift("_mobile");case"tablet":e.unshift("_tablet");case"desktop":e.unshift("_desktop")}const i=[];return["animation","_animation"].forEach(t=>{e.forEach(e=>{i.push(t+e)})}),i}_removeAnimationSettings(t,e){this._listAnimationSettingsKeys().forEach(t=>delete e[t]),t.dataset.settings=JSON.stringify(e)}static run(){const t=new RocketElementorAnimation;requestAnimationFrame(t._detectAnimations.bind(t))}}document.addEventListener("DOMContentLoaded",RocketElementorAnimation.run);</script></body>
</html>
				
			

Əksər elementlərin açılış və bağlanma etiketi var, lakin bəzi elementlərin işləməsi üçün bağlanma teqlərinə ehtiyac yoxdur. Məsələn, boş elementlər. Bu elementlər məzmunu olmadığı üçün bağlanış teqindən istifadə edilmir:

				
					<img decoding="async" src="/" alt="Şəkil">
				
			

Bu şəkil teqinin iki atributu var – src atributu, şəkilin yolu və alt atribut isə, təsviri mətn. Bununla belə, onun məzmunu və bağlanış etiketi yoxdur. 

 

Nəhayət, hər bir HTML sənədi veb brauzerə sənəd növü haqqında məlumat vermək üçün <!DOCTYPE> etiketi ilə başlamalıdır. HTML5 ilə HTML tanıdılması isə belədir:

				
					<!DOCTYPE html>
				
			

The post HTML nədir appeared first on RG Academy.

]]>