12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688168916901691169216931694169516961697169816991700170117021703170417051706170717081709171017111712171317141715171617171718171917201721172217231724172517261727172817291730173117321733173417351736173717381739174017411742174317441745174617471748174917501751175217531754175517561757175817591760176117621763176417651766176717681769177017711772177317741775177617771778177917801781178217831784178517861787178817891790179117921793179417951796179717981799180018011802180318041805180618071808180918101811181218131814181518161817181818191820182118221823182418251826182718281829183018311832183318341835183618371838183918401841184218431844 |
- <!DOCTYPE html>
- <html lang="es">
- <head>
- <meta charset="utf-8">
- <meta name="generator" content="gendoc 1.0.0: https://gitlab.com/bztsrc/gendoc">
- <meta name="viewport" content="width=device-width, initial-scale=1.0">
- <title>Aprendiendo PHP, MySQL y JavaScript</title>
- <style rel="logic">*{box-sizing:border-box;font-family:inherit;}body {background:rgba(0,0,0,0.05);font-weight:400;font-size:16px;}hr{display:block;height:1px;border:0;border-top:1px solid #e1e4e5;margin:26px 0;padding:0;border-top:1px solid;}br:after,br:before{display:table;content:""}br{clear:both;}h1,h2,h3,h4,h5,h6{clear:both;margin:0px 0px 20px 0px;padding-top:4px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;}p{margin:0 0 24px}a{cursor:pointer;}h1{font-size:175%}h2{font-size:150%}h3{font-size:125%}h4{font-size:115%}h5{font-size:110%}h6{font-size:100%}pre,samp,code,var,kbd{font-family:Monaco,Consolas,Liberation Mono,Courier,monospace;font-variant-ligatures:none;}pre,code{display:block;overflow:auto;white-space:pre;font-size:14px;line-height:16px!important;}pre{padding:12px;margin:0px;}code{padding:0 0 12px 0;margin:12px 12px 0px 2px;background:url(data:type/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAAgCAYAAADT5RIaAAAAFklEQVQI12NgYGDgZWJgYGCgDkFtAAAWnAAsyj4TxgAAAABJRU5ErkJggg==) 0 0 repeat;}.lineno{display:block;padding:0px 4px 0px 4px;margin:12px 0px 0px 0px;opacity:.4;text-align:right;float:left;white-space:pre;font-size:12px;line-height:16px!important;}pre .hl_b,samp .hl_b,code .hl_b{display:block;}blockquote{margin:0px;padding:12px;}blockquote>span:first-child::before{content:url(data:type/png;base64,iVBORw0KGgoAAAANSUhEUgAAADAAAAAgCAYAAABU1PscAAABRElEQVRYw+3WTytEURjH8c/4l1JTpKxsyEbYWFkpG+UVKOWFeAts7eytbJSysLLVxIKNFAslwhSlUQabUdM0xm0e967Ot+7inPN8z+13z73nXBKJRCIRoJSxbggrmMMInlHBIWoF+KEAQ9jAaJuxe2zhJUe/Iz0ZahZ/uTmMYT1nPxxg/I/xWQzn6IcD1IIha//wkEIBKhlq+nP0wwHOsYuvDjWvOfod6c1Yd9O4ZjDQZvwAbzn6oRVofpKbqLf0P+GxAD8cAO7w0NJ3WqAfDlBCuan9gaMC/XCA+cbJ+sMRqgX6oQCTWGtqX2O/QL8tfRlqyljGUlPgW2y3+SDz8Lv6mRvEQmPbm25ZqQvs/LHtRf3wCkxgtaWvij2cZJg36ocD/Pw91nGJY5zhM+O8UT/8Ck01TswrvHcxb9RPJBKJRDF8AyNbWk4WFTIzAAAAAElFTkSuQmCC);float:left;vertical-align:top;}.ui1,.ui2,.ui3,.ui4,.ui5,.ui6{display:inline-block;height:24px!important;line-height:24px!important;padding:0px 4px;margin:-2px 0px -2px;}kbd{display:inline-block;font-weight:700;border:1px solid #888;height:24px!important;padding:0px 4px;margin:-2px 0px -2px;border-radius:4px;background-image:linear-gradient(#ddd 0%,#eee 10%,#bbb 10%,#ccc 30%,#fff 85%,#eee 85%,#888 100%);}.mouseleft,.mouseright,.mousewheel{display:inline-block;min-width:16px;height:24px!important;padding:0px;margin:-2px 0px 0px 0px;vertical-align:middle;}.mouseleft::before{content:url(data:type/png;base64,iVBORw0KGgoAAAANSUhEUgAAABAAAAAYCAMAAADEfo0+AAAAe1BMVEUAAACoqKj9/f2zs7O1tbWRkZGlpaWsrKybm5u2traNjY2Wlpanp6empqaYmJiPj4+3t7f5+fmjo6P19fXu7u6ZmZnx8fHi4uLm5ube3t7q6uqwsLC0tLS7u7u4uLi/v7/W1tbDw8PLy8vPz8/T09Pa2trHx8eIiIhERkShhqFGAAAAAXRSTlMAQObYZgAAAI5JREFUGNNV0EcCwjAMRFEB6R2DKSGQUBLp/idEjsG23m7+cgAMIsJWwR8Z235pumDTnkUbv+lg7CIfTqvSbTquxsGFfjWXLlwsdOFs+XC1EHAWOEwCh4/A4S1weAkcFoHDU0CI8zGQx1Cpe0BVAO0j0PIfiR4cnZjLdHP7abQ9VRVZnaZ1VvjfO42o7edfH3EoHZS6XE4AAAAASUVORK5CYII=);}.mouseright::before{content:url(data:type/png;base64,iVBORw0KGgoAAAANSUhEUgAAABAAAAAYCAMAAADEfo0+AAAAe1BMVEUAAACoqKj9/f2zs7O1tbWRkZGlpaWsrKybm5u2traNjY2Wlpanp6empqaYmJiPj4+3t7f5+fmjo6P19fXu7u6ZmZnx8fHi4uLm5ube3t7q6uqwsLC0tLS7u7u4uLi/v7/W1tbDw8PLy8vPz8/T09Pa2trHx8eIiIhERkShhqFGAAAAAXRSTlMAQObYZgAAAI9JREFUGNNV0NkWgjAMRdGozFOxWgdEcYLk/7/Q0EpL9tNd5/ECzLRCIoJF20zdlsinTbRn5Eu0O8zIl/Jk+dAPR4uWUo6d5QNenBDOTghXJ4RRQMCnwOErcPgIHN4Ch0ng8BIQ4nxYyWOo9H1FVwDqsaL4j8T0nknmy0xz+2uMO1UXWZ2mdVbo8LtBNK2dP/2+KB2shyfVAAAAAElFTkSuQmCC);}.mousewheel::before{content:url(data:type/png;base64,iVBORw0KGgoAAAANSUhEUgAAABAAAAAYCAMAAADEfo0+AAAAe1BMVEUAAACzs7OoqKisrKyRkZGlpaX9/f22trabm5uNjY2mpqanp6ePj4+1tbWYmJi3t7eWlpajo6OZmZmwsLD5+fnu7u7x8fHi4uLW1tbm5ube3t7T09Pq6ur19fW4uLi7u7u0tLTa2trPz8+/v7/Dw8PLy8vHx8eIiIhERkS4354xAAAAAXRSTlMAQObYZgAAAKdJREFUGNNV0NkagiAUhdHjPAECzWWlWdL7P2Fno/nJumHzXx4iMMI5YeivVVOX592k2vkfy/1CxvjL6L6KJAd9ZF+GVxP144Eh4B170kPHEPAOmtwFEPxw5E6A4AeHKyD4wWEABD84nAHBDw43QPCDwyvA4RPgMAU4vAOO0mLcKFJqzHPDNETisSH4HpntVzbDyazaLZSdj2qqsk6Suqw2d7fO2fnmP7kAJW9a/HbiAAAAAElFTkSuQmCC);}footer{width:100%;padding:0 3.236em;}footer p{opacity:0.6;}footer small{opacity:0.5;}footer a{text-decoration:none;color:inherit;}footer a:hover{text-decoration:underline;}dl{margin:0 0 24px 0;padding:0px;}dt{font-weight:700;margin-bottom:12px;}dd{margin:0 0 12px 24px;}.table table{margin:0px;border-collapse:collapse;border-spacing:0;empty-cells:show;border:1px solid;width:100%;}th{font-weight:700;padding:8px 16px;overflow:visible;vertical-align:middle;white-space:nowrap;border:1px solid;}th.wide{width:100%;}td{padding:8px 16px;overflow:visible;vertical-align:middle;font-size:90%;border:1px solid;}td.right{text-align:right;}table.grid{margin:0px;padding:0px;border:none!important;background:none!important;border-spacing:0;border:0px!important;empty-cells:show;width:100%;}table.grid tr, table.grid td{margin:0px;padding:0px;overflow:hidden;vertical-align:top;background:none!important;border:0px!important;font-size:90%;}div.frame{position:absolute;width:100%;min-height:100%;margin:0px;padding:0px;max-width:1100px;top:0px;left:0px;}#_m{margin-left:300px;min-height:100%;}div.title{display:block;width:300px;padding-top:.809em;padding-bottom:.809em;margin-bottom:.809em;text-align:center;font-weight:700;}div.title>a{padding:4px 6px;margin-bottom:.809em;font-size:150%;}div.title>a:hover{background:transparent;}div.title>a>img{max-width:280px;border:0px;padding:0px;margin:0px;}div.title input{display:none;width:270px;border-radius:50px;padding:6px 12px;font-size:80%;box-shadow:inset 0 1px 3px #ddd;transition:border .3s linear;}div.title input:required:invalid{background:#fcfcfc url() no-repeat 10px 50%;}div.title input:focus{background:#fcfcfc!important;}div.version{margin-top:.4045em;margin-bottom:.809em;font-size:90%;}nav.side {display:block;position:fixed;top:0;bottom:0;left:0;width:300px;overflow-x:hidden;overflow-y:hidden;min-height:100%;font-weight:400;z-index:999;}nav.mobile {display:none;font-weight:bold;padding:.4045em .809em;position:relative;line-height:50px;text-align:center;font-size:100%;*zoom:1;}nav a{color:inherit;text-decoration:none;display:block;}nav.side>div{position:relative;overflow-x:hidden;overflow-y:scroll;width:320px;height:100%;padding-bottom:64px;}div.nav p{height:32px;line-height:32px;padding:0 1.618em;margin:12px 0px 0px 0px;font-weight:700;text-transform:uppercase;font-size:85%;white-space:nowrap;-webkit-font-smoothing:antialiased}div.nav li>.current,div.nav li>ul{display:none;}div.nav li>a,div.nav li>label{display:block;}div.nav a,div.nav ul>li>label,div.nav ul>li>.current{width:300px;line-height:18px;padding:0.4045em 1.618em;}div.nav a,div.nav ul>li>label{cursor:pointer;}div.nav .current{font-weight:700;border-top:1px solid;border-bottom:1px solid #c9c9c9;}div.nav ul>li>ul>li>a{border-right:solid 1px #c9c9c9;font-size:90%;}div.nav ul>li>ul>li.h2>a{padding:0.4045em 2.427em;}div.nav ul>li>ul>li.h3>a{padding:.4045em 1.618em .4045em 4.045em;}div.nav ul>li>ul>li.h4>a{padding:.4045em 1.618em .4045em 5.663em;}div.nav ul>li>ul>li.h5>a{padding:.4045em 1.618em .4045em 7.281em;}div.nav ul>li>ul>li.h6>a{padding:.4045em 1.618em .4045em 8.899em;}div.nav ul,div.nav li,.breadcrumbs{margin:0px!important;padding:0px;list-style:none;}ul.breadcrumbs,.breadcrumbs li{display:inline-block;}.menu{display:inline-block;position:absolute;top:12px;right:20px;cursor:pointer;width:1.5em;height:1.5em;vertical-align:middle;padding:16px 24px 16px 24px;border:solid 1px rgba(255, 255, 255, 0.5);border-radius:5px;background:no-repeat center center url("data:image/svg+xml;charset=utf8,%3Csvg viewBox='0 0 30 30' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath stroke='rgba(255, 255, 255, 0.5)' stroke-width='2' stroke-linecap='round' stroke-miterlimit='10' d='M4 7h22M4 15h22M4 23h22'/%3E%3C/svg%3E");}.home{display:inline-block;max-width:16px;max-height:16px;line-height:16px;margin:0 5px 0 0;cursor:pointer;}.home::before{content:url();}h1>a,h2>a,h3>a,h4>a,h5>a,h6>a{display:none;max-width:16px;max-height:24px;margin:-8px 0 0 5px;vertical-align:middle;}h1:hover>a,h2:hover>a,h3:hover>a,h4:hover>a,h5:hover>a,h6:hover>a{display:inline-block;text-decoration:none!important;}h1>a::before,h2>a::before,h3>a::before,h4>a::before,h5>a::before,h6>a::before{content:url();}h1>a:hover::after,h2>a:hover::after,h3>a:hover::after,h4>a:hover::after,h5>a:hover::after,h6>a:hover::after{content:"Enlace permanente a este encabezado";display:block;padding:12px;position:absolute;margin:-8px 8px;font-weight:400;font-size:14px;background:rgba(0,0,0,.8);color:#fff;border-radius:4px;}input[type=radio]{display:none;}input[type=radio]:checked ~ ul{display:block;}.fig{margin-top:-12px;padding-bottom:12px;display:block;text-align:center;font-style:italic;}div.page{width:100%;padding:1.618em 3.236em;margin:auto;line-height:24px;}div.page ol{margin:0 0 24px 12px;padding-left:0px;}div.page ul{margin:0 0 24px 24px;list-style:disc outside;padding-left:0px;}div.page ol{list-style-type:none;counter-reset:list;}div.page ol li:before{counter-increment:list;content:counters(list,".") ". ";}div.pre{overflow-x:auto;margin:1px 0px 24px;}div.table{overflow-x:auto;margin:0px 0px 24px;}div.info,div.hint,div.warn{padding:12px;line-height:24px;margin-bottom:24px;}div.info>p,div.hint>p,div.warn>p{margin:0px;}div.info>p:first-child,div.hint>p:first-child,div.warn>p:first-child{display:block;font-weight:700;padding:2px 8px 2px;margin:-12px -12px 8px -12px;vertical-align:middle;}div.info>p:first-child>span,div.hint>p:first-child>span,div.warn>p:first-child>span{display:block;max-height:20px;margin:0px;vertical-align:middle;}div.info>p:first-child>span::before,div.hint>p:first-child>span::before,div.warn>p:first-child>span::before{content:url();}p>div:last-child,dd>*:last-child,td>*:last-child,li>ol,li>ul{margin-bottom:0px!important;}img{border:0px;}img.imgt{display:inline-block;max-height:22px!important;padding:0px;margin:-4px 0px 0px 0px;vertical-align:middle;}img.imgl{float:left;margin:0px 12px 12px 0px;}img.imgr{float:right;margin:0px 0px 12px 12px;}div.imgc{text-align:center;padding:0px;margin:0 12px 0 0;clear:both;}img.imgc{max-width:100%%;}img.imgw{width:100%;margin-bottom:12px;clear:both;}.btn{border-radius:2px;line-height:normal;white-space:nowrap;color:inherit;text-align:center;cursor:pointer;font-size:100%;padding:4px 12px 8px;border:1px solid rgba(0,0,0,.1);text-decoration:none;box-shadow:inset 0 1px 2px -1px hsla(0,0%,100%,.5),inset 0 -2px 0 0 rgba(0,0,0,.1);vertical-align:middle;*zoom:1;user-select:none;transition:all .1s linear}.prev{float:left;}.prev::before{content:url();}.next{float:right;}.next::after{content:url();}@media screen and (max-width:991.98px){nav.mobile{display:block;}nav.side{display:none;}#menuchk:checked ~ nav.side{display:block;}#_m{margin-left:0px;}}#_prefacio:checked ~ nav div ul li[rel=prefacio]>.toc,#_introduccion_contenido_dinamico_web:checked ~ nav div ul li[rel=introduccion_contenido_dinamico_web]>.toc,#_configuracion_servidor_desarrollo:checked ~ nav div ul li[rel=configuracion_servidor_desarrollo]>.toc,#_introduccion_php:checked ~ nav div ul li[rel=introduccion_php]>.toc,#_expresiones_control_flujo_php:checked ~ nav div ul li[rel=expresiones_control_flujo_php]>.toc,#_funciones_objetos_php:checked ~ nav div ul li[rel=funciones_objetos_php]>.toc,#_arrays_php:checked ~ nav div ul li[rel=arrays_php]>.toc,#_php_practico:checked ~ nav div ul li[rel=php_practico]>.toc,#_introduccion_mysql:checked ~ nav div ul li[rel=introduccion_mysql]>.toc,#_dominando_mysql:checked ~ nav div ul li[rel=dominando_mysql]>.toc,#_novedades_php_8_mysql_8:checked ~ nav div ul li[rel=novedades_php_8_mysql_8]>.toc,#_accediendo_mysql_utilizando_php:checked ~ nav div ul li[rel=accediendo_mysql_utilizando_php]>.toc,#_manejo_formularios:checked ~ nav div ul li[rel=manejo_formularios]>.toc,#_cookies_sesiones_autenticacion:checked ~ nav div ul li[rel=cookies_sesiones_autenticacion]>.toc,#_explorando_javascript:checked ~ nav div ul li[rel=explorando_javascript]>.toc,#_expresiones_control_flujo_javascript:checked ~ nav div ul li[rel=expresiones_control_flujo_javascript]>.toc,#_funciones_objetos_arrays_javascript:checked ~ nav div ul li[rel=funciones_objetos_arrays_javascript]>.toc,#_validacion_manejo_errores_javascript_php:checked ~ nav div ul li[rel=validacion_manejo_errores_javascript_php]>.toc,#_utilizando_comunicaciones_asincronas:checked ~ nav div ul li[rel=utilizando_comunicaciones_asincronas]>.toc,#_introduccion_css:checked ~ nav div ul li[rel=introduccion_css]>.toc,#_css_avanzado_css3:checked ~ nav div ul li[rel=css_avanzado_css3]>.toc,#_accediendo_css_desde_javascript:checked ~ nav div ul li[rel=accediendo_css_desde_javascript]>.toc,#_introduccion_jquery:checked ~ nav div ul li[rel=introduccion_jquery]>.toc,#_introduccion_jquery_mobile:checked ~ nav div ul li[rel=introduccion_jquery_mobile]>.toc,#_introduccion_react:checked ~ nav div ul li[rel=introduccion_react]>.toc,#_introduccion_html5:checked ~ nav div ul li[rel=introduccion_html5]>.toc,#_canvas_html5:checked ~ nav div ul li[rel=canvas_html5]>.toc,#_audio_video_html5:checked ~ nav div ul li[rel=audio_video_html5]>.toc,#_otras_caracteristicas_html5:checked ~ nav div ul li[rel=otras_caracteristicas_html5]>.toc,#_uniendo_todo:checked ~ nav div ul li[rel=uniendo_todo]>.toc,#_soluciones_preguntas_capitulos:checked ~ nav div ul li[rel=soluciones_preguntas_capitulos]>.toc,div.page{display:none;}#_prefacio:checked ~ nav div ul li[rel=prefacio]>ul,#_prefacio:checked ~ nav div ul li[rel=prefacio]>.current,#_prefacio:checked ~ div div[rel=prefacio],#_introduccion_contenido_dinamico_web:checked ~ nav div ul li[rel=introduccion_contenido_dinamico_web]>ul,#_introduccion_contenido_dinamico_web:checked ~ nav div ul li[rel=introduccion_contenido_dinamico_web]>.current,#_introduccion_contenido_dinamico_web:checked ~ div div[rel=introduccion_contenido_dinamico_web],#_configuracion_servidor_desarrollo:checked ~ nav div ul li[rel=configuracion_servidor_desarrollo]>ul,#_configuracion_servidor_desarrollo:checked ~ nav div ul li[rel=configuracion_servidor_desarrollo]>.current,#_configuracion_servidor_desarrollo:checked ~ div div[rel=configuracion_servidor_desarrollo],#_introduccion_php:checked ~ nav div ul li[rel=introduccion_php]>ul,#_introduccion_php:checked ~ nav div ul li[rel=introduccion_php]>.current,#_introduccion_php:checked ~ div div[rel=introduccion_php],#_expresiones_control_flujo_php:checked ~ nav div ul li[rel=expresiones_control_flujo_php]>ul,#_expresiones_control_flujo_php:checked ~ nav div ul li[rel=expresiones_control_flujo_php]>.current,#_expresiones_control_flujo_php:checked ~ div div[rel=expresiones_control_flujo_php],#_funciones_objetos_php:checked ~ nav div ul li[rel=funciones_objetos_php]>ul,#_funciones_objetos_php:checked ~ nav div ul li[rel=funciones_objetos_php]>.current,#_funciones_objetos_php:checked ~ div div[rel=funciones_objetos_php],#_arrays_php:checked ~ nav div ul li[rel=arrays_php]>ul,#_arrays_php:checked ~ nav div ul li[rel=arrays_php]>.current,#_arrays_php:checked ~ div div[rel=arrays_php],#_php_practico:checked ~ nav div ul li[rel=php_practico]>ul,#_php_practico:checked ~ nav div ul li[rel=php_practico]>.current,#_php_practico:checked ~ div div[rel=php_practico],#_introduccion_mysql:checked ~ nav div ul li[rel=introduccion_mysql]>ul,#_introduccion_mysql:checked ~ nav div ul li[rel=introduccion_mysql]>.current,#_introduccion_mysql:checked ~ div div[rel=introduccion_mysql],#_dominando_mysql:checked ~ nav div ul li[rel=dominando_mysql]>ul,#_dominando_mysql:checked ~ nav div ul li[rel=dominando_mysql]>.current,#_dominando_mysql:checked ~ div div[rel=dominando_mysql],#_novedades_php_8_mysql_8:checked ~ nav div ul li[rel=novedades_php_8_mysql_8]>ul,#_novedades_php_8_mysql_8:checked ~ nav div ul li[rel=novedades_php_8_mysql_8]>.current,#_novedades_php_8_mysql_8:checked ~ div div[rel=novedades_php_8_mysql_8],#_accediendo_mysql_utilizando_php:checked ~ nav div ul li[rel=accediendo_mysql_utilizando_php]>ul,#_accediendo_mysql_utilizando_php:checked ~ nav div ul li[rel=accediendo_mysql_utilizando_php]>.current,#_accediendo_mysql_utilizando_php:checked ~ div div[rel=accediendo_mysql_utilizando_php],#_manejo_formularios:checked ~ nav div ul li[rel=manejo_formularios]>ul,#_manejo_formularios:checked ~ nav div ul li[rel=manejo_formularios]>.current,#_manejo_formularios:checked ~ div div[rel=manejo_formularios],#_cookies_sesiones_autenticacion:checked ~ nav div ul li[rel=cookies_sesiones_autenticacion]>ul,#_cookies_sesiones_autenticacion:checked ~ nav div ul li[rel=cookies_sesiones_autenticacion]>.current,#_cookies_sesiones_autenticacion:checked ~ div div[rel=cookies_sesiones_autenticacion],#_explorando_javascript:checked ~ nav div ul li[rel=explorando_javascript]>ul,#_explorando_javascript:checked ~ nav div ul li[rel=explorando_javascript]>.current,#_explorando_javascript:checked ~ div div[rel=explorando_javascript],#_expresiones_control_flujo_javascript:checked ~ nav div ul li[rel=expresiones_control_flujo_javascript]>ul,#_expresiones_control_flujo_javascript:checked ~ nav div ul li[rel=expresiones_control_flujo_javascript]>.current,#_expresiones_control_flujo_javascript:checked ~ div div[rel=expresiones_control_flujo_javascript],#_funciones_objetos_arrays_javascript:checked ~ nav div ul li[rel=funciones_objetos_arrays_javascript]>ul,#_funciones_objetos_arrays_javascript:checked ~ nav div ul li[rel=funciones_objetos_arrays_javascript]>.current,#_funciones_objetos_arrays_javascript:checked ~ div div[rel=funciones_objetos_arrays_javascript],#_validacion_manejo_errores_javascript_php:checked ~ nav div ul li[rel=validacion_manejo_errores_javascript_php]>ul,#_validacion_manejo_errores_javascript_php:checked ~ nav div ul li[rel=validacion_manejo_errores_javascript_php]>.current,#_validacion_manejo_errores_javascript_php:checked ~ div div[rel=validacion_manejo_errores_javascript_php],#_utilizando_comunicaciones_asincronas:checked ~ nav div ul li[rel=utilizando_comunicaciones_asincronas]>ul,#_utilizando_comunicaciones_asincronas:checked ~ nav div ul li[rel=utilizando_comunicaciones_asincronas]>.current,#_utilizando_comunicaciones_asincronas:checked ~ div div[rel=utilizando_comunicaciones_asincronas],#_introduccion_css:checked ~ nav div ul li[rel=introduccion_css]>ul,#_introduccion_css:checked ~ nav div ul li[rel=introduccion_css]>.current,#_introduccion_css:checked ~ div div[rel=introduccion_css],#_css_avanzado_css3:checked ~ nav div ul li[rel=css_avanzado_css3]>ul,#_css_avanzado_css3:checked ~ nav div ul li[rel=css_avanzado_css3]>.current,#_css_avanzado_css3:checked ~ div div[rel=css_avanzado_css3],#_accediendo_css_desde_javascript:checked ~ nav div ul li[rel=accediendo_css_desde_javascript]>ul,#_accediendo_css_desde_javascript:checked ~ nav div ul li[rel=accediendo_css_desde_javascript]>.current,#_accediendo_css_desde_javascript:checked ~ div div[rel=accediendo_css_desde_javascript],#_introduccion_jquery:checked ~ nav div ul li[rel=introduccion_jquery]>ul,#_introduccion_jquery:checked ~ nav div ul li[rel=introduccion_jquery]>.current,#_introduccion_jquery:checked ~ div div[rel=introduccion_jquery],#_introduccion_jquery_mobile:checked ~ nav div ul li[rel=introduccion_jquery_mobile]>ul,#_introduccion_jquery_mobile:checked ~ nav div ul li[rel=introduccion_jquery_mobile]>.current,#_introduccion_jquery_mobile:checked ~ div div[rel=introduccion_jquery_mobile],#_introduccion_react:checked ~ nav div ul li[rel=introduccion_react]>ul,#_introduccion_react:checked ~ nav div ul li[rel=introduccion_react]>.current,#_introduccion_react:checked ~ div div[rel=introduccion_react],#_introduccion_html5:checked ~ nav div ul li[rel=introduccion_html5]>ul,#_introduccion_html5:checked ~ nav div ul li[rel=introduccion_html5]>.current,#_introduccion_html5:checked ~ div div[rel=introduccion_html5],#_canvas_html5:checked ~ nav div ul li[rel=canvas_html5]>ul,#_canvas_html5:checked ~ nav div ul li[rel=canvas_html5]>.current,#_canvas_html5:checked ~ div div[rel=canvas_html5],#_audio_video_html5:checked ~ nav div ul li[rel=audio_video_html5]>ul,#_audio_video_html5:checked ~ nav div ul li[rel=audio_video_html5]>.current,#_audio_video_html5:checked ~ div div[rel=audio_video_html5],#_otras_caracteristicas_html5:checked ~ nav div ul li[rel=otras_caracteristicas_html5]>ul,#_otras_caracteristicas_html5:checked ~ nav div ul li[rel=otras_caracteristicas_html5]>.current,#_otras_caracteristicas_html5:checked ~ div div[rel=otras_caracteristicas_html5],#_uniendo_todo:checked ~ nav div ul li[rel=uniendo_todo]>ul,#_uniendo_todo:checked ~ nav div ul li[rel=uniendo_todo]>.current,#_uniendo_todo:checked ~ div div[rel=uniendo_todo],#_soluciones_preguntas_capitulos:checked ~ nav div ul li[rel=soluciones_preguntas_capitulos]>ul,#_soluciones_preguntas_capitulos:checked ~ nav div ul li[rel=soluciones_preguntas_capitulos]>.current,#_soluciones_preguntas_capitulos:checked ~ div div[rel=soluciones_preguntas_capitulos],#_:checked ~ div div[rel=_]{display:block;}</style>
- <style rel="theme">hr,table,th,td{border-color:#e1e4e5;}th{background:#d6d6d6;}tr:nth-child(odd){background:#f3f6f6;}a{text-decoration:none;color:#2980B9;}samp{background:rgba(0,0,0,.1);color:#408040;}.content{background:#fcfcfc;color:#404040;font-family:Lato,Helvetica,Neue,Arial,Deja Vu,sans-serif;}.title,.home,h1>a,h2>a,h3>a,h4>a,h5>a,h6>a{background:#2980B9;color:#fcfcfc;}.version{color:rgba(255,255,255,0.3);}.search{border:1px solid #2472a4;background:#fcfcfc;}.nav{background:#343131;color:#d9d9d9;}.nav p{color:#55a5d9;}.nav label:hover,.nav a:hover{background:#4e4a4a;}.nav .current{background:#fcfcfc;color:#404040;}.nav li>ul>li{background:#e3e3e3;}.nav li>ul>li>a{color:#404040;}.nav li>ul>li>a:hover{background:#d6d6d6;}.pre {border:1px solid #e1e4e5;background:#f8f8f8;}.info{background:#e7f2fa;}.info>p:first-child{background:#6ab0de;color:#fff;}.hint{background:#dbfaf4;}.hint>p:first-child{background:#1abc9c;color:#fff;}.warn{background:#ffedcc;}.warn>p:first-child{background:#f0b37e;color:#fff;}.btn{background:#f3f6f6;}.btn:hover{background:#e5ebeb;}.ui1{font-family:Serif;font-size:12px;border:1px solid #555;border-radius:3px;background-image:linear-gradient(#fff 0%,#fff 1%,#f2f2f2 1%,#ebebeb 50%,#ddd 50%,#cfcfcf 99%,#fff 99%,#fff 100%);}.hl_h{background-color:#ccffcc;}.hl_c{color:#808080;font-style:italic;}.hl_p{color:#1f7199;}.hl_o{color:#404040;}.hl_n{color:#0164eb;}.hl_s{color:#986801;}.hl_t{color:#60A050;}.hl_k{color:#a626a4;}.hl_f{color:#2a9292;}.hl_v{color:#e95649;}</style>
- </head>
- <body>
- <div class="frame content">
- <input type="radio" name="page" id="_" checked><input type="radio" name="page" id="_prefacio"><input type="radio" name="page" id="_introduccion_contenido_dinamico_web"><input type="radio" name="page" id="_configuracion_servidor_desarrollo"><input type="radio" name="page" id="_introduccion_php"><input type="radio" name="page" id="_expresiones_control_flujo_php"><input type="radio" name="page" id="_funciones_objetos_php"><input type="radio" name="page" id="_arrays_php"><input type="radio" name="page" id="_php_practico"><input type="radio" name="page" id="_introduccion_mysql"><input type="radio" name="page" id="_dominando_mysql"><input type="radio" name="page" id="_novedades_php_8_mysql_8"><input type="radio" name="page" id="_accediendo_mysql_utilizando_php"><input type="radio" name="page" id="_manejo_formularios"><input type="radio" name="page" id="_cookies_sesiones_autenticacion"><input type="radio" name="page" id="_explorando_javascript"><input type="radio" name="page" id="_expresiones_control_flujo_javascript"><input type="radio" name="page" id="_funciones_objetos_arrays_javascript"><input type="radio" name="page" id="_validacion_manejo_errores_javascript_php"><input type="radio" name="page" id="_utilizando_comunicaciones_asincronas"><input type="radio" name="page" id="_introduccion_css"><input type="radio" name="page" id="_css_avanzado_css3"><input type="radio" name="page" id="_accediendo_css_desde_javascript"><input type="radio" name="page" id="_introduccion_jquery"><input type="radio" name="page" id="_introduccion_jquery_mobile"><input type="radio" name="page" id="_introduccion_react"><input type="radio" name="page" id="_introduccion_html5"><input type="radio" name="page" id="_canvas_html5"><input type="radio" name="page" id="_audio_video_html5"><input type="radio" name="page" id="_otras_caracteristicas_html5"><input type="radio" name="page" id="_uniendo_todo"><input type="radio" name="page" id="_soluciones_preguntas_capitulos">
- <input type="checkbox" id="menuchk" style="display:none;"><nav class="side nav"><div>
- <div class="title"><a href="https://ricardogj08.github.io/aprendiendo-php-mysql-javascript/">Aprendiendo PHP, MySQL y JavaScript</a><div class="version">6.0</div><input id="_q" class="search" type="text" required="required" onkeyup="s(this.value);"></div> <div id="_s" class="nav"></div>
- <div id="_t" class="nav">
- <p>Capítulo 0</p>
- <ul>
- <li rel="prefacio"><label class="toc" for="_prefacio">Prefacio</label><div class="current">Prefacio</div><ul>
- <li class="h2"><a href="#prefacio_audiencia" onclick="m()">Audiencia</a></li>
- </ul></li>
- </ul>
- <p>Capítulo 1</p>
- <ul>
- <li rel="introduccion_contenido_dinamico_web"><label class="toc" for="_introduccion_contenido_dinamico_web">Introducción al contenido dinámico de la web</label><div class="current">Introducción al contenido dinámico de la web</div><ul>
- <li class="h2"><a href="#introduccion_contenido_dinamico_web_http_html_conceptos_basicos_berners_lee" onclick="m()">HTTP y HTML: Los conceptos básicos de Berners-Lee</a></li>
- </ul></li>
- </ul>
- <p>Capítulo 2</p>
- <ul>
- <li rel="configuracion_servidor_desarrollo"><label class="toc" for="_configuracion_servidor_desarrollo">Configuración de un servidor de desarrollo</label><div class="current">Configuración de un servidor de desarrollo</div><ul>
- <li class="h2"><a href="#configuracion_servidor_desarrollo_que_es_wamp_mamp_lamp" onclick="m()">¿Qué es WAMP, MAMP o LAMP?</a></li>
- </ul></li>
- </ul>
- <p>Capítulo 3</p>
- <ul>
- <li rel="introduccion_php"><label class="toc" for="_introduccion_php">Introducción a PHP</label><div class="current">Introducción a PHP</div><ul>
- <li class="h2"><a href="#introduccion_php_integrando_php_dentro_html" onclick="m()">Integrando PHP dentro de HTML</a></li>
- </ul></li>
- </ul>
- <p>Capítulo 4</p>
- <ul>
- <li rel="expresiones_control_flujo_php"><label class="toc" for="_expresiones_control_flujo_php">Expresiones y control de flujo en PHP</label><div class="current">Expresiones y control de flujo en PHP</div><ul>
- <li class="h2"><a href="#expresiones_control_flujo_php_expresiones" onclick="m()">Expresiones</a></li>
- </ul></li>
- </ul>
- <p>Capítulo 5</p>
- <ul>
- <li rel="funciones_objetos_php"><label class="toc" for="_funciones_objetos_php">Funciones y objetos en PHP</label><div class="current">Funciones y objetos en PHP</div><ul>
- <li class="h2"><a href="#funciones_objetos_php_funciones_php" onclick="m()">Funciones en PHP</a></li>
- </ul></li>
- </ul>
- <p>Capítulo 6</p>
- <ul>
- <li rel="arrays_php"><label class="toc" for="_arrays_php">Arrays en PHP</label><div class="current">Arrays en PHP</div><ul>
- <li class="h2"><a href="#arrays_php_acceso_basico" onclick="m()">Acceso básico</a></li>
- </ul></li>
- </ul>
- <p>Capítulo 7</p>
- <ul>
- <li rel="php_practico"><label class="toc" for="_php_practico">PHP práctico</label><div class="current">PHP práctico</div><ul>
- <li class="h2"><a href="#php_practico_utilizando_printf" onclick="m()">Utilizando printf</a></li>
- </ul></li>
- </ul>
- <p>Capítulo 8</p>
- <ul>
- <li rel="introduccion_mysql"><label class="toc" for="_introduccion_mysql">Introducción a MySQL</label><div class="current">Introducción a MySQL</div><ul>
- <li class="h2"><a href="#introduccion_mysql_fundamentos_mysql" onclick="m()">Fundamentos de MySQL</a></li>
- </ul></li>
- </ul>
- <p>Capítulo 9</p>
- <ul>
- <li rel="dominando_mysql"><label class="toc" for="_dominando_mysql">Dominando MySQL</label><div class="current">Dominando MySQL</div><ul>
- <li class="h2"><a href="#dominando_mysql_disenio_base_datos" onclick="m()">Diseño de bases de datos</a></li>
- </ul></li>
- </ul>
- <p>Capítulo 10</p>
- <ul>
- <li rel="novedades_php_8_mysql_8"><label class="toc" for="_novedades_php_8_mysql_8">Novedades de PHP 8 y MySQL 8</label><div class="current">Novedades de PHP 8 y MySQL 8</div><ul>
- <li class="h2"><a href="#novedades_php_8_mysql_8_sobre_este_capitulo" onclick="m()">Sobre este capítulo</a></li>
- </ul></li>
- </ul>
- <p>Capítulo 11</p>
- <ul>
- <li rel="accediendo_mysql_utilizando_php"><label class="toc" for="_accediendo_mysql_utilizando_php">Accediendo a MySQL utilizando PHP</label><div class="current">Accediendo a MySQL utilizando PHP</div><ul>
- <li class="h2"><a href="#accediendo_mysql_utilizando_php_consultando_base_datos_mysql_php" onclick="m()">Consultando una base de datos MySQL con PHP</a></li>
- </ul></li>
- </ul>
- <p>Capítulo 12</p>
- <ul>
- <li rel="manejo_formularios"><label class="toc" for="_manejo_formularios">Manejo de formularios</label><div class="current">Manejo de formularios</div><ul>
- <li class="h2"><a href="#manejo_formularios_creacion_formularios" onclick="m()">Creación de formularios</a></li>
- </ul></li>
- </ul>
- <p>Capítulo 13</p>
- <ul>
- <li rel="cookies_sesiones_autenticacion"><label class="toc" for="_cookies_sesiones_autenticacion">Cookies, sesiones y autenticación</label><div class="current">Cookies, sesiones y autenticación</div><ul>
- <li class="h2"><a href="#cookies_sesiones_autenticacion_utilizando_cookies_php" onclick="m()">Utilizando cookies en PHP</a></li>
- </ul></li>
- </ul>
- <p>Capítulo 14</p>
- <ul>
- <li rel="explorando_javascript"><label class="toc" for="_explorando_javascript">Explorando JavaScript</label><div class="current">Explorando JavaScript</div><ul>
- <li class="h2"><a href="#explorando_javascript_introduccion" onclick="m()">Introducción</a></li>
- <li class="h2"><a href="#explorando_javascript_texto_javascript_html" onclick="m()">Texto JavaScript y HTML</a></li>
- <li class="h3"><a href="#explorando_javascript_scripts_cabecera_documento" onclick="m()">Uso de scripts dentro de la cabecera de un documento</a></li>
- <li class="h3"><a href="#explorando_javascript_navegadores_antiguos_no_estandar" onclick="m()">Navegadores antiguos y no estándar</a></li>
- <li class="h3"><a href="#explorando_javascript_incluyendo_archivos_javascript" onclick="m()">Incluyendo archivos JavaScript</a></li>
- <li class="h3"><a href="#explorando_javascript_depuracion_errores_javascript" onclick="m()">Depuración de errores en JavaScript</a></li>
- <li class="h2"><a href="#explorando_javascript_utilizando_comentarios" onclick="m()">Utilizando comentarios</a></li>
- <li class="h2"><a href="#explorando_javascript_signos_punto_coma" onclick="m()">Signos de punto y coma</a></li>
- <li class="h2"><a href="#explorando_javascript_variables" onclick="m()">Variables</a></li>
- <li class="h3"><a href="#explorando_javascript_variables_string" onclick="m()">Variables string</a></li>
- <li class="h3"><a href="#explorando_javascript_variables_numericas" onclick="m()">Variables numéricas</a></li>
- <li class="h3"><a href="#explorando_javascript_arrays" onclick="m()">Arrays</a></li>
- <li class="h2"><a href="#explorando_javascript_operadores" onclick="m()">Operadores</a></li>
- <li class="h3"><a href="#explorando_javascript_operadores_aritmeticos" onclick="m()">Operadores aritméticos</a></li>
- <li class="h3"><a href="#explorando_javascript_operadores_asignacion" onclick="m()">Operadores de asignación</a></li>
- <li class="h3"><a href="#explorando_javascript_operadores_comparacion" onclick="m()">Operadores de comparación</a></li>
- <li class="h3"><a href="#explorando_javascript_operadores_logicos" onclick="m()">Operadores lógicos</a></li>
- <li class="h3"><a href="#explorando_javascript_incrementando_decrementando_asignacion_abreviada" onclick="m()">Incrementando, decrementando y asignación abreviada</a></li>
- <li class="h3"><a href="#explorando_javascript_concatenacion_strings" onclick="m()">Concatenación de strings</a></li>
- <li class="h3"><a href="#explorando_javascript_caracteres_escape" onclick="m()">Caracteres de escape</a></li>
- <li class="h2"><a href="#explorando_javascript_tipado_variables" onclick="m()">Tipado de variables</a></li>
- <li class="h2"><a href="#explorando_javascript_funciones" onclick="m()">Funciones</a></li>
- <li class="h2"><a href="#explorando_javascript_variables_globales" onclick="m()">Variables globales</a></li>
- <li class="h2"><a href="#explorando_javascript_variables_locales" onclick="m()">Variables locales</a></li>
- <li class="h3"><a href="#explorando_javascript_utilizando_let_const" onclick="m()">Utilizando let y const</a></li>
- <li class="h2"><a href="#explorando_javascript_document_object_model" onclick="m()">El Document Object Model</a></li>
- <li class="h3"><a href="#explorando_javascript_otro_uso_simbolo" onclick="m()">Otro uso del símbolo $</a></li>
- <li class="h3"><a href="#explorando_javascript_utilizando_dom" onclick="m()">Utilizando el DOM</a></li>
- <li class="h2"><a href="#explorando_javascript_sobre_document_write" onclick="m()">Sobre document.write</a></li>
- <li class="h3"><a href="#explorando_javascript_utilizando_console_log" onclick="m()">Utilizando console.log</a></li>
- <li class="h3"><a href="#explorando_javascript_utilizando_alert" onclick="m()">Utilizando alert</a></li>
- <li class="h3"><a href="#explorando_javascript_escritura_elementos" onclick="m()">Escritura en elementos</a></li>
- <li class="h3"><a href="#explorando_javascript_utilizando_document_write" onclick="m()">Utilizando document.write</a></li>
- <li class="h2"><a href="#explorando_javascript_preguntas" onclick="m()">Preguntas</a></li>
- </ul></li>
- </ul>
- <p>Capítulo 15</p>
- <ul>
- <li rel="expresiones_control_flujo_javascript"><label class="toc" for="_expresiones_control_flujo_javascript">Expresiones y control de flujo en JavaScript</label><div class="current">Expresiones y control de flujo en JavaScript</div><ul>
- <li class="h2"><a href="#expresiones_control_flujo_javascript_expresiones" onclick="m()">Expresiones</a></li>
- <li class="h2"><a href="#expresiones_control_flujo_javascript_literales_variables" onclick="m()">Literales y variables</a></li>
- <li class="h2"><a href="#expresiones_control_flujo_javascript_operadores" onclick="m()">Operadores</a></li>
- <li class="h3"><a href="#expresiones_control_flujo_javascript_precedencia_operadores" onclick="m()">Precedencia de operadores</a></li>
- <li class="h3"><a href="#expresiones_control_flujo_javascript_asociatividad" onclick="m()">Asociatividad</a></li>
- <li class="h2"><a href="#expresiones_control_flujo_javascript_operadores_relacionales" onclick="m()">Operadores relacionales</a></li>
- <li class="h3"><a href="#expresiones_control_flujo_javascript_operadores_igualdad" onclick="m()">Operadores de igualdad</a></li>
- <li class="h3"><a href="#expresiones_control_flujo_javascript_operadores_comparacion" onclick="m()">Operadores de comparación</a></li>
- <li class="h3"><a href="#expresiones_control_flujo_javascript_operadores_logicos" onclick="m()">Operadores lógicos</a></li>
- <li class="h2"><a href="#expresiones_control_flujo_javascript_declaracion_with" onclick="m()">Declaración with</a></li>
- <li class="h2"><a href="#expresiones_control_flujo_javascript_utilizando_onerror" onclick="m()">Utilizando onerror</a></li>
- <li class="h2"><a href="#expresiones_control_flujo_javascript_utilizando_try_catch" onclick="m()">Utilizando try...catch</a></li>
- <li class="h2"><a href="#expresiones_control_flujo_javascript_condicionales" onclick="m()">Condicionales</a></li>
- <li class="h3"><a href="#expresiones_control_flujo_javascript_declaracion_if" onclick="m()">Declaración if</a></li>
- <li class="h3"><a href="#expresiones_control_flujo_javascript_declaracion_else" onclick="m()">Declaración else</a></li>
- <li class="h3"><a href="#expresiones_control_flujo_javascript_declaracion_switch" onclick="m()">Declaración switch</a></li>
- <li class="h4"><a href="#expresiones_control_flujo_javascript_ruptura" onclick="m()">Ruptura</a></li>
- <li class="h4"><a href="#expresiones_control_flujo_javascript_accion_por_defecto" onclick="m()">Acción por defecto</a></li>
- <li class="h3"><a href="#expresiones_control_flujo_javascript_operador" onclick="m()">El operador ?</a></li>
- <li class="h2"><a href="#expresiones_control_flujo_javascript_bucles" onclick="m()">Bucles</a></li>
- <li class="h3"><a href="#expresiones_control_flujo_javascript_bucles_while" onclick="m()">Bucles while</a></li>
- <li class="h3"><a href="#expresiones_control_flujo_javascript_bucles_do_while" onclick="m()">Bucles do...while</a></li>
- <li class="h3"><a href="#expresiones_control_flujo_javascript_bucles_for" onclick="m()">Bucles for</a></li>
- <li class="h3"><a href="#expresiones_control_flujo_javascript_ruptura_bucle" onclick="m()">Ruptura de un bucle</a></li>
- <li class="h3"><a href="#expresiones_control_flujo_javascript_declaracion_continue" onclick="m()">Declaración continue</a></li>
- <li class="h2"><a href="#expresiones_control_flujo_javascript_conversion_explicita" onclick="m()">Conversión explícita</a></li>
- <li class="h2"><a href="#expresiones_control_flujo_javascript_preguntas" onclick="m()">Preguntas</a></li>
- </ul></li>
- </ul>
- <p>Capítulo 16</p>
- <ul>
- <li rel="funciones_objetos_arrays_javascript"><label class="toc" for="_funciones_objetos_arrays_javascript">Funciones, objetos y arrays en JavaScript</label><div class="current">Funciones, objetos y arrays en JavaScript</div><ul>
- <li class="h2"><a href="#funciones_objetos_arrays_javascript_funciones_javascript" onclick="m()">Funciones en JavaScript</a></li>
- <li class="h3"><a href="#funciones_objetos_arrays_javascript_definicion_funcion" onclick="m()">Definición de una función</a></li>
- <li class="h3"><a href="#funciones_objetos_arrays_array_arguments" onclick="m()">El array arguments</a></li>
- <li class="h3"><a href="#funciones_objetos_arrays_javascript_devolviendo_valor" onclick="m()">Devolviendo un valor</a></li>
- </ul></li>
- </ul>
- <p>Capítulo 17</p>
- <ul>
- <li rel="validacion_manejo_errores_javascript_php"><label class="toc" for="_validacion_manejo_errores_javascript_php">Validación y manejo de errores en JavaScript y PHP</label><div class="current">Validación y manejo de errores en JavaScript y PHP</div><ul>
- <li class="h2"><a href="#validacion_manejo_errores_javascript_php_validando_entrada_usuario_javascript" onclick="m()">Validando la entrada del usuario con JavaScript</a></li>
- </ul></li>
- </ul>
- <p>Capítulo 18</p>
- <ul>
- <li rel="utilizando_comunicaciones_asincronas"><label class="toc" for="_utilizando_comunicaciones_asincronas">Utilizando comunicaciones asíncronas</label><div class="current">Utilizando comunicaciones asíncronas</div><ul>
- <li class="h2"><a href="#utilizando_comunicaciones_asincronas_que_es_comunicacion_asincrona" onclick="m()">¿Qué es la comunicación asíncrona?</a></li>
- </ul></li>
- </ul>
- <p>Capítulo 19</p>
- <ul>
- <li rel="introduccion_css"><label class="toc" for="_introduccion_css">Introducción a CSS</label><div class="current">Introducción a CSS</div><ul>
- <li class="h2"><a href="#introduccion_css_importando_hoja_estilos" onclick="m()">Importando una hoja de estilos</a></li>
- </ul></li>
- </ul>
- <p>Capítulo 20</p>
- <ul>
- <li rel="css_avanzado_css3"><label class="toc" for="_css_avanzado_css3">CSS avanzado con CSS3</label><div class="current">CSS avanzado con CSS3</div><ul>
- <li class="h2"><a href="#css_avanzado_css3_selectores_atributos" onclick="m()">Selectores de atributos</a></li>
- </ul></li>
- </ul>
- <p>Capítulo 21</p>
- <ul>
- <li rel="accediendo_css_desde_javascript"><label class="toc" for="_accediendo_css_desde_javascript">Accediendo a CSS desde JavaScript</label><div class="current">Accediendo a CSS desde JavaScript</div><ul>
- <li class="h2"><a href="#accediendo_css_desde_javascript_revisando_funcion_getelementbyid" onclick="m()">Revisando la función getElementById</a></li>
- </ul></li>
- </ul>
- <p>Capítulo 22</p>
- <ul>
- <li rel="introduccion_jquery"><label class="toc" for="_introduccion_jquery">Introducción a jQuery</label><div class="current">Introducción a jQuery</div><ul>
- <li class="h2"><a href="#introduccion_jquery_por_que_jquery" onclick="m()">¿Por qué jQuery?</a></li>
- </ul></li>
- </ul>
- <p>Capítulo 23</p>
- <ul>
- <li rel="introduccion_jquery_mobile"><label class="toc" for="_introduccion_jquery_mobile">Introducción a jQuery Mobile</label><div class="current">Introducción a jQuery Mobile</div><ul>
- <li class="h2"><a href="#introduccion_jquery_mobile_incluyendo_jquery_mobile" onclick="m()">Incluyendo jQuery Mobile</a></li>
- </ul></li>
- </ul>
- <p>Capítulo 24</p>
- <ul>
- <li rel="introduccion_react"><label class="toc" for="_introduccion_react">Introducción a React</label><div class="current">Introducción a React</div><ul>
- <li class="h2"><a href="#introduccion_react_para_que_sirve_react" onclick="m()">¿Para qué sirve React?</a></li>
- </ul></li>
- </ul>
- <p>Capítulo 25</p>
- <ul>
- <li rel="introduccion_html5"><label class="toc" for="_introduccion_html5">Introducción a HTML5</label><div class="current">Introducción a HTML5</div><ul>
- <li class="h2"><a href="#introduccion_html5_canvas" onclick="m()">Canvas</a></li>
- </ul></li>
- </ul>
- <p>Capítulo 26</p>
- <ul>
- <li rel="canvas_html5"><label class="toc" for="_canvas_html5">Canvas de HTML5</label><div class="current">Canvas de HTML5</div><ul>
- <li class="h2"><a href="#canvas_html5_creando_accediendo_canvas" onclick="m()">Creando y accediendo a Canvas</a></li>
- </ul></li>
- </ul>
- <p>Capítulo 27</p>
- <ul>
- <li rel="audio_video_html5"><label class="toc" for="_audio_video_html5">Audio y vídeo en HTML5</label><div class="current">Audio y vídeo en HTML5</div><ul>
- <li class="h2"><a href="#audio_video_html5_sobre_codecs" onclick="m()">Sobre los códecs</a></li>
- </ul></li>
- </ul>
- <p>Capítulo 28</p>
- <ul>
- <li rel="otras_caracteristicas_html5"><label class="toc" for="_otras_caracteristicas_html5">Otras características de HTML5</label><div class="current">Otras características de HTML5</div><ul>
- <li class="h2"><a href="#otras_caracteristicas_html5_geolocalizacion_servicio_gps" onclick="m()">Geolocalización y el servicio de GPS</a></li>
- </ul></li>
- </ul>
- <p>Capítulo 29</p>
- <ul>
- <li rel="uniendo_todo"><label class="toc" for="_uniendo_todo">Uniendo todo</label><div class="current">Uniendo todo</div><ul>
- <li class="h2"><a href="#uniendo_todo_diseniando_aplicacion_redes_sociales" onclick="m()">Diseñando una aplicación de redes sociales</a></li>
- </ul></li>
- </ul>
- <p>Apéndice A</p>
- <ul>
- <li rel="soluciones_preguntas_capitulos"><label class="toc" for="_soluciones_preguntas_capitulos">Soluciones a las preguntas de los capítulos</label><div class="current">Soluciones a las preguntas de los capítulos</div><ul>
- <li class="h2"><a href="#soluciones_preguntas_capitulos_respuestas_capitulo_14" onclick="m()">Respuestas del capítulo 14</a></li>
- <li class="h2"><a href="#soluciones_preguntas_capitulos_respuestas_capitulo_15" onclick="m()">Respuestas del capítulo 15</a></li>
- </ul></li>
- </ul>
- </div>
- </div></nav>
- <div id="_m">
- <nav class="mobile title">Aprendiendo PHP, MySQL y JavaScript<label for="menuchk" class="menu"></label></nav>
- <div class="page" rel="_">
- <h1>Aprendiendo PHP, MySQL y JavaScript</h1><br style="clear:both;"><label class="btn next" accesskey="n" for="_prefacio" title="Prefacio">Siguiente</label></div>
- <div class="page" rel="prefacio"><div><ul class="breadcrumbs"><li><label class="home" for="_" title="Inicio"></label> »</li><li> Capítulo 0 »</li><li> Prefacio</li></ul><hr></div>
- <h1 id="prefacio">Prefacio<a href="#prefacio"></a></h1>
- <h2 id="prefacio_audiencia">Audiencia<a href="#prefacio_audiencia"></a></h2><br style="clear:both;"><label class="btn prev" accesskey="p" for="_">Volver</label><label class="btn next" accesskey="n" for="_introduccion_contenido_dinamico_web" title="Introducción al contenido dinámico de la web">Siguiente</label></div>
- <div class="page" rel="introduccion_contenido_dinamico_web"><div><ul class="breadcrumbs"><li><label class="home" for="_" title="Inicio"></label> »</li><li> Capítulo 1 »</li><li> Introducción al contenido dinámico de la web</li></ul><hr></div>
- <h1 id="introduccion_contenido_dinamico_web">Introducción al contenido dinámico de la web<a href="#introduccion_contenido_dinamico_web"></a></h1>
- <h2 id="introduccion_contenido_dinamico_web_http_html_conceptos_basicos_berners_lee">HTTP y HTML: Los conceptos básicos de Berners-Lee<a href="#introduccion_contenido_dinamico_web_http_html_conceptos_basicos_berners_lee"></a></h2><br style="clear:both;"><label class="btn prev" accesskey="p" for="_prefacio" title="Prefacio">Volver</label><label class="btn next" accesskey="n" for="_configuracion_servidor_desarrollo" title="Configuración de un servidor de desarrollo">Siguiente</label></div>
- <div class="page" rel="configuracion_servidor_desarrollo"><div><ul class="breadcrumbs"><li><label class="home" for="_" title="Inicio"></label> »</li><li> Capítulo 2 »</li><li> Configuración de un servidor de desarrollo</li></ul><hr></div>
- <h1 id="configuracion_servidor_desarrollo">Configuración de un servidor de desarrollo<a href="#configuracion_servidor_desarrollo"></a></h1>
- <h2 id="configuracion_servidor_desarrollo_que_es_wamp_mamp_lamp">¿Qué es WAMP, MAMP o LAMP?<a href="#configuracion_servidor_desarrollo_que_es_wamp_mamp_lamp"></a></h2><br style="clear:both;"><label class="btn prev" accesskey="p" for="_introduccion_contenido_dinamico_web" title="Introducción al contenido dinámico de la web">Volver</label><label class="btn next" accesskey="n" for="_introduccion_php" title="Introducción a PHP">Siguiente</label></div>
- <div class="page" rel="introduccion_php"><div><ul class="breadcrumbs"><li><label class="home" for="_" title="Inicio"></label> »</li><li> Capítulo 3 »</li><li> Introducción a PHP</li></ul><hr></div>
- <h1 id="introduccion_php">Introducción a PHP<a href="#introduccion_php"></a></h1>
- <h2 id="introduccion_php_integrando_php_dentro_html">Integrando PHP dentro de HTML<a href="#introduccion_php_integrando_php_dentro_html"></a></h2><br style="clear:both;"><label class="btn prev" accesskey="p" for="_configuracion_servidor_desarrollo" title="Configuración de un servidor de desarrollo">Volver</label><label class="btn next" accesskey="n" for="_expresiones_control_flujo_php" title="Expresiones y control de flujo en PHP">Siguiente</label></div>
- <div class="page" rel="expresiones_control_flujo_php"><div><ul class="breadcrumbs"><li><label class="home" for="_" title="Inicio"></label> »</li><li> Capítulo 4 »</li><li> Expresiones y control de flujo en PHP</li></ul><hr></div>
- <h1 id="expresiones_control_flujo_php">Expresiones y control de flujo en PHP<a href="#expresiones_control_flujo_php"></a></h1>
- <h2 id="expresiones_control_flujo_php_expresiones">Expresiones<a href="#expresiones_control_flujo_php_expresiones"></a></h2><br style="clear:both;"><label class="btn prev" accesskey="p" for="_introduccion_php" title="Introducción a PHP">Volver</label><label class="btn next" accesskey="n" for="_funciones_objetos_php" title="Funciones y objetos en PHP">Siguiente</label></div>
- <div class="page" rel="funciones_objetos_php"><div><ul class="breadcrumbs"><li><label class="home" for="_" title="Inicio"></label> »</li><li> Capítulo 5 »</li><li> Funciones y objetos en PHP</li></ul><hr></div>
- <h1 id="funciones_objetos_php">Funciones y objetos en PHP<a href="#funciones_objetos_php"></a></h1>
- <h2 id="funciones_objetos_php_funciones_php">Funciones en PHP<a href="#funciones_objetos_php_funciones_php"></a></h2><br style="clear:both;"><label class="btn prev" accesskey="p" for="_expresiones_control_flujo_php" title="Expresiones y control de flujo en PHP">Volver</label><label class="btn next" accesskey="n" for="_arrays_php" title="Arrays en PHP">Siguiente</label></div>
- <div class="page" rel="arrays_php"><div><ul class="breadcrumbs"><li><label class="home" for="_" title="Inicio"></label> »</li><li> Capítulo 6 »</li><li> Arrays en PHP</li></ul><hr></div>
- <h1 id="arrays_php">Arrays en PHP<a href="#arrays_php"></a></h1>
- <h2 id="arrays_php_acceso_basico">Acceso básico<a href="#arrays_php_acceso_basico"></a></h2><br style="clear:both;"><label class="btn prev" accesskey="p" for="_funciones_objetos_php" title="Funciones y objetos en PHP">Volver</label><label class="btn next" accesskey="n" for="_php_practico" title="PHP práctico">Siguiente</label></div>
- <div class="page" rel="php_practico"><div><ul class="breadcrumbs"><li><label class="home" for="_" title="Inicio"></label> »</li><li> Capítulo 7 »</li><li> PHP práctico</li></ul><hr></div>
- <h1 id="php_practico">PHP práctico<a href="#php_practico"></a></h1>
- <h2 id="php_practico_utilizando_printf">Utilizando printf<a href="#php_practico_utilizando_printf"></a></h2><br style="clear:both;"><label class="btn prev" accesskey="p" for="_arrays_php" title="Arrays en PHP">Volver</label><label class="btn next" accesskey="n" for="_introduccion_mysql" title="Introducción a MySQL">Siguiente</label></div>
- <div class="page" rel="introduccion_mysql"><div><ul class="breadcrumbs"><li><label class="home" for="_" title="Inicio"></label> »</li><li> Capítulo 8 »</li><li> Introducción a MySQL</li></ul><hr></div>
- <h1 id="introduccion_mysql">Introducción a MySQL<a href="#introduccion_mysql"></a></h1>
- <h2 id="introduccion_mysql_fundamentos_mysql">Fundamentos de MySQL<a href="#introduccion_mysql_fundamentos_mysql"></a></h2><br style="clear:both;"><label class="btn prev" accesskey="p" for="_php_practico" title="PHP práctico">Volver</label><label class="btn next" accesskey="n" for="_dominando_mysql" title="Dominando MySQL">Siguiente</label></div>
- <div class="page" rel="dominando_mysql"><div><ul class="breadcrumbs"><li><label class="home" for="_" title="Inicio"></label> »</li><li> Capítulo 9 »</li><li> Dominando MySQL</li></ul><hr></div>
- <h1 id="dominando_mysql">Dominando MySQL<a href="#dominando_mysql"></a></h1>
- <h2 id="dominando_mysql_disenio_base_datos">Diseño de bases de datos<a href="#dominando_mysql_disenio_base_datos"></a></h2><br style="clear:both;"><label class="btn prev" accesskey="p" for="_introduccion_mysql" title="Introducción a MySQL">Volver</label><label class="btn next" accesskey="n" for="_novedades_php_8_mysql_8" title="Novedades de PHP 8 y MySQL 8">Siguiente</label></div>
- <div class="page" rel="novedades_php_8_mysql_8"><div><ul class="breadcrumbs"><li><label class="home" for="_" title="Inicio"></label> »</li><li> Capítulo 10 »</li><li> Novedades de PHP 8 y MySQL 8</li></ul><hr></div>
- <h1 id="novedades_php_8_mysql_8">Novedades de PHP 8 y MySQL 8<a href="#novedades_php_8_mysql_8"></a></h1>
- <h2 id="novedades_php_8_mysql_8_sobre_este_capitulo">Sobre este capítulo<a href="#novedades_php_8_mysql_8_sobre_este_capitulo"></a></h2><br style="clear:both;"><label class="btn prev" accesskey="p" for="_dominando_mysql" title="Dominando MySQL">Volver</label><label class="btn next" accesskey="n" for="_accediendo_mysql_utilizando_php" title="Accediendo a MySQL utilizando PHP">Siguiente</label></div>
- <div class="page" rel="accediendo_mysql_utilizando_php"><div><ul class="breadcrumbs"><li><label class="home" for="_" title="Inicio"></label> »</li><li> Capítulo 11 »</li><li> Accediendo a MySQL utilizando PHP</li></ul><hr></div>
- <h1 id="accediendo_mysql_utilizando_php">Accediendo a MySQL utilizando PHP<a href="#accediendo_mysql_utilizando_php"></a></h1>
- <h2 id="accediendo_mysql_utilizando_php_consultando_base_datos_mysql_php">Consultando una base de datos MySQL con PHP<a href="#accediendo_mysql_utilizando_php_consultando_base_datos_mysql_php"></a></h2><br style="clear:both;"><label class="btn prev" accesskey="p" for="_novedades_php_8_mysql_8" title="Novedades de PHP 8 y MySQL 8">Volver</label><label class="btn next" accesskey="n" for="_manejo_formularios" title="Manejo de formularios">Siguiente</label></div>
- <div class="page" rel="manejo_formularios"><div><ul class="breadcrumbs"><li><label class="home" for="_" title="Inicio"></label> »</li><li> Capítulo 12 »</li><li> Manejo de formularios</li></ul><hr></div>
- <h1 id="manejo_formularios">Manejo de formularios<a href="#manejo_formularios"></a></h1>
- <h2 id="manejo_formularios_creacion_formularios">Creación de formularios<a href="#manejo_formularios_creacion_formularios"></a></h2><br style="clear:both;"><label class="btn prev" accesskey="p" for="_accediendo_mysql_utilizando_php" title="Accediendo a MySQL utilizando PHP">Volver</label><label class="btn next" accesskey="n" for="_cookies_sesiones_autenticacion" title="Cookies, sesiones y autenticación">Siguiente</label></div>
- <div class="page" rel="cookies_sesiones_autenticacion"><div><ul class="breadcrumbs"><li><label class="home" for="_" title="Inicio"></label> »</li><li> Capítulo 13 »</li><li> Cookies, sesiones y autenticación</li></ul><hr></div>
- <h1 id="cookies_sesiones_autenticacion">Cookies, sesiones y autenticación<a href="#cookies_sesiones_autenticacion"></a></h1>
- <h2 id="cookies_sesiones_autenticacion_utilizando_cookies_php">Utilizando cookies en PHP<a href="#cookies_sesiones_autenticacion_utilizando_cookies_php"></a></h2><br style="clear:both;"><label class="btn prev" accesskey="p" for="_manejo_formularios" title="Manejo de formularios">Volver</label><label class="btn next" accesskey="n" for="_explorando_javascript" title="Explorando JavaScript">Siguiente</label></div>
- <div class="page" rel="explorando_javascript"><div><ul class="breadcrumbs"><li><label class="home" for="_" title="Inicio"></label> »</li><li> Capítulo 14 »</li><li> Explorando JavaScript</li></ul><hr></div>
- <h1 id="explorando_javascript">Explorando JavaScript<a href="#explorando_javascript"></a></h1>
- <h2 id="explorando_javascript_introduccion">Introducción<a href="#explorando_javascript_introduccion"></a></h2>
- <p>JavaScript aporta una funcionalidad dinámica a tus sitios web. Cada vez que mires algo aparecer cuando pasas el mouse sobre un elemento en el navegador, o ves nuevo texto, colores o imágenes aparecer en la página frente a tus ojos, o cuando tomas un objeto en la página y lo arrastras a una nueva ubicación, todas esas cosas generalmente se hacen a través de JavaScript (aunque CSS se está volviendo cada vez más poderoso y también puede hacer muchas de estas cosas). Ofrece efectos que de otro modo no serían posibles, porque se ejecuta dentro del navegador y tiene acceso directo a todos los elementos de un documento web.</p>
- <p>JavaScript apareció por primera vez en el navegador Netscape Navigator en 1995, coincidiendo con la incorporación del soporte para la tecnología Java en el navegador. Debido a la incorrecta impresión inicial de que JavaScript era un derivado de Java, ha habido una confusión durante mucho tiempo sobre su relación. Sin embargo, el nombre fue solo una táctica de <i>marketing</i> para ayudar al nuevo lenguaje de scripting a beneficiarse de la popularidad del lenguaje de programación Java.</p>
- <p>JavaScript ganó nuevo poder cuando los elementos HTML de la página web obtuvieron una definición más formal y estructurada en lo que se llama <i>Document Object Model</i> (DOM). El DOM hace que sea relativamente fácil añadir un nuevo párrafo o centrarse en un fragmento de texto y modificarlo.</p>
- <p>Debido a que tanto JavaScript como PHP soportan gran parte de la sintaxis de la programación estructurada que utiliza el lenguaje de programación C, son muy similares entre sí. También son lenguajes de alto nivel. Además, son débilmente tipados, por lo que es fácil cambiar una variable a un nuevo tipo simplemente usándola en un nuevo contexto.</p>
- <p>Ahora que has aprendido PHP, deberías encontrar JavaScript aún más fácil. Y te alegrarás de haberlo hecho, porque está en el corazón de la tecnología de la comunicación asíncrona que proporciona las interfaces web fluidas que (junto con las características de HTML5) los usuarios web expertos esperan hoy en día.</p>
- <h2 id="explorando_javascript_texto_javascript_html">Texto JavaScript y HTML<a href="#explorando_javascript_texto_javascript_html"></a></h2>
- <p>JavaScript es un lenguaje de scripting del lado del cliente que se ejecuta completamente dentro del navegador web o bajo <i>Node.js</i>. Para llamarlo, se coloca entre las etiquetas HTML de apertura <samp><script></samp> y cierre <samp></script></samp>. Un documento típico de "Hello World" utilizando JavaScript puede parecerse al Ejemplo 14-1.</p>
- <p><i>Ejemplo 14-1. Visualización de "Hello World" con JavaScript</i></p>
- <div class="pre"><pre class="lineno">1<br>2<br>3<br>4<br>5<br>6<br>7<br>8<br>9<br>10<br>11<br>12<br>13<br></pre><code><span class="hl_o"><</span><span class="hl_v">html</span><span class="hl_o">></span>
- <span class="hl_o"><</span><span class="hl_v">head</span><span class="hl_o">></span>
- <span class="hl_o"><</span><span class="hl_v">title</span><span class="hl_o">></span><span class="hl_v">Hello</span> <span class="hl_v">World</span><span class="hl_o"></</span><span class="hl_v">title</span><span class="hl_o">></span>
- <span class="hl_o"></</span><span class="hl_v">head</span><span class="hl_o">></span>
- <span class="hl_o"><</span><span class="hl_v">body</span><span class="hl_o">></span>
- <span class="hl_o"><</span><span class="hl_v">script</span> <span class="hl_v">type</span><span class="hl_o">=</span><span class="hl_s">"text/javascript"</span><span class="hl_o">></span>
- <span class="hl_f">document.write</span>(<span class="hl_s">"Hello World"</span>)
- <span class="hl_o"></</span><span class="hl_v">script</span><span class="hl_o">></span>
- <span class="hl_o"><</span><span class="hl_v">noscript</span><span class="hl_o">></span>
- <span class="hl_v">Your</span> <span class="hl_v">browser</span> <span class="hl_v">doesn't</span> <span class="hl_v">support</span> <span class="hl_k">or</span> <span class="hl_v">has</span> <span class="hl_v">disabled</span> <span class="hl_v">JavaScript</span>
- <span class="hl_o"></</span><span class="hl_v">noscript</span><span class="hl_o">></span>
- <span class="hl_o"></</span><span class="hl_v">body</span><span class="hl_o">></span>
- <span class="hl_o"></</span><span class="hl_v">html</span><span class="hl_o">></span></code></div>
- <div class="info"><p><span>Nota</span></p><p>Es posible que hayas visto páginas web que utilizan la etiqueta HTML <samp><script language="javascript"></samp>, pero ahora esa manera está obsoleta. Este ejemplo utiliza el más reciente y preferido <samp><script type="text/javascript"></samp>, o puedes simplemente utilizar <samp><script></samp> por tu cuenta si lo prefieres.</p></div>
- <p>Dentro de las etiquetas <samp><script></samp> hay una sola línea de código JavaScript que utiliza su equivalente a los comandos <samp>echo</samp> o <samp>print</samp> de PHP, es <samp>document.write</samp>. Como era de esperar, simplemente envía el string proporcionado al documento actual, donde se muestra.</p>
- <p>También puede que haya notado que, a diferencia de PHP, no hay punto y coma al final (<samp>;</samp>). Esto se debe a que un salto de línea cumple la misma función que un punto y coma en JavaScript. Sin embargo, si deseas tener más de una instrucción en una sola línea, debes colocar un punto y coma después de cada comando, excepto el último. Por supuesto, si lo deseas, puedes añadir un punto y coma al final de cada instrucción, y tu JavaScript funcionará bien. Mi preferencia personal es omitir el punto y coma porque es innecesario, y por lo tanto también evito prácticas que podrían causar problemas. Al final del día, sin embargo, la elección puede depender del equipo en el que trabajes, que más a menudo no puede requerir puntos y coma, solo para estar seguros. Entonces, si tienes dudas, simplemente añade los puntos y comas.</p>
- <p>Lo otro a tener en cuenta en este ejemplo es el par de etiquetas <samp><noscript></samp> y <samp></noscript></samp>. Estos se utilizan cuando deseas ofrecer HTML alternativo a los usuarios cuyos navegadores no soportan JavaScript o lo tienen desactivado. El uso de estas etiquetas depende de ti, ya que no son obligatorias, pero realmente deberías usarlas porque generalmente no es tan difícil proporcionar alternativas HTML estáticas a las operaciones que ofreces utilizando JavaScript. Sin embargo, los ejemplos restantes en este libro omitirán las etiquetas <samp><noscript></samp>, porque nos estamos enfocando en lo que puedes hacer con JavaScript, no en lo que puedes hacer sin él.</p>
- <p>Cuando se carga el Ejemplo 14-1, un navegador web con JavaScript habilitado mostrará lo siguiente (ver Figura 14-1):</p>
- <div class="pre"><pre>
- Hello World
- </pre></div>
- <div class="imgc"><img class="imgc" width="479" height="163" alt="figura_14-1.png" src=""></div>
- <div class="fig">Figura 14-1. JavaScript, habilitado y funcionando</div>
- <p>Un navegador con JavaScript desactivado mostrará este mensaje (ver Figura 14-2):</p>
- <div class="pre"><pre>
- Your browser doesn't support or has disabled JavaScript
- </pre></div>
- <div class="imgc"><img class="imgc" width="480" height="164" alt="figura_14-2.png" src=""></div>
- <div class="fig">Figura 14-2. JavaScript, desactivado</div>
- <h3 id="explorando_javascript_scripts_cabecera_documento">Uso de scripts dentro de la cabecera de un documento<a href="#explorando_javascript_scripts_cabecera_documento"></a></h3>
- <p>Además de colocar un script dentro del cuerpo de un documento, puedes ponerlo en la sección <samp><head></samp>, que es el lugar ideal si deseas ejecutar un script cuando se carga una página. Si colocas código y funciones críticas allí, también puedes tener la seguridad de que estén listos para usarse de inmediato por cualquier otra sección de script en el documento que dependa de ellos.</p>
- <p>Otra razón para colocar un script en la cabecera del documento es permitir que JavaScript escriba cosas como meta etiquetas en la sección <samp><head></samp>, porque la ubicación de tu script es la parte del documento donde se escribe (imprime) por defecto.</p>
- <h3 id="explorando_javascript_navegadores_antiguos_no_estandar">Navegadores antiguos y no estándar<a href="#explorando_javascript_navegadores_antiguos_no_estandar"></a></h3>
- <p>Si necesitas soportar navegadores que no ofrecen scripting (muy poco probable en la actualidad), deberás usar las etiquetas de comentario HTML (<samp><!--</samp> y <samp>--></samp>) para evitar que se encuentren con código script que no deberían ver. El ejemplo 14-2 muestra cómo añadirlos a tu código de script.</p>
- <p>Ejemplo 14-2. El ejemplo de "Hello World" modificado para navegadores que no soportan JavaScript</p>
- <div class="pre"><pre class="lineno">1<br>2<br>3<br>4<br>5<br>6<br>7<br>8<br>9<br>10<br>11<br></pre><code><span class="hl_o"><</span><span class="hl_v">html</span><span class="hl_o">></span>
- <span class="hl_o"><</span><span class="hl_v">head</span><span class="hl_o">></span>
- <span class="hl_o"><</span><span class="hl_v">title</span><span class="hl_o">></span><span class="hl_v">Hello</span> <span class="hl_v">World</span><span class="hl_o"></</span><span class="hl_v">title</span><span class="hl_o">></span>
- <span class="hl_o"></</span><span class="hl_v">head</span><span class="hl_o">></span>
- <span class="hl_o"><</span><span class="hl_v">body</span><span class="hl_o">></span>
- <span class="hl_o"><</span><span class="hl_v">script</span> <span class="hl_v">type</span><span class="hl_o">=</span><span class="hl_s">"text/javascript"</span><span class="hl_o">><!--</span>
- <span class="hl_f">document.write</span>(<span class="hl_v">'Hello</span> <span class="hl_v">World'</span>)
- <span class="hl_c">// --></span>
- <span class="hl_o"></</span><span class="hl_v">script</span><span class="hl_o">></span>
- <span class="hl_o"></</span><span class="hl_v">body</span><span class="hl_o">></span>
- <span class="hl_o"></</span><span class="hl_v">html</span><span class="hl_o">></span></code></div>
- <p>Aquí se ha añadido una etiqueta HTML de apertura de comentario (<samp><!--</samp>) directamente después de la declaración de apertura <samp><script></samp>, y se ha añadido una etiqueta de cierre de comentario (<samp>// --></samp>) directamente antes de que el script se cierre con <samp></script></samp>.</p>
- <p>La doble barra diagonal (<samp>//</samp>) la utiliza JavaScript para indicar que el resto de la línea es un comentario. Está ahí para que los navegadores que <i>sí soportan JavaScript</i> ignoren el siguiente <samp>--></samp>, pero los navegadores que no soportan JavaScript ignorarán el <samp>//</samp> anterior y actuarán sobre el <samp>--></samp> cerrando el comentario HTML.</p>
- <p>Aunque la solución es un poco complicada, lo único que realmente necesitas recordar es utilizar las dos líneas siguientes para encerrar tu JavaScript cuando desees soportar navegadores muy antiguos o no estándar:</p>
- <div class="pre"><pre class="lineno">1<br>2<br>3<br>4<br></pre><code><span class="hl_o"><</span><span class="hl_v">script</span> <span class="hl_v">type</span><span class="hl_o">=</span><span class="hl_s">"text/javascript"</span><span class="hl_o">><!--</span>
- (<span class="hl_v">Your</span> <span class="hl_v">JavaScript</span> <span class="hl_v">goes</span> <span class="hl_v">here...</span>)
- <span class="hl_c">// --></span>
- <span class="hl_o"></</span><span class="hl_v">script</span><span class="hl_o">></span></code></div>
- <p>Sin embargo, el uso de estos comentarios es innecesario para cualquier navegador lanzado en los últimos años, pero debes estar al tanto de esto, por si acaso.</p>
- <h3 id="explorando_javascript_incluyendo_archivos_javascript">Incluyendo archivos JavaScript<a href="#explorando_javascript_incluyendo_archivos_javascript"></a></h3>
- <p>Además de escribir código JavaScript directamente en documentos HTML, puedes incluir archivos de código JavaScript desde tu sitio web o desde cualquier lugar de internet. La sintaxis para esto es la siguiente:</p>
- <div class="pre"><pre class="lineno">1<br></pre><code><span class="hl_o"><</span><span class="hl_v">script</span> <span class="hl_v">type</span><span class="hl_o">=</span><span class="hl_s">"text/javascript"</span> <span class="hl_v">src</span><span class="hl_o">=</span><span class="hl_s">"script.js"</span><span class="hl_o">></</span><span class="hl_v">script</span><span class="hl_o">></span></code></div>
- <p>O, para cargar un archivo desde internet, usa esto (aquí sin el <samp>type="text/javascript"</samp> ya que es opcional):</p>
- <div class="pre"><pre class="lineno">1<br></pre><code><span class="hl_o"><</span><span class="hl_v">script</span> <span class="hl_v">src</span><span class="hl_o">=</span><span class="hl_s">"http://someserver.com/script.js"</span><span class="hl_o">></</span><span class="hl_v">script</span><span class="hl_o">></span></code></div>
- <p>En cuanto a los archivos de script en sí, <i>no deben incluir</i> ninguna etiqueta <samp><script></samp> o <samp></script></samp>, porque son innecesarias: el navegador ya sabe que se está cargando un archivo JavaScript. Ponerlos en los archivos JavaScript causará un error.</p>
- <p>Incluir archivos de script es la forma preferida para que uses archivos JavaScript de terceros en tu sitio web.</p>
- <div class="info"><p><span>Nota</span></p><p>Es posible omitir el parámetro <samp>type="text/javascript"</samp>; todos los navegadores modernos asumen por defecto que el script contiene JavaScript.</p></div>
- <h3 id="explorando_javascript_depuracion_errores_javascript">Depuración de errores en JavaScript<a href="#explorando_javascript_depuracion_errores_javascript"></a></h3>
- <p>Cuando estás aprendiendo JavaScript, es importante poder rastrear errores de escritura u otros errores de codificación. A diferencia de PHP, que muestra mensajes de error en el navegador, JavaScript maneja los mensajes de error de una manera que cambia de acuerdo con el navegador que se esté utilizando. La Tabla 14-1 muestra cómo acceder a los mensajes de error de JavaScript en los navegadores más utilizados.</p>
- <p><i>Tabla 14-1. Acceso a los mensajes de error de JavaScript en diferentes navegadores</i></p>
- <div class="table"><table>
- <tr>
- <th>Navegador</th>
- <th>Cómo acceder a los mensajes de error de JavaScript</th>
- </tr>
- <tr>
- <td>Apple Safari</td>
- <td>Abre Safari y elige <span class="ui1">Safari</span> > <span class="ui1">Preferencias</span> > <span class="ui1">Avanzado</span>. Luego selecciona <span class="ui1">Mostrar menú de desarrollo en la barra de menú</span>. Elige <span class="ui1">Desarrollar</span> > <span class="ui1">Mostrar Consola de Errores</span></td>
- </tr>
- <tr>
- <td>Google Chrome, Microsoft Edge, Mozilla Firefox, & Opera</td>
- <td>Presiona <kbd>Ctrl</kbd> + <kbd>Shift</kbd> + <kbd>J</kbd> en una PC o <kbd>Command</kbd> + <kbd>Shift</kbd> + <kbd>J</kbd> en una Mac.</td>
- </tr>
- </table></div>
- <p>Por favor, consulte la documentación de los desarrolladores del navegador en sus sitios web para obtener todos los detalles sobre su uso.</p>
- <h2 id="explorando_javascript_utilizando_comentarios">Utilizando comentarios<a href="#explorando_javascript_utilizando_comentarios"></a></h2>
- <p>Debido a su herencia compartida del lenguaje de programación C, PHP y JavaScript tienen muchas similitudes, una de las cuales es la forma de comentar. Primero, hay el comentario de una sola línea, como este:</p>
- <div class="pre"><pre class="lineno">1<br></pre><code><span class="hl_c">// This is a comment</span></code></div>
- <p>Este estilo utiliza un par de caracteres de barra diagonal (<samp>//</samp>) para informar a JavaScript que todo lo que sigue debe ser ignorado. También tienes comentarios multilínea, como este:</p>
- <div class="pre"><pre class="lineno">1<br>2<br>3<br>4<br></pre><code><span class="hl_c">/* This is a section
- of multiline comments
- that will not be
- interpreted */</span></code></div>
- <p>Empiezas un comentario de varias líneas con la secuencia <samp>/*</samp> y lo terminas con <samp>*/</samp>. Solo recuerda que no puedes anidar comentarios multilínea, así que asegúrate de no comentar grandes secciones de código que ya contengan comentarios multilínea.</p>
- <h2 id="explorando_javascript_signos_punto_coma">Signos de punto y coma<a href="#explorando_javascript_signos_punto_coma"></a></h2>
- <p>A diferencia de PHP, JavaScript generalmente no requiere punto y coma si tienes solo una instrucción en una línea. Por lo tanto, lo siguiente es válido:</p>
- <div class="pre"><pre class="lineno">1<br></pre><code><span class="hl_v">x</span> <span class="hl_o">+=</span> <span class="hl_n">10</span></code></div>
- <p>Sin embargo, cuando desees colocar más de una declaración en una línea, debes separarlas con punto y coma, así:</p>
- <div class="pre"><pre class="lineno">1<br></pre><code><span class="hl_v">x</span> <span class="hl_o">+=</span> <span class="hl_n">10</span>; <span class="hl_v">y</span> <span class="hl_o">-=</span> <span class="hl_n">5</span>; <span class="hl_v">z</span> <span class="hl_o">=</span> <span class="hl_n">0</span></code></div>
- <p>Normalmente puedes omitir el punto y coma final, porque la nueva línea termina la declaración final.</p>
- <div class="warn"><p><span>Precaución</span></p><p>Hay excepciones a la regla del punto y coma. Si escribes bookmarklets (marcadores) en JavaScript, o terminas una declaración con una referencia a una variable o función, <i>y el primer carácter</i> de la siguiente línea es un paréntesis izquierdo o un corchete, <i>debes recordar</i> agregar un punto y coma o JavaScript fallará. Entonces, cuando tengas dudas, usa un punto y coma.</p></div>
- <h2 id="explorando_javascript_variables">Variables<a href="#explorando_javascript_variables"></a></h2>
- <p>Ningún carácter en particular identifica una variable en JavaScript como lo hace el signo de dólar en PHP. En su lugar, las variables utilizan las siguientes reglas de nomenclatura:</p>
- <ul>
- <li>Una variable puede incluir solo las letras <samp>a–z</samp>, <samp>A–Z</samp>, <samp>0–9</samp>, el símbolo <samp>$</samp> y el guion bajo (<samp>_</samp>).</li>
- <li>No se permiten otros caracteres, como espacios o signos de puntuación, en el nombre de una variable.</li>
- <li>El primer carácter del nombre de una variable puede ser solo <samp>a–z</samp>, <samp>A–Z</samp>, <samp>$</samp>, o <samp>_</samp> (sin números).</li>
- <li>Los nombres son sensibles a mayúsculas y minúsculas. <samp>Count</samp>, <samp>count</samp> y <samp>COUNT</samp> son todas variables diferentes.</li>
- <li>No hay un límite establecido para la longitud de los nombres de las variables.</li>
- </ul>
- <p>Y sí, tienes razón: hay un <samp>$</samp> en esta lista de caracteres permitidos. <i>Está permitido</i> por JavaScript y <i>puede ser</i> el primer carácter de un nombre de una variable o función. Aunque no recomiendo utilizar los caracteres <samp>$</samp>, esta regla te permite integrar mucho código PHP más rápidamente a JavaScript.</p>
- <h3 id="explorando_javascript_variables_string">Variables string<a href="#explorando_javascript_variables_string"></a></h3>
- <p>Las variables string en JavaScript deben estar entre comillas simples o dobles, así:</p>
- <div class="pre"><pre class="lineno">1<br>2<br></pre><code><span class="hl_v">greeting</span> <span class="hl_o">=</span> <span class="hl_s">"Hello there"</span>
- <span class="hl_v">warning</span> <span class="hl_o">=</span> <span class="hl_v">'Be</span> <span class="hl_v">careful'</span></code></div>
- <p>Puedes incluir una comilla simple dentro de un string de comillas dobles o una comilla doble dentro de un string de comillas simples. Pero debes escapar el entrecomillado del mismo tipo usando el carácter de barra invertida, así:</p>
- <div class="pre"><pre class="lineno">1<br>2<br></pre><code><span class="hl_v">greeting</span> <span class="hl_o">=</span> <span class="hl_s">"\"Hello there\" is a greeting"</span>
- <span class="hl_v">warning</span> <span class="hl_o">=</span> <span class="hl_v">'</span><span class="hl_s">\'Be careful\' is a warning'</span></code></div>
- <p>Para leer de una variable string, puedes asignarla a otra, así:</p>
- <div class="pre"><pre class="lineno">1<br></pre><code><span class="hl_v">newstring</span> <span class="hl_o">=</span> <span class="hl_v">oldstring</span></code></div>
- <p>o puedes usarla en una función, así:</p>
- <div class="pre"><pre class="lineno">1<br>2<br></pre><code><span class="hl_v">status</span> <span class="hl_o">=</span> <span class="hl_s">"All systems are working"</span>
- <span class="hl_f">document.write</span>(<span class="hl_v">status</span>)</code></div>
- <h3 id="explorando_javascript_variables_numericas">Variables numéricas<a href="#explorando_javascript_variables_numericas"></a></h3>
- <p>Crear una variable numérica es tan simple como asignarle un valor, como estos ejemplos:</p>
- <div class="pre"><pre class="lineno">1<br>2<br></pre><code><span class="hl_v">count</span> <span class="hl_o">=</span> <span class="hl_n">42</span>
- <span class="hl_v">temperature</span> <span class="hl_o">=</span> <span class="hl_n">98</span><span class="hl_v">.4</span></code></div>
- <p>Al igual que los strings, las variables numéricas pueden leerse y usarse en expresiones y funciones.</p>
- <h3 id="explorando_javascript_arrays">Arrays<a href="#explorando_javascript_arrays"></a></h3>
- <p>Los arrays en JavaScript también son muy similares a los de PHP, en el sentido de que un array puede contener datos de tipo string o numéricos, así como otros arrays. Para asignar valores a un array, utiliza la siguiente sintaxis (que en este caso crea un array de strings):</p>
- <div class="pre"><pre class="lineno">1<br></pre><code><span class="hl_v">toys</span> <span class="hl_o">=</span> [<span class="hl_v">'bat'</span>, <span class="hl_v">'ball'</span>, <span class="hl_v">'whistle'</span>, <span class="hl_v">'puzzle'</span>, <span class="hl_v">'doll'</span>]</code></div>
- <p>Para crear un array multidimensional, anida arrays más pequeños dentro de uno más grande. Entonces, para crear un array bidimensional que contenga los colores de una sola cara de un Cubo Rubik desordenado (donde los colores red (rojo), green (verde), orange (naranja), yellow (amarillo), blue (azul) y white (blanco) están representados por sus letras iniciales en mayúscula), podrías usar el siguiente código:</p>
- <div class="pre"><pre class="lineno">1<br>2<br>3<br>4<br>5<br></pre><code><span class="hl_v">face</span> <span class="hl_o">=</span> [
- [<span class="hl_v">'R'</span>, <span class="hl_v">'G'</span>, <span class="hl_v">'Y'</span>],
- [<span class="hl_v">'W'</span>, <span class="hl_v">'R'</span>, <span class="hl_v">'O'</span>],
- [<span class="hl_v">'Y'</span>, <span class="hl_v">'W'</span>, <span class="hl_v">'G'</span>]
- ]</code></div>
- <p>El ejemplo anterior se le ha dado formato para que sea obvio lo que está sucediendo, pero también podría escribirse así:</p>
- <div class="pre"><pre class="lineno">1<br></pre><code><span class="hl_v">face</span> <span class="hl_o">=</span> [[<span class="hl_v">'R'</span>, <span class="hl_v">'G'</span>, <span class="hl_v">'Y'</span>], [<span class="hl_v">'W'</span>, <span class="hl_v">'R'</span>, <span class="hl_v">'O'</span>], [<span class="hl_v">'Y'</span>, <span class="hl_v">'W'</span>, <span class="hl_v">'G'</span>]]</code></div>
- <p>o incluso así:</p>
- <div class="pre"><pre class="lineno">1<br>2<br>3<br>4<br>5<br></pre><code><span class="hl_v">top</span> <span class="hl_o">=</span> [<span class="hl_v">'R'</span>, <span class="hl_v">'G'</span>, <span class="hl_v">'Y'</span>]
- <span class="hl_v">mid</span> <span class="hl_o">=</span> [<span class="hl_v">'W'</span>, <span class="hl_v">'R'</span>, <span class="hl_v">'O'</span>]
- <span class="hl_v">bot</span> <span class="hl_o">=</span> [<span class="hl_v">'Y'</span>, <span class="hl_v">'W'</span>, <span class="hl_v">'G'</span>]
- <span class="hl_v">face</span> <span class="hl_o">=</span> [<span class="hl_v">top</span>, <span class="hl_v">mid</span>, <span class="hl_v">bot</span>]</code></div>
- <p>Para acceder al elemento dos hacia abajo y tres hacia la derecha en este array, usarías lo siguiente (porque los elementos del array comienzan en la posición <samp>0</samp>):</p>
- <div class="pre"><pre class="lineno">1<br></pre><code><span class="hl_f">document.write</span>(<span class="hl_v">face</span>[<span class="hl_n">1</span>][<span class="hl_n">2</span>])</code></div>
- <p>Esta declaración mostrará la letra <samp>O</samp> para <i>orange</i> (naranja).</p>
- <div class="info"><p><span>Nota</span></p><p>Los arrays en JavaScript son estructuras de almacenamiento poderosas, por lo que en el <a href="#funciones_objetos_arrays_javascript" onclick="c('funciones_objetos_arrays_javascript')">Capítulo 16</a> se tratan con mucho más detalle.</p></div>
- <h2 id="explorando_javascript_operadores">Operadores<a href="#explorando_javascript_operadores"></a></h2>
- <p>Los operadores en JavaScript, al igual que en PHP, pueden incluir matemáticas, cambios en strings y operaciones de comparación y lógicas. (<samp>and</samp>, <samp>or</samp>, etc.). Los operadores matemáticos de JavaScript se parecen mucho a la aritmética básica; por ejemplo, la siguiente instrucción devuelve <samp>15</samp>:</p>
- <div class="pre"><pre class="lineno">1<br></pre><code><span class="hl_f">document.write</span>(<span class="hl_n">13</span> <span class="hl_o">+</span> <span class="hl_n">2</span>)</code></div>
- <p>Las siguientes secciones te enseñan sobre los distintos operadores.</p>
- <h3 id="explorando_javascript_operadores_aritmeticos">Operadores aritméticos<a href="#explorando_javascript_operadores_aritmeticos"></a></h3>
- <p>Los <i>operadores aritméticos</i> se utilizan para realizar operaciones matemáticas. Puedes usarlos para las cuatro operaciones principales (suma, resta, multiplicación y división), así como para encontrar el módulo de una división (el residuo después de una división) y para incrementar o decrementar un valor.
- (ver la Tabla 14-2).</p>
- <p><i>Tabla 14-2. Operadores aritméticos</i></p>
- <div class="table"><table>
- <tr>
- <th>Operador</th>
- <th>Descripción</th>
- <th>Ejemplo</th>
- </tr>
- <tr>
- <td><samp>+</samp></td>
- <td>Suma</td>
- <td><samp>j + 12</samp></td>
- </tr>
- <tr>
- <td><samp>-</samp></td>
- <td>Resta</td>
- <td><samp>j - 22</samp></td>
- </tr>
- <tr>
- <td><samp>*</samp></td>
- <td>Multiplicación</td>
- <td><samp>j * 7</samp></td>
- </tr>
- <tr>
- <td><samp>/</samp></td>
- <td>División</td>
- <td><samp>j / 3.13</samp></td>
- </tr>
- <tr>
- <td><samp>%</samp></td>
- <td>Módulo (resto de la división)</td>
- <td><samp>j % 6</samp></td>
- </tr>
- <tr>
- <td><samp>++</samp></td>
- <td>Incremento</td>
- <td><samp>++j</samp></td>
- </tr>
- <tr>
- <td><samp>--</samp></td>
- <td>Decremento</td>
- <td><samp>--j</samp></td>
- </tr>
- </table></div>
- <h3 id="explorando_javascript_operadores_asignacion">Operadores de asignación<a href="#explorando_javascript_operadores_asignacion"></a></h3>
- <p>Los <i>operadores de asignación</i> se utilizan para asignar valores a las variables. Empiezan con el muy simple <samp>=</samp> y continúan con <samp>+=</samp>, <samp>–=</samp>, y así sucesivamente. El operador <samp>+=</samp> añade el valor del lado derecho a la variable del lado izquierdo, en lugar de reemplazar totalmente el valor del lado izquierdo. Así, si <samp>count</samp> comienza con el valor de <samp>6</samp>, la declaración:</p>
- <div class="pre"><pre class="lineno">1<br></pre><code><span class="hl_v">count</span> <span class="hl_o">+=</span> <span class="hl_n">1</span></code></div>
- <p>establece <samp>count</samp> en <samp>7</samp>, al igual que la declaración de asignación más familiar:</p>
- <div class="pre"><pre class="lineno">1<br></pre><code><span class="hl_v">count</span> <span class="hl_o">=</span> <span class="hl_v">count</span> <span class="hl_o">+</span> <span class="hl_n">1</span></code></div>
- <p>La Tabla 14-3 enumera los distintos operadores de asignación disponibles.</p>
- <p><i>Tabla 14-3. Operadores de asignación</i></p>
- <div class="table"><table>
- <tr>
- <th>Operador</th>
- <th>Ejemplo</th>
- <th>Equivalente a</th>
- </tr>
- <tr>
- <td><samp>=</samp></td>
- <td><samp>j = 99</samp></td>
- <td><samp>j = 99</samp></td>
- </tr>
- <tr>
- <td><samp>+=</samp></td>
- <td><samp>j += 2</samp></td>
- <td><samp>j = j + 2</samp></td>
- </tr>
- <tr>
- <td><samp>+=</samp></td>
- <td><samp>j += 'string'</samp></td>
- <td><samp>j = j + 'string'</samp></td>
- </tr>
- <tr>
- <td><samp>–=</samp></td>
- <td><samp>j –= 12</samp></td>
- <td><samp>j = j – 12</samp></td>
- </tr>
- <tr>
- <td><samp>*=</samp></td>
- <td><samp>j *= 2</samp></td>
- <td><samp>j = j * 2</samp></td>
- </tr>
- <tr>
- <td><samp>/=</samp></td>
- <td><samp>j /= 6</samp></td>
- <td><samp>j = j / 6</samp></td>
- </tr>
- <tr>
- <td><samp>%=</samp></td>
- <td><samp>j %= 7</samp></td>
- <td><samp>j = j % 7</samp></td>
- </tr>
- </table></div>
- <h3 id="explorando_javascript_operadores_comparacion">Operadores de comparación<a href="#explorando_javascript_operadores_comparacion"></a></h3>
- <p>Los <i>operadores de comparación</i> se utilizan generalmente dentro de una estructura como en una declaración <samp>if</samp>, donde necesitas comparar dos elementos. Por ejemplo, puede que desees saber si una variable que se ha estado incrementando ha alcanzado un valor específico, o si otra variable es menor que un valor establecido, y así sucesivamente. (ver la Tabla 14-4).</p>
- <p><i>Tabla 14-4. Operadores de comparación</i></p>
- <div class="table"><table>
- <tr>
- <th>Operador</th>
- <th>Descripción</th>
- <th>Ejemplo</th>
- </tr>
- <tr>
- <td><samp>==</samp></td>
- <td>Es <i>igual</i> a</td>
- <td><samp>j == 42</samp></td>
- </tr>
- <tr>
- <td><samp>!=</samp></td>
- <td><i>No es igual</i> a</td>
- <td><samp>j != 17</samp></td>
- </tr>
- <tr>
- <td><samp>></samp></td>
- <td>Es <i>mayor que</i></td>
- <td><samp>j > 0</samp></td>
- </tr>
- <tr>
- <td><samp><</samp></td>
- <td>Es <i>menor que</i></td>
- <td><samp>j < 100</samp></td>
- </tr>
- <tr>
- <td><samp>>=</samp></td>
- <td>Es <i>mayor o igual</i> que</td>
- <td><samp>j >= 23</samp></td>
- </tr>
- <tr>
- <td><samp><=</samp></td>
- <td>Es <i>menor o igual</i> que</td>
- <td><samp>j <= 13</samp></td>
- </tr>
- <tr>
- <td><samp>===</samp></td>
- <td>Es <i>igual</i> a (y del mismo tipo)</td>
- <td><samp>j === 56</samp></td>
- </tr>
- <tr>
- <td><samp>!==</samp></td>
- <td><i>No es igual</i> a (y del mismo tipo)</td>
- <td><samp>j !== '1'</samp></td>
- </tr>
- </table></div>
- <h3 id="explorando_javascript_operadores_logicos">Operadores lógicos<a href="#explorando_javascript_operadores_logicos"></a></h3>
- <p>A diferencia de PHP, los <i>operadores lógicos</i> de JavaScript no incluyen equivalentes de <samp>and</samp> y <samp>or</samp> a <samp>&&</samp> y <samp>||</samp>, y no hay un operador <samp>xor</samp>. (ver la Tabla 14-5).</p>
- <p><i>Tabla 14-5. Operadores lógicos</i></p>
- <div class="table"><table>
- <tr>
- <th>Operador</th>
- <th>Descripción</th>
- <th>Ejemplo</th>
- </tr>
- <tr>
- <td><samp>&&</samp></td>
- <td>And</td>
- <td><samp>j == 1 && k == 2</samp></td>
- </tr>
- <tr>
- <td><samp>||</samp></td>
- <td>Or</td>
- <td><samp>j < 100 || j > 0</samp></td>
- </tr>
- <tr>
- <td><samp>!</samp></td>
- <td>Not</td>
- <td><samp>! (j == k)</samp></td>
- </tr>
- </table></div>
- <h3 id="explorando_javascript_incrementando_decrementando_asignacion_abreviada">Incrementando, decrementando y asignación abreviada<a href="#explorando_javascript_incrementando_decrementando_asignacion_abreviada"></a></h3>
- <p>Las siguientes formas de post y preincremento y decremento que aprendiste a utilizar en PHP también son compatibles con JavaScript, al igual que los operadores de asignación abreviada:</p>
- <div class="pre"><pre class="lineno">1<br>2<br>3<br>4<br></pre><code><span class="hl_o">++</span><span class="hl_v">x</span>
- <span class="hl_o">--</span><span class="hl_v">y</span>
- <span class="hl_v">x</span> <span class="hl_o">+=</span> <span class="hl_n">22</span>
- <span class="hl_v">y</span> <span class="hl_o">-=</span> <span class="hl_n">3</span></code></div>
- <h3 id="explorando_javascript_concatenacion_strings">Concatenación de strings<a href="#explorando_javascript_concatenacion_strings"></a></h3>
- <p>JavaScript maneja la concatenación de strings de manera ligeramente diferente a PHP. En lugar del operador <samp>.</samp> (punto), utiliza el signo más (<samp>+</samp>), así:</p>
- <div class="pre"><pre class="lineno">1<br></pre><code><span class="hl_f">document.write</span>(<span class="hl_s">"You have "</span> <span class="hl_o">+</span> <span class="hl_v">messages</span> <span class="hl_o">+</span> <span class="hl_s">" messages."</span>)</code></div>
- <p>Suponiendo que la variable <samp>messages</samp> está establecida con el valor de <samp>3</samp>, la salida de esta línea de código será la siguiente:</p>
- <div class="pre"><pre>
- You have 3 messages.
- </pre></div>
- <p>Así como puedes agregar un valor a una variable numérica con el operador <samp>+=</samp>, también puedes concatenar un string a otra de la misma manera:</p>
- <div class="pre"><pre class="lineno">1<br>2<br></pre><code><span class="hl_v">name</span> <span class="hl_o">=</span> <span class="hl_s">"James"</span>
- <span class="hl_v">name</span> <span class="hl_o">+=</span> <span class="hl_s">" Dean"</span></code></div>
- <h3 id="explorando_javascript_caracteres_escape">Caracteres de escape<a href="#explorando_javascript_caracteres_escape"></a></h3>
- <p>Los caracteres de escape, que se han utilizado para insertar comillas en los strings, también pueden ser utilizados para insertar varios caracteres especiales, como tabulaciones, saltos de línea y retornos de carro. Aquí hay un ejemplo usando tabulaciones para organizar un encabezado: se incluye aquí simplemente para ilustrar escapes, porque en las páginas web, hay mejores maneras de hacer el diseño:</p>
- <div class="pre"><pre class="lineno">1<br></pre><code><span class="hl_v">heading</span> <span class="hl_o">=</span> <span class="hl_s">"Name\tAge\tLocation"</span></code></div>
- <p>La Tabla 14-6 detalla los caracteres de escape disponibles.</p>
- <p><i>Tabla 14-6. Caracteres de escape en JavaScript</i></p>
- <div class="table"><table>
- <tr>
- <th>Caracter</th>
- <th class="wide">Significado</th>
- </tr>
- <tr>
- <td><samp>\b</samp></td>
- <td>Retroceso</td>
- </tr>
- <tr>
- <td><samp>\f</samp></td>
- <td>Salto de página</td>
- </tr>
- <tr>
- <td><samp>\n</samp></td>
- <td>Salto de línea</td>
- </tr>
- <tr>
- <td><samp>\r</samp></td>
- <td>Retorno de carro</td>
- </tr>
- <tr>
- <td><samp>\t</samp></td>
- <td>Tabulador</td>
- </tr>
- <tr>
- <td><samp>\'</samp></td>
- <td>Comillas simples (o apóstrofe)</td>
- </tr>
- <tr>
- <td><samp>\"</samp></td>
- <td>Comillas dobles</td>
- </tr>
- <tr>
- <td><samp>\\</samp></td>
- <td>Barra invertida</td>
- </tr>
- <tr>
- <td><samp>\XXX</samp></td>
- <td>Un número octal entre <samp>000</samp> y <samp>377</samp> que representa el equivalente de caracteres Latin-1 (como <samp>\251</samp> para el símbolo ©)</td>
- </tr>
- <tr>
- <td><samp>\xXX</samp></td>
- <td>Un número hexadecimal entre <samp>00</samp> y <samp>FF</samp> que representa el equivalente de caracteres Latin-1 (como <samp>\xA9</samp> para el símbolo ©)</td>
- </tr>
- <tr>
- <td><samp>\uXXXX</samp></td>
- <td>Un número hexadecimal entre <samp>0000</samp> y <samp>FFFF</samp> que representa el equivalente de caracteres Unicode (como <samp>\u00A9</samp> para el símbolo ©)</td>
- </tr>
- </table></div>
- <h2 id="explorando_javascript_tipado_variables">Tipado de variables<a href="#explorando_javascript_tipado_variables"></a></h2>
- <p>Al igual que PHP, JavaScript es un lenguaje muy débilmente tipado; el <i>tipo de dato</i> de una variable se determina solo cuando se le asigna un valor y puede cambiar a medida que la variable aparece en diferentes contextos. Por lo general, no tienes que preocuparte por el tipo de dato de las variables; JavaScript averigua lo que quieres y simplemente lo hace.</p>
- <p>Echa un vistazo al Ejemplo 14-3, en el cual:</p>
- <ol>
- <li>A la variable <samp>n</samp> se le asigna el valor del string <samp>'838102050'</samp>. La siguiente línea imprime su valor, y se utiliza el operador <samp>typeof</samp> para consultar el tipo de dato de la variable.</li>
- <li><samp>n</samp> se le asigna el valor devuelto cuando se multiplican los números <samp>12345</samp> y <samp>67890</samp>. Este valor también es <samp>838102050</samp>, pero es un número, no un string. El tipo de dato de la variable se busca y se muestra.</li>
- <li>Se añade algún texto al número <samp>n</samp> y se muestra el resultado.</li>
- </ol>
- <p><i>Ejemplo 14-3. Establece el tipo de dato de una variable por asignación</i></p>
- <div class="pre"><pre class="lineno">1<br>2<br>3<br>4<br>5<br>6<br>7<br>8<br>9<br>10<br></pre><code><span class="hl_o"><</span><span class="hl_v">script</span><span class="hl_o">></span>
- <span class="hl_v">n</span> <span class="hl_o">=</span> <span class="hl_v">'838102050'</span> <span class="hl_c">// Set 'n' to a string</span>
- <span class="hl_f">document.write</span>(<span class="hl_v">'n</span> <span class="hl_o">=</span> <span class="hl_v">'</span> <span class="hl_o">+</span> <span class="hl_v">n</span> <span class="hl_o">+</span> <span class="hl_v">'</span>, <span class="hl_k">and</span> <span class="hl_k">is</span> <span class="hl_v">a</span> <span class="hl_v">'</span> <span class="hl_o">+</span> <span class="hl_v">typeof</span> <span class="hl_v">n</span> <span class="hl_o">+</span> <span class="hl_v">'</span><span class="hl_o"><</span><span class="hl_v">br</span><span class="hl_o">></span><span class="hl_v">'</span>)
- <span class="hl_v">n</span> <span class="hl_o">=</span> <span class="hl_n">12345</span> <span class="hl_o">*</span> <span class="hl_n">67890</span>; <span class="hl_c">// Set 'n' to a number</span>
- <span class="hl_f">document.write</span>(<span class="hl_v">'n</span> <span class="hl_o">=</span> <span class="hl_v">'</span> <span class="hl_o">+</span> <span class="hl_v">n</span> <span class="hl_o">+</span> <span class="hl_v">'</span>, <span class="hl_k">and</span> <span class="hl_k">is</span> <span class="hl_v">a</span> <span class="hl_v">'</span> <span class="hl_o">+</span> <span class="hl_v">typeof</span> <span class="hl_v">n</span> <span class="hl_o">+</span> <span class="hl_v">'</span><span class="hl_o"><</span><span class="hl_v">br</span><span class="hl_o">></span><span class="hl_v">'</span>)
- <span class="hl_v">n</span> <span class="hl_o">+=</span> <span class="hl_v">'</span> <span class="hl_v">plus</span> <span class="hl_v">some</span> <span class="hl_v">text'</span> <span class="hl_c">// Change 'n' from a number to a string</span>
- <span class="hl_f">document.write</span>(<span class="hl_v">'n</span> <span class="hl_o">=</span> <span class="hl_v">'</span> <span class="hl_o">+</span> <span class="hl_v">n</span> <span class="hl_o">+</span> <span class="hl_v">'</span>, <span class="hl_k">and</span> <span class="hl_k">is</span> <span class="hl_v">a</span> <span class="hl_v">'</span> <span class="hl_o">+</span> <span class="hl_v">typeof</span> <span class="hl_v">n</span> <span class="hl_o">+</span> <span class="hl_v">'</span><span class="hl_o"><</span><span class="hl_v">br</span><span class="hl_o">></span><span class="hl_v">'</span>)
- <span class="hl_o"></</span><span class="hl_v">script</span><span class="hl_o">></span></code></div>
- <p>La salida de este script se ve así:</p>
- <div class="pre"><pre>
- n = 838102050, and is a string
- n = 838102050, and is a number
- n = 838102050 plus some text, and is a string
- </pre></div>
- <p>Si alguna vez hay alguna duda sobre el tipo de dato de una variable, o necesitas asegurarte de que una variable tenga un tipo de dato en particular, puedes forzarla a ese tipo de dato utilizando declaraciones como las siguientes (que convierten respectivamente un string a un número y un número a un string):</p>
- <div class="pre"><pre class="lineno">1<br>2<br>3<br>4<br>5<br></pre><code><span class="hl_v">n</span> <span class="hl_o">=</span> <span class="hl_s">"123"</span>
- <span class="hl_v">n</span> <span class="hl_o">*=</span> <span class="hl_n">1</span> <span class="hl_c">// Convert 'n' into a number</span>
- <span class="hl_v">n</span> <span class="hl_o">=</span> <span class="hl_n">123</span>
- <span class="hl_v">n</span> <span class="hl_o">+=</span> <span class="hl_s">""</span> <span class="hl_c">// Convert 'n' into a string</span></code></div>
- <p>O puedes usar las siguientes funciones de la misma manera:</p>
- <div class="pre"><pre class="lineno">1<br>2<br>3<br>4<br>5<br>6<br></pre><code><span class="hl_v">n</span> <span class="hl_o">=</span> <span class="hl_s">"123"</span>
- <span class="hl_v">n</span> <span class="hl_o">=</span> <span class="hl_f">parseInt</span>(<span class="hl_v">n</span>) <span class="hl_c">// Convert 'n' into an integer number</span>
- <span class="hl_v">n</span> <span class="hl_o">=</span> <span class="hl_f">parseFloat</span>(<span class="hl_v">n</span>) <span class="hl_c">// Convert 'n' into a floating point number</span>
- <span class="hl_v">n</span> <span class="hl_o">=</span> <span class="hl_n">123</span>
- <span class="hl_v">n</span> <span class="hl_o">=</span> <span class="hl_f">n.toString</span>() <span class="hl_c">// Convert 'n' into a string</span></code></div>
- <p>Puedes leer más sobre la conversión de tipos de datos en JavaScript en línea (<a href="https://es.javascript.info/type-conversions" target="new">https://es.javascript.info/type-conversions</a>). Y siempre puedes consultar el tipo de dato de una variable usando el operador <samp>typeof</samp>.</p>
- <h2 id="explorando_javascript_funciones">Funciones<a href="#explorando_javascript_funciones"></a></h2>
- <p>Al igual que con PHP, las funciones en JavaScript se utilizan para separar secciones de código que realizan una tarea específica. Para crear una función, se declara de la manera que se muestra en el Ejemplo 14-4.</p>
- <p><i>Ejemplo 14-4. Una declaración simple de una función</i></p>
- <div class="pre"><pre class="lineno">1<br>2<br>3<br>4<br>5<br>6<br></pre><code><span class="hl_o"><</span><span class="hl_v">script</span><span class="hl_o">></span>
- <span class="hl_k">function</span> <span class="hl_f">product</span>(<span class="hl_v">a</span>, <span class="hl_v">b</span>)
- {
- <span class="hl_k">return</span> <span class="hl_v">a</span><span class="hl_o">*</span><span class="hl_v">b</span>
- }
- <span class="hl_o"></</span><span class="hl_v">script</span><span class="hl_o">></span></code></div>
- <p>Esta función toma los dos parámetros pasados, los multiplica y devuelve el resultado.</p>
- <h2 id="explorando_javascript_variables_globales">Variables globales<a href="#explorando_javascript_variables_globales"></a></h2>
- <p>Las <i>variables globales</i> son aquellas definidas fuera de cualquier función (o definidas dentro de funciones pero sin la palabra clave <samp>var</samp>). Pueden definirse de las siguientes maneras:</p>
- <div class="pre"><pre class="lineno">1<br>2<br>3<br></pre><code> <span class="hl_v">a</span> <span class="hl_o">=</span> <span class="hl_n">123</span> <span class="hl_c">// Global scope</span>
- <span class="hl_v">var</span> <span class="hl_v">b</span> <span class="hl_o">=</span> <span class="hl_n">456</span> <span class="hl_c">// Global scope</span>
- <span class="hl_k">if</span> (<span class="hl_v">a</span> <span class="hl_o">==</span> <span class="hl_n">123</span>) <span class="hl_v">var</span> <span class="hl_v">c</span> <span class="hl_o">=</span> <span class="hl_n">789</span> <span class="hl_c">// Global scope</span></code></div>
- <p>Independientemente si estás utilizando la palabra clave <samp>var</samp>, mientras una variable esté definida fuera de una función, su alcance es global. Esto significa que cada parte de un script puede tener acceso a él.</p>
- <h2 id="explorando_javascript_variables_locales">Variables locales<a href="#explorando_javascript_variables_locales"></a></h2>
- <p>Los parámetros pasados a una función automáticamente tienen un <i>alcance local</i>, es decir, solo pueden ser referenciados dentro de esa función. Sin embargo, hay una excepción. Los arrays se pasan a una función por referencia, por lo que si modificas cualquier elemento de un parámetro de tipo array, los elementos del array original serán modificados.</p>
- <p>Para definir una variable local que tenga alcance solo dentro de la función actual y que no haya sido pasada como parámetro, utiliza la palabra clave <samp>var</samp>. El Ejemplo 14-5 muestra una función que crea una variable con alcance global y dos con alcance local.</p>
- <p><i>Ejemplo 14-5. Una función que crea variables con alcance global y local</i></p>
- <div class="pre"><pre class="lineno">1<br>2<br>3<br>4<br>5<br>6<br>7<br>8<br></pre><code><span class="hl_o"><</span><span class="hl_v">script</span><span class="hl_o">></span>
- <span class="hl_k">function</span> <span class="hl_f">test</span>()
- {
- <span class="hl_v">a</span> <span class="hl_o">=</span> <span class="hl_n">123</span> <span class="hl_c">// Global scope</span>
- <span class="hl_v">var</span> <span class="hl_v">b</span> <span class="hl_o">=</span> <span class="hl_n">456</span> <span class="hl_c">// Local scope</span>
- <span class="hl_k">if</span> (<span class="hl_v">a</span> <span class="hl_o">==</span> <span class="hl_n">123</span>) <span class="hl_v">var</span> <span class="hl_v">c</span> <span class="hl_o">=</span> <span class="hl_n">789</span> <span class="hl_c">// Local scope</span>
- }
- <span class="hl_o"></</span><span class="hl_v">script</span><span class="hl_o">></span></code></div>
- <p>Para comprobar si la configuración del alcance ha funcionado en PHP, podemos usar la función <samp>isset</samp>. Pero en JavaScript no existe tal función, así que el Ejemplo 14-6 utiliza el operador <samp>typeof</samp>, que devuelve el string <samp>undefined</samp> cuando una variable no está definida.</p>
- <p><i>Ejemplo 14-6. Verificación del alcance de las variables definidas en la función test</i></p>
- <div class="pre"><pre class="lineno">1<br>2<br>3<br>4<br>5<br>6<br>7<br>8<br>9<br>10<br>11<br>12<br>13<br>14<br>15<br></pre><code><span class="hl_o"><</span><span class="hl_v">script</span><span class="hl_o">></span>
- <span class="hl_f">test</span>()
- <span class="hl_k">if</span> (<span class="hl_v">typeof</span> <span class="hl_v">a</span> <span class="hl_o">!=</span> <span class="hl_v">'undefined'</span>) <span class="hl_f">document.write</span>(<span class="hl_v">'a</span> <span class="hl_o">=</span> <span class="hl_s">"' + a + '"</span><span class="hl_o"><</span><span class="hl_v">br</span><span class="hl_o">></span><span class="hl_v">'</span>)
- <span class="hl_k">if</span> (<span class="hl_v">typeof</span> <span class="hl_v">b</span> <span class="hl_o">!=</span> <span class="hl_v">'undefined'</span>) <span class="hl_f">document.write</span>(<span class="hl_v">'b</span> <span class="hl_o">=</span> <span class="hl_s">"' + b + '"</span><span class="hl_o"><</span><span class="hl_v">br</span><span class="hl_o">></span><span class="hl_v">'</span>)
- <span class="hl_k">if</span> (<span class="hl_v">typeof</span> <span class="hl_v">c</span> <span class="hl_o">!=</span> <span class="hl_v">'undefined'</span>) <span class="hl_f">document.write</span>(<span class="hl_v">'c</span> <span class="hl_o">=</span> <span class="hl_s">"' + c + '"</span><span class="hl_o"><</span><span class="hl_v">br</span><span class="hl_o">></span><span class="hl_v">'</span>)
- <span class="hl_k">function</span> <span class="hl_f">test</span>()
- {
- <span class="hl_v">a</span> <span class="hl_o">=</span> <span class="hl_n">123</span>
- <span class="hl_v">var</span> <span class="hl_v">b</span> <span class="hl_o">=</span> <span class="hl_n">456</span>
- <span class="hl_k">if</span> (<span class="hl_v">a</span> <span class="hl_o">==</span> <span class="hl_n">123</span>) <span class="hl_v">var</span> <span class="hl_v">c</span> <span class="hl_o">=</span> <span class="hl_n">789</span>
- }
- <span class="hl_o"></</span><span class="hl_v">script</span><span class="hl_o">></span></code></div>
- <p>La salida de este script es la siguiente línea:</p>
- <div class="pre"><pre>
- a = "123"
- </pre></div>
- <p>Esto muestra que solo la variable <samp>a</samp> recibió un alcance global, que es exactamente lo que esperaríamos, ya que las variables <samp>b</samp> y <samp>c</samp> recibieron un alcance local al estar precedidas por la palabra clave <samp>var</samp>.</p>
- <p>Si tu navegador emite una advertencia sobre que <samp>b</samp> está indefinido, la advertencia es correcta pero se puede ignorar.</p>
- <h3 id="explorando_javascript_utilizando_let_const">Utilizando let y const<a href="#explorando_javascript_utilizando_let_const"></a></h3>
- <p>JavaScript ahora ofrece dos nuevas palabras clave: <samp>let</samp> y <samp>const</samp>. La palabra clave <samp>let</samp> es prácticamente un reemplazo para <samp>var</samp>, pero tiene la ventaja de que no puedes redeclarar una variable una vez que lo hayas hecho con <samp>let</samp>, aunque sí puedes con <samp>var</samp>.</p>
- <p>Verás, el hecho de que pudieras redeclarar variables utilizando <samp>var</samp> estaba llevando a errores oscuros, como el siguiente:</p>
- <div class="pre"><pre class="lineno">1<br>2<br>3<br>4<br>5<br>6<br>7<br>8<br>9<br></pre><code><span class="hl_v">var</span> <span class="hl_v">hello</span> <span class="hl_o">=</span> <span class="hl_s">"Hello there"</span>
- <span class="hl_v">var</span> <span class="hl_v">counter</span> <span class="hl_o">=</span> <span class="hl_n">1</span>
- <span class="hl_k">if</span> (<span class="hl_v">counter</span> <span class="hl_o">></span> <span class="hl_n">0</span>)
- {
- <span class="hl_v">var</span> <span class="hl_v">hello</span> <span class="hl_o">=</span> <span class="hl_s">"How are you?"</span>
- }
- <span class="hl_f">document.write</span>(<span class="hl_v">hello</span>)</code></div>
- <p>¿Puedes ver el problema? Debido a que <samp>counter</samp> es mayor que <samp>0</samp> (ya que lo inicializamos en <samp>1</samp>), el string <samp>hello</samp> se redefine como "How are you?" (¿Cómo estás?) y luego se muestra en el documento.</p>
- <p>Ahora, si reemplazas <samp>var</samp> con <samp>let</samp> (como lo siguiente), la segunda declaración será ignorada, y se mostrará el string original "Hello there":</p>
- <div class="pre"><pre class="lineno">1<br>2<br>3<br>4<br>5<br>6<br>7<br>8<br>9<br></pre><code><span class="hl_v">let</span> <span class="hl_v">hello</span> <span class="hl_o">=</span> <span class="hl_s">"Hello there"</span>
- <span class="hl_v">let</span> <span class="hl_v">counter</span> <span class="hl_o">=</span> <span class="hl_n">1</span>
- <span class="hl_k">if</span> (<span class="hl_v">counter</span> <span class="hl_o">></span> <span class="hl_n">0</span>)
- {
- <span class="hl_v">let</span> <span class="hl_v">hello</span> <span class="hl_o">=</span> <span class="hl_s">"How are you?"</span>
- }
- <span class="hl_f">document.write</span>(<span class="hl_v">hello</span>)</code></div>
- <p>La palabra clave <samp>var</samp> tiene un alcance global (si está fuera de cualquier bloque o función) o de <i>función</i>, y las variables declaradas se inicializan con <samp>undefined</samp>, pero la palabra clave <samp>let</samp> tiene un alcance global o de <i>bloque</i>, y las variables no se inicializan.</p>
- <p>Cualquier variable asignada utilizando <samp>let</samp> tiene un alcance dentro de todo el documento si se declara fuera de cualquier bloque, o, si se declara dentro de un bloque delimitado por <samp>{}</samp> (lo que incluye funciones), su alcance se limita a ese bloque (y cualquier sub-bloque anidado). Si declaras una variable dentro de un bloque pero intentas acceder a ella desde fuera de ese bloque, se devolverá un error, como en el siguiente caso, que fallará en el <samp>document.write</samp> porque <samp>hello</samp> no tendrá valor:</p>
- <div class="pre"><pre class="lineno">1<br>2<br>3<br>4<br>5<br>6<br>7<br>8<br></pre><code><span class="hl_v">let</span> <span class="hl_v">counter</span> <span class="hl_o">=</span> <span class="hl_n">1</span>
- <span class="hl_k">if</span> (<span class="hl_v">counter</span> <span class="hl_o">></span> <span class="hl_n">0</span>)
- {
- <span class="hl_v">let</span> <span class="hl_v">hello</span> <span class="hl_o">=</span> <span class="hl_s">"How are you?"</span>
- }
- <span class="hl_f">document.write</span>(<span class="hl_v">hello</span>)</code></div>
- <p>Puedes usar <samp>let</samp> para declarar variables con el mismo nombre que las variables previamente declaradas, siempre y cuando sean dentro de un nuevo ámbito, en cuyo caso cualquier valor anterior asignado a una variable con el mismo nombre en el ámbito anterior se volverá inaccesible para el nuevo ámbito, porque la nueva variable con el mismo nombre se maneja totalmente diferente de la anterior. Solo tiene alcance dentro del bloque actual, o de cualquier sub-bloque (a menos que se use otro <samp>let</samp> para declarar otra variable con el mismo nombre en un sub-bloque).</p>
- <p>Es una buena práctica intentar evitar la reutilización de nombres significativos de variables, o corres el riesgo de causar confusión. Sin embargo, las variables de bucle o índice como <samp>i</samp> (u otros nombres cortos y simples) generalmente pueden reutilizarse en nuevos ámbitos sin causar confusión.</p>
- <p>Puedes aumentar aún más tu control sobre el alcance declarando una variable con un valor constante, es decir, uno que no pueda ser cambiado. Esto es beneficioso cuando has creado una variable que lo estás tratando como una constante pero la has declarado utilizando solo <samp>var</samp> o <samp>let</samp>, porque podrías tener ocasiones que en tu código intentes cambiar ese valor, lo cual estaría permitido pero sería un error.</p>
- <p>Sin embargo, si utilizas la palabra clave <samp>const</samp> para declarar la variable y asignar su valor, cualquier intento de cambiar más tarde su valor será prohibido, y tu código se detendrá con un mensaje de error en la consola similar a:</p>
- <div class="pre"><pre>
- Uncaught TypeError: Assignment to constant variable
- </pre></div>
- <p>El siguiente código causará exactamente ese error:</p>
- <div class="pre"><pre class="lineno">1<br>2<br>3<br>4<br>5<br>6<br>7<br>8<br>9<br></pre><code><span class="hl_v">const</span> <span class="hl_v">hello</span> <span class="hl_o">=</span> <span class="hl_s">"Hello there"</span>
- <span class="hl_v">let</span> <span class="hl_v">counter</span> <span class="hl_o">=</span> <span class="hl_n">1</span>
- <span class="hl_k">if</span> (<span class="hl_v">counter</span> <span class="hl_o">></span> <span class="hl_n">0</span>)
- {
- <span class="hl_v">hello</span> <span class="hl_o">=</span> <span class="hl_s">"How are you?"</span>
- }
- <span class="hl_f">document.write</span>(<span class="hl_v">hello</span>)</code></div>
- <p>Al igual que <samp>let</samp>, las declaraciones <samp>const</samp> también tienen un alcance de bloque (dentro de secciones <samp>{}</samp> y cualquier sub-bloque), lo que significa que puedes tener variables constantes con el mismo nombre pero con diferentes valores en diferentes ámbitos de un fragmento de código. Sin embargo, te recomiendo encarecidamente que intentes evitar la duplicación de nombres y mantengas cualquier nombre de constante para un solo valor a lo largo de cada programa, utilizando un nuevo nombre de constante donde necesites una nueva constante.</p>
- <p>En resumen: <samp>var</samp> tiene un alcance global o de función, y <samp>let</samp> y <samp>const</samp> tienen un alcance global o de bloque. Tanto <samp>var</samp> como <samp>let</samp> pueden ser declarados sin ser inicializados, mientras que <samp>const</samp> debe ser inicializado durante la declaración. La palabra clave <samp>var</samp> se puede reutilizar para redeclarar una variable <samp>var</samp>, pero <samp>let</samp> y <samp>const</samp> no pueden. Finalmente, <samp>const</samp> no puede ser redeclarado ni reasignado.</p>
- <div class="info"><p><span>Nota</span></p><p>Es posible que prefieras utilizar una consola de desarrollador para pruebas como estas (y en otras partes de este libro) como se explicó anteriormente en <a href="#explorando_javascript_depuracion_errores_javascript" onclick="c('explorando_javascript_depuracion_errores_javascript')">"Depuración de errores en JavaScript"</a>, en cuyo caso puedes reemplazar <samp>document.write</samp> con <samp>console.log</samp>, y la salida se mostrará en la consola en lugar del documento del navegador. También es una mejor opción para que JavaScript se ejecute una vez que el documento se haya cargado completamente, porque en ese momento <samp>document.write</samp> reemplazaría el documento actual, en lugar de agregarle contenido, lo cual probablemente no sea lo que esperes.</p></div>
- <h2 id="explorando_javascript_document_object_model">El Document Object Model<a href="#explorando_javascript_document_object_model"></a></h2>
- <p>El diseño de JavaScript es muy inteligente. En lugar de simplemente crear otro lenguaje de scripting (lo que hubiera sido una mejora bastante buena en ese momento), había una visión de construirlo alrededor del ya existente Document Object Model de HTML. Este modelo descompone las partes de un documento HTML en <i>objetos</i> discretos, cada uno con sus respectivas <i>propiedades</i> y <i>métodos</i>, y cada uno sujeto al control de JavaScript.</p>
- <p>JavaScript separa objetos, propiedades y métodos utilizando un punto (una buena razón por la cual <samp>+</samp> es el operador de concatenación de strings en JavaScript, en lugar del punto). Por ejemplo, consideremos una tarjeta de presentación como un objeto al que llamaremos <samp>card</samp>. Este objeto contiene propiedades como su nombre, dirección, número de teléfono, y así sucesivamente. En la sintaxis de JavaScript, estas propiedades se verían así:</p>
- <div class="pre"><pre>
- card.name
- card.phone
- card.address
- </pre></div>
- <p>Sus métodos son funciones que recuperan, modifican y actúan de otras maneras sobre las propiedades. Por ejemplo, para invocar un método que muestre las propiedades del objeto <samp>card</samp>, podrías utilizar una sintaxis como esta:</p>
- <div class="pre"><pre class="lineno">1<br></pre><code><span class="hl_f">card.display</span>()</code></div>
- <p>Echa un vistazo a algunos de los ejemplos anteriores en este capítulo y observa dónde se utiliza la instrucción <samp>document.write</samp>. Ahora que entiendes cómo JavaScript se basa en objetos, verás que <samp>write</samp> es en realidad un método del objeto <samp>document</samp>.</p>
- <p>Dentro de JavaScript, existe una jerarquía de objetos padre e hijo, que es lo que se conoce como el Document Object Model. (DOM; ver Figura 14-3).</p>
- <div class="imgc"><img class="imgc" width="679" height="265" alt="figura_14-3.png" src=""></div>
- <div class="fig">Figura 14-3. Ejemplo de jerarquía de objetos del DOM</div>
- <p>La figura utiliza etiquetas HTML con las que ya estás familiarizado para ilustrar la relación padre/hijo entre los distintos objetos de un documento. Por ejemplo, una URL dentro de un enlace es parte del cuerpo de un documento HTML. En JavaScript, se hace referencia a ello así:</p>
- <div class="pre"><pre class="lineno">1<br></pre><code><span class="hl_v">url</span> <span class="hl_o">=</span> <span class="hl_v">document.links.linkname.href</span></code></div>
- <p>Observa cómo esto sigue la columna central hacia abajo. La primera parte, <samp>document</samp>, se refiere a las etiquetas <samp><html></samp> y <samp><body></samp>; <samp>links.linkname</samp> se refiere a la etiqueta <samp><a></samp>, y <samp>href</samp> al atributo <samp>href</samp>.</p>
- <p>Vamos a convertir la expresión en HTML y un script para leer las propiedades de un enlace. Escribe el Ejemplo 14-7 y guárdalo como <i>linktest.html</i>; luego ábrelo en tu navegador.</p>
- <p><i>Ejemplo 14-7. Leer una URL de un enlace con JavaScript</i></p>
- <div class="pre"><pre class="lineno">1<br>2<br>3<br>4<br>5<br>6<br>7<br>8<br>9<br>10<br>11<br>12<br></pre><code><span class="hl_o"><</span><span class="hl_v">html</span><span class="hl_o">></span>
- <span class="hl_o"><</span><span class="hl_v">head</span><span class="hl_o">></span>
- <span class="hl_o"><</span><span class="hl_v">title</span><span class="hl_o">></span><span class="hl_v">Link</span> <span class="hl_v">Test</span><span class="hl_o"></</span><span class="hl_v">title</span><span class="hl_o">></span>
- <span class="hl_o"></</span><span class="hl_v">head</span><span class="hl_o">></span>
- <span class="hl_o"><</span><span class="hl_v">body</span><span class="hl_o">></span>
- <span class="hl_o"><</span><span class="hl_v">a</span> <span class="hl_v">id</span><span class="hl_o">=</span><span class="hl_s">"mylink"</span> <span class="hl_v">href</span><span class="hl_o">=</span><span class="hl_s">"http://mysite.com"</span><span class="hl_o">></span><span class="hl_v">Click</span> <span class="hl_v">me</span><span class="hl_o"></</span><span class="hl_v">a</span><span class="hl_o">><</span><span class="hl_v">br</span><span class="hl_o">></span>
- <span class="hl_o"><</span><span class="hl_v">script</span><span class="hl_o">></span>
- <span class="hl_v">url</span> <span class="hl_o">=</span> <span class="hl_v">document.links.mylink.href</span>
- <span class="hl_f">document.write</span>(<span class="hl_v">'The</span> <span class="hl_v">URL</span> <span class="hl_k">is</span> <span class="hl_v">'</span> <span class="hl_o">+</span> <span class="hl_v">url</span>)
- <span class="hl_o"></</span><span class="hl_v">script</span><span class="hl_o">></span>
- <span class="hl_o"></</span><span class="hl_v">body</span><span class="hl_o">></span>
- <span class="hl_o"></</span><span class="hl_v">html</span><span class="hl_o">></span></code></div>
- <p>Observa la forma corta de las etiquetas <samp><script></samp>, donde he omitido el parámetro <samp>type="text/JavaScript"</samp> para ahorrarte un poco de escritura. Si lo deseas, solo con el fin de probar esto (y otros ejemplos), también podrías omitir todo lo que esté fuera de las etiquetas <samp><script></samp> y <samp></script></samp>. El resultado de este ejemplo es el siguiente:</p>
- <div class="pre"><pre>
- <span class="hl_h">Click me</span>
- The URL is http://mysite.com
- </pre></div>
- <p>La segunda línea de la salida proviene del método <samp>document.write</samp>. Observa cómo el código sigue el árbol del documento desde <samp>document</samp> hasta <samp>links</samp>, luego a <samp>mylink</samp> (el <samp>id</samp> dado al enlace) y finalmente a <samp>href</samp> (el valor de destino de la URL).</p>
- <p>También hay una forma corta que funciona igual de bien, que comienza con el valor en el atributo <samp>id</samp>: <samp>mylink.href</samp>. Entonces, puedes reemplazar esto:</p>
- <div class="pre"><pre class="lineno">1<br></pre><code><span class="hl_v">url</span> <span class="hl_o">=</span> <span class="hl_v">document.links.mylink.href</span></code></div>
- <p>con lo siguiente:</p>
- <div class="pre"><pre class="lineno">1<br></pre><code><span class="hl_v">url</span> <span class="hl_o">=</span> <span class="hl_v">mylink.href</span></code></div>
- <h3 id="explorando_javascript_otro_uso_simbolo">Otro uso del símbolo $<a href="#explorando_javascript_otro_uso_simbolo"></a></h3>
- <p>Como se mencionó anteriormente, el símbolo <samp>$</samp> está permitido en los nombres de variables y funciones de JavaScript. Debido a esto, a veces puedes encontrarte con código de aspecto extraño como este:</p>
- <div class="pre"><pre class="lineno">1<br></pre><code><span class="hl_v">url</span> <span class="hl_o">=</span> <span class="hl_f">$</span>(<span class="hl_v">'mylink'</span>)<span class="hl_v">.href</span></code></div>
- <p>Algunos programadores con iniciativa han decidido que la función <samp>getElementById</samp> es tan importante en JavaScript que han escrito una función para reemplazar la llamada <samp>$</samp>, como en jQuery (aunque jQuery usa el <samp>$</samp> para mucho más que eso ver <a href="#introduccion_jquery" onclick="c('introduccion_jquery')">Capítulo 22</a>), como se muestra en el Ejemplo 14-8.</p>
- <p><i>Ejemplo 14-8. Una función que reemplaza el método <samp>getElementById</samp></i></p>
- <div class="pre"><pre class="lineno">1<br>2<br>3<br>4<br>5<br>6<br></pre><code><span class="hl_o"><</span><span class="hl_v">script</span><span class="hl_o">></span>
- <span class="hl_k">function</span> <span class="hl_f">$</span>(<span class="hl_v">id</span>)
- {
- <span class="hl_k">return</span> <span class="hl_f">document.getElementById</span>(<span class="hl_v">id</span>)
- }
- <span class="hl_o"></</span><span class="hl_v">script</span><span class="hl_o">></span></code></div>
- <p>Por lo tanto, siempre y cuando hayas incluido la función <samp>$</samp> en tu código, una sintaxis como esta:</p>
- <div class="pre"><pre class="lineno">1<br></pre><code><span class="hl_f">$</span>(<span class="hl_v">'mylink'</span>)<span class="hl_v">.href</span></code></div>
- <p>puede reemplazar al siguiente código:</p>
- <div class="pre"><pre class="lineno">1<br></pre><code><span class="hl_f">document.getElementById</span>(<span class="hl_v">'mylink'</span>)<span class="hl_v">.href</span></code></div>
- <h3 id="explorando_javascript_utilizando_dom">Utilizando el DOM<a href="#explorando_javascript_utilizando_dom"></a></h3>
- <p>El objeto <samp>links</samp> es en realidad un array de URLs, por lo que la URL <samp>mylink</samp> en el <a href="#explorando_javascript_document_object_model" onclick="c('explorando_javascript_document_object_model')">Ejemplo 14-7</a> también puede referirse de manera segura en todos los navegadores de la siguiente manera (porque es el primer y único enlace):</p>
- <div class="pre"><pre class="lineno">1<br></pre><code><span class="hl_v">url</span> <span class="hl_o">=</span> <span class="hl_v">document.links</span>[<span class="hl_n">0</span>]<span class="hl_v">.href</span></code></div>
- <p>Si quieres saber cuántos enlaces hay en un documento completo, puedes consultar la propiedad <samp>length</samp> del objeto <samp>links</samp> así:</p>
- <div class="pre"><pre class="lineno">1<br></pre><code><span class="hl_v">numlinks</span> <span class="hl_o">=</span> <span class="hl_v">document.links.length</span></code></div>
- <p>Puedes extraer y mostrar todos los enlaces en un documento de esta manera:</p>
- <div class="pre"><pre class="lineno">1<br>2<br></pre><code><span class="hl_k">for</span> (<span class="hl_v">j</span> <span class="hl_o">=</span> <span class="hl_n">0</span>; <span class="hl_v">j</span> <span class="hl_o"><</span> <span class="hl_v">document.links.length</span>; <span class="hl_o">++</span><span class="hl_v">j</span>)
- <span class="hl_f">document.write</span>(<span class="hl_v">document.links</span>[<span class="hl_v">j</span>]<span class="hl_v">.href</span> <span class="hl_o">+</span> <span class="hl_v">'</span><span class="hl_o"><</span><span class="hl_v">br</span><span class="hl_o">></span><span class="hl_v">'</span>)</code></div>
- <p>El <samp>length</samp> de algo es una propiedad de cada array, y de muchos objetos también. Por ejemplo, el número de elementos en el historial web de tu navegador se puede consultar así:</p>
- <div class="pre"><pre class="lineno">1<br></pre><code><span class="hl_f">document.write</span>(<span class="hl_v">history.length</span>)</code></div>
- <p>Para evitar que los sitios web espíen tu historial de navegación, el objeto <samp>history</samp> almacena solo el número de sitios en el array: no puedes leer ni escribir en estos valores. Pero puedes reemplazar la página actual con una del historial, si sabes en qué posición se encuentra dentro del historial. Esto puede ser muy útil en casos en los que sabes que ciertas páginas en el historial provienen de tu sitio, o simplemente desees que el navegador retroceda una o más páginas, lo cual puedes hacer con el método <samp>go</samp> del objeto <samp>history</samp>. Por ejemplo, para hacer que el navegador retroceda tres páginas, emita el siguiente comando:</p>
- <div class="pre"><pre class="lineno">1<br></pre><code><span class="hl_f">history.go</span>(<span class="hl_n">-3</span>)</code></div>
- <p>También puedes utilizar los siguientes métodos para avanzar o retroceder una página a la vez:</p>
- <div class="pre"><pre class="lineno">1<br>2<br></pre><code><span class="hl_f">history.back</span>()
- <span class="hl_f">history.forward</span>()</code></div>
- <p>De manera similar, puedes reemplazar la URL actualmente cargada con una de tu elección, así:</p>
- <div class="pre"><pre class="lineno">1<br></pre><code><span class="hl_v">document.location.href</span> <span class="hl_o">=</span> <span class="hl_v">'http</span><span class="hl_o">:</span><span class="hl_c">//google.com'</span></code></div>
- <p>Por supuesto, hay mucho más cosas en el DOM que leer y modificar enlaces. A medida que avances a través de los siguientes capítulos sobre JavaScript, te familiarizarás bastante con el DOM y en la manera de cómo acceder a él.</p>
- <h2 id="explorando_javascript_sobre_document_write">Sobre document.write<a href="#explorando_javascript_sobre_document_write"></a></h2>
- <p>Al enseñar programación, es necesario tener una forma rápida y fácil de mostrar los resultados de las expresiones. En PHP (por ejemplo) existen las declaraciones <samp>echo</samp> y <samp>print</samp>, que simplemente envían texto al navegador, así que es fácil. En JavaScript, sin embargo, existen las siguientes alternativas.</p>
- <h3 id="explorando_javascript_utilizando_console_log">Utilizando console.log<a href="#explorando_javascript_utilizando_console_log"></a></h3>
- <p>La función <samp>console.log</samp> mostrará en la consola del navegador actual el resultado de cualquier valor o expresión que se le pase. Se trata de un modo especial de presentación, con un marco o ventana separada de la ventana del navegador, en la cual se pueden mostrar errores y otros mensajes. Aunque es genial para programadores experimentados, no es la mejor opción para principiantes porque la salida no se parece al contenido web en el navegador.</p>
- <h3 id="explorando_javascript_utilizando_alert">Utilizando alert<a href="#explorando_javascript_utilizando_alert"></a></h3>
- <p>La función <samp>alert</samp> muestra en una ventana emergente valores o expresiones que se le pasan, la cual requiere que hagas clic en un botón para cerrarla. Claramente, esto puede volverse bastante irritante muy rápidamente, y tiene la desventaja de mostrar solo el mensaje actual, borrando los anteriores.</p>
- <h3 id="explorando_javascript_escritura_elementos">Escritura en elementos<a href="#explorando_javascript_escritura_elementos"></a></h3>
- <p>Es posible escribir directamente en el texto de un elemento HTML, lo cual es una solución bastante elegante (y la mejor para sitios web en producción), excepto que para este libro cada ejemplo requeriría que se creara dicho elemento y algunas líneas de código JavaScript para acceder a él. Esto interfiere con la enseñanza principal de un ejemplo y haría que el código pareciera excesivamente engorroso y confuso.</p>
- <h3 id="explorando_javascript_utilizando_document_write">Utilizando document.write<a href="#explorando_javascript_utilizando_document_write"></a></h3>
- <p>La función <samp>document.write</samp> escribe un valor o expresión en la ubicación actual del navegador y, por lo tanto, es la opción perfecta para mostrar resultados rápidamente. Mantiene todos los ejemplos breves y concisos, colocando la salida justo allí en el navegador junto al contenido web y el código.</p>
- <p>Sin embargo, es posible que hayas escuchado que esta función es considerada insegura por algunos desarrolladores, porque cuando la llamas después de que una página web se ha cargado completamente, sobrescribirá el documento actual. Aunque esto es correcto, no se aplica a ninguno de los ejemplos de este libro, porque todos ellos utilizan <samp>document.write</samp> de la manera en que originalmente se pretendía: como parte del proceso de creación de la página, llamándolo solo antes de que la página haya terminado de cargarse y mostrarse.</p>
- <p>No obstante, aunque uso <samp>document.write</samp> de esta manera para ejemplos simples, nunca lo utilizo en código de producción (excepto en las circunstancias más raras en las que realmente es necesario). En su lugar, casi siempre utilizo la opción anterior de escribir directamente en un elemento especialmente preparado, como en los ejemplos más complejos a partir del <a href="#utilizando_comunicaciones_asincronas" onclick="c('utilizando_comunicaciones_asincronas')">Capítulo 18</a>. (que acceden a la propiedad <samp>innerHTML</samp> de los elementos para presentar la salida del programa).</p>
- <p>Así que, por favor, recuerda que cuando veas que se llama a <samp>document.write</samp> en este libro, está ahí solo para simplificar un ejemplo, y les recomiendo que también usen la función de la misma manera para obtener resultados rápidos de prueba.</p>
- <p>Con la advertencia explicada, en el siguiente capítulo continuaremos nuestra exploración con JavaScript analizando cómo controlar el flujo del programa y escribir expresiones.</p>
- <h2 id="explorando_javascript_preguntas">Preguntas<a href="#explorando_javascript_preguntas"></a></h2>
- <ol>
- <li>¿Qué etiquetas utilizas para incluir código JavaScript?</li>
- <li>Por defecto, ¿a qué parte de un documento se enviará la salida del código JavaScript?</li>
- <li>¿Cómo puedes incluir código JavaScript desde otra fuente en tus documentos?</li>
- <li>¿Qué función de JavaScript es equivalente a <samp>echo</samp> o <samp>print</samp> de PHP?</li>
- <li>¿Cómo puedes crear un comentario en JavaScript?</li>
- <li>¿Cuál es el operador de concatenación de strings en JavaScript?</li>
- <li>¿Qué palabra clave puedes utilizar dentro de una función en JavaScript para definir una variable que tenga un alcance local?</li>
- <li>Proporciona dos métodos compatibles con múltiples navegadores para mostrar la URL asignada al enlace con un <samp>id</samp> de <samp>thislink</samp>.</li>
- <li>¿Qué dos comandos de JavaScript harán que el navegador cargue la página anterior en su array de historial?</li>
- <li>¿Qué comando de JavaScript usarías para reemplazar el documento actual con la página principal del sitio web <i>oreilly.com</i>?</li>
- </ol>
- <p>Ver <a href="#soluciones_preguntas_capitulos_respuestas_capitulo_14" onclick="c('soluciones_preguntas_capitulos_respuestas_capitulo_14')">"Respuestas del capítulo 14"</a> del <a href="#soluciones_preguntas_capitulos" onclick="c('soluciones_preguntas_capitulos')">Apéndice A</a> para comprobar las respuestas a estas preguntas.</p><br style="clear:both;"><label class="btn prev" accesskey="p" for="_cookies_sesiones_autenticacion" title="Cookies, sesiones y autenticación">Volver</label><label class="btn next" accesskey="n" for="_expresiones_control_flujo_javascript" title="Expresiones y control de flujo en JavaScript">Siguiente</label></div>
- <div class="page" rel="expresiones_control_flujo_javascript"><div><ul class="breadcrumbs"><li><label class="home" for="_" title="Inicio"></label> »</li><li> Capítulo 15 »</li><li> Expresiones y control de flujo en JavaScript</li></ul><hr></div>
- <h1 id="expresiones_control_flujo_javascript">Expresiones y control de flujo en JavaScript<a href="#expresiones_control_flujo_javascript"></a></h1>
- <p>En el capítulo anterior, introduje los conceptos básicos de JavaScript y el DOM. Ahora es el momento de ver cómo construir expresiones complejas en JavaScript y cómo controlar el flujo del programa de tus scripts utilizando declaraciones condicionales.</p>
- <h2 id="expresiones_control_flujo_javascript_expresiones">Expresiones<a href="#expresiones_control_flujo_javascript_expresiones"></a></h2>
- <p>Las expresiones de JavaScript son muy similares a las de PHP. Como aprendiste en el <a href="#expresiones_control_flujo_php" onclick="c('expresiones_control_flujo_php')">Capítulo 4</a>, una expresión es una combinación de valores, variables, operadores y funciones que da como resultado un valor; el resultado puede ser un número, un string o un valor booleano (que se evalúa como <samp>true</samp> o <samp>false</samp>).</p>
- <p>El ejemplo 15-1 muestra algunas expresiones simples. En cada línea, imprime una letra entre <samp>a</samp> y <samp>d</samp>, seguida de dos puntos y el resultado de las expresiones. La etiqueta <samp><br></samp> está ahí para crear un salto de línea y separar la salida en cuatro líneas (recuerda que tanto <samp><br></samp> como <samp><br/></samp> son aceptables en HTML5, así que decidí utilizar el primer estilo por brevedad).</p>
- <p><i>Ejemplo 15-1. Cuatro simples expresiones booleanas</i></p>
- <div class="pre"><pre class="lineno">1<br>2<br>3<br>4<br>5<br>6<br></pre><code><span class="hl_o"><</span><span class="hl_v">script</span><span class="hl_o">></span>
- <span class="hl_f">document.write</span>(<span class="hl_s">"a: "</span> <span class="hl_o">+</span> (<span class="hl_n">42</span> <span class="hl_o">></span> <span class="hl_n">3</span>) <span class="hl_o">+</span> <span class="hl_s">"<br>"</span>)
- <span class="hl_f">document.write</span>(<span class="hl_s">"b: "</span> <span class="hl_o">+</span> (<span class="hl_n">91</span> <span class="hl_o"><</span> <span class="hl_n">4</span>) <span class="hl_o">+</span> <span class="hl_s">"<br>"</span>)
- <span class="hl_f">document.write</span>(<span class="hl_s">"c: "</span> <span class="hl_o">+</span> (<span class="hl_n">8</span> <span class="hl_o">==</span> <span class="hl_n">2</span>) <span class="hl_o">+</span> <span class="hl_s">"<br>"</span>)
- <span class="hl_f">document.write</span>(<span class="hl_s">"d: "</span> <span class="hl_o">+</span> (<span class="hl_n">4</span> <span class="hl_o"><</span> <span class="hl_n">17</span>) <span class="hl_o">+</span> <span class="hl_s">"<br>"</span>)
- <span class="hl_o"></</span><span class="hl_v">script</span><span class="hl_o">></span></code></div>
- <p>La salida de este código es la siguiente:</p>
- <div class="pre"><pre>
- a: true
- b: false
- c: false
- d: true
- </pre></div>
- <p>Nota que ambas expresiones <samp>a:</samp> y <samp>d:</samp> se evalúan como <samp>true</samp>, pero <samp>b:</samp> y <samp>c:</samp> se evalúan como <samp>false</samp>. A diferencia de PHP (que imprimiría el número <samp>1</samp> y nada, respectivamente), se muestran los strings <samp>true</samp> y <samp>false</samp>.</p>
- <p>En JavaScript, cuando estás comprobando si un valor es <samp>true</samp> o <samp>false</samp>, todos los valores se evalúan como <samp>true</samp> excepto los siguientes, que se evalúan como <samp>false</samp>: el string <samp>false</samp> en sí misma, <samp>0</samp>, <samp>-0</samp>, la cadena vacía, <samp>null</samp>, <samp>undefined</samp> y <samp>NaN</samp> (Not a Number, un concepto de ingeniería informática para el resultado de una operación ilegal de punto flotante como la división entre cero).</p>
- <p>Como puedes ver, me estoy refiriendo a <samp>true</samp> y <samp>false</samp> en minúsculas. Esto se debe a que, a diferencia de PHP, estos valores <i>deben estar</i> en minúsculas en JavaScript. Por lo tanto, solo se mostrará la primera de las dos siguientes sentencias, imprimiendo la palabra en minúsculas <samp>true</samp>, porque la segunda causará un error de '<samp>TRUE</samp>' no está definido:</p>
- <div class="pre"><pre class="lineno">1<br>2<br></pre><code><span class="hl_k">if</span> (<span class="hl_n">1</span> <span class="hl_o">==</span> <span class="hl_t">true</span>) <span class="hl_f">document.write</span>(<span class="hl_v">'true'</span>) <span class="hl_c">// True</span>
- <span class="hl_k">if</span> (<span class="hl_n">1</span> <span class="hl_o">==</span> <span class="hl_t">TRUE</span>) <span class="hl_f">document.write</span>(<span class="hl_v">'TRUE'</span>) <span class="hl_c">// Will cause an error</span></code></div>
- <div class="info"><p><span>Nota</span></p><p>Recuerda que cualquier fragmento de código que desees escribir y probar por ti mismo en un archivo HTML, debe estar encerrado dentro de las etiquetas <samp><script></samp> y <samp></script></samp>.</p></div>
- <h2 id="expresiones_control_flujo_javascript_literales_variables">Literales y variables<a href="#expresiones_control_flujo_javascript_literales_variables"></a></h2>
- <p>La forma más simple de una expresión es una <i>literal</i>, que significa algo que se evalúa a sí mismo, como el número <samp>22</samp> o el string <samp>Presiona Enter</samp>. Una expresión también podría ser una variable, que evalúa el valor que se le ha asignado. Ambos son tipos de expresiones, porque devuelven un valor.</p>
- <p>El Ejemplo 15-2 muestra tres literales diferentes y dos variables, todas ellas devuelven valores, aunque de diferentes tipos.</p>
- <p><i>Ejemplo 15-2. Cinco tipos de literales</i></p>
- <div class="pre"><pre class="lineno">1<br>2<br>3<br>4<br>5<br>6<br>7<br>8<br>9<br></pre><code><span class="hl_o"><</span><span class="hl_v">script</span><span class="hl_o">></span>
- <span class="hl_v">myname</span> <span class="hl_o">=</span> <span class="hl_s">"Peter"</span>
- <span class="hl_v">myage</span> <span class="hl_o">=</span> <span class="hl_n">24</span>
- <span class="hl_f">document.write</span>(<span class="hl_s">"a: "</span> <span class="hl_o">+</span> <span class="hl_n">42</span> <span class="hl_o">+</span> <span class="hl_s">"<br>"</span>) <span class="hl_c">// Numeric literal</span>
- <span class="hl_f">document.write</span>(<span class="hl_s">"b: "</span> <span class="hl_o">+</span> <span class="hl_s">"Hi"</span> <span class="hl_o">+</span> <span class="hl_s">"<br>"</span>) <span class="hl_c">// String literal</span>
- <span class="hl_f">document.write</span>(<span class="hl_s">"c: "</span> <span class="hl_o">+</span> <span class="hl_t">true</span> <span class="hl_o">+</span> <span class="hl_s">"<br>"</span>) <span class="hl_c">// Boolean literal</span>
- <span class="hl_f">document.write</span>(<span class="hl_s">"d: "</span> <span class="hl_o">+</span> <span class="hl_v">myname</span> <span class="hl_o">+</span> <span class="hl_s">"<br>"</span>) <span class="hl_c">// String variable</span>
- <span class="hl_f">document.write</span>(<span class="hl_s">"e: "</span> <span class="hl_o">+</span> <span class="hl_v">myage</span> <span class="hl_o">+</span> <span class="hl_s">"<br>"</span>) <span class="hl_c">// Numeric variable</span>
- <span class="hl_o"></</span><span class="hl_v">script</span><span class="hl_o">></span></code></div>
- <p>Y, como es de esperar, puedes ver el valor de retorno de todo esto en la siguiente salida:</p>
- <div class="pre"><pre>
- a: 42
- b: Hi
- c: true
- d: Peter
- e: 24
- </pre></div>
- <p>Los operadores te permiten crear expresiones más complejas que se evalúan en resultados útiles. Cuando combinas asignaciones o estructuras de control de flujo con expresiones, el resultado es una <i>sentencia</i>.</p>
- <p>El ejemplo 15-3 muestra uno de cada uno. El primero asigna el resultado de la expresión <samp>366 - day_number</samp> a la variable <samp>days_to_new_year</samp>, y el segundo muestra un mensaje amigable solo si la expresión <samp>days_to_new_year < 30</samp> se evalúa como <samp>true</samp>.</p>
- <p><i>Ejemplo 15-3. Dos sentencias simples de JavaScript</i></p>
- <div class="pre"><pre class="lineno">1<br>2<br>3<br>4<br>5<br>6<br></pre><code><span class="hl_o"><</span><span class="hl_v">script</span><span class="hl_o">></span>
- <span class="hl_v">day_number</span> <span class="hl_o">=</span> <span class="hl_n">127</span> <span class="hl_c">// For example</span>
- <span class="hl_v">days_to_new_year</span> <span class="hl_o">=</span> <span class="hl_n">366</span> <span class="hl_o">-</span> <span class="hl_v">day_number</span>
- <span class="hl_k">if</span> (<span class="hl_v">days_to_new_year</span> <span class="hl_o"><</span> <span class="hl_n">30</span>) <span class="hl_f">document.write</span>(<span class="hl_s">"It's nearly New Year"</span>)
- <span class="hl_k">else</span> <span class="hl_f">document.write</span>(<span class="hl_s">"It's a long time to go"</span>)
- <span class="hl_o"></</span><span class="hl_v">script</span><span class="hl_o">></span></code></div>
- <h2 id="expresiones_control_flujo_javascript_operadores">Operadores<a href="#expresiones_control_flujo_javascript_operadores"></a></h2>
- <p>JavaScript ofrece muchos operadores potentes, que van desde operadores aritméticos, de string y lógicos hasta de asignación, comparación, etc. (ver la Tabla 15-1).</p>
- <p><i>Tabla 15-1. Tipos de operadores de JavaScript</i></p>
- <div class="table"><table>
- <tr>
- <th>Operador</th>
- <th>Descripción</th>
- <th>Ejemplo</th>
- </tr>
- <tr>
- <td>Aritmético</td>
- <td>Matemáticas básicas</td>
- <td><samp>a + b</samp></td>
- </tr>
- <tr>
- <td>Array</td>
- <td>Manipulación de arrays</td>
- <td><samp>a + b</samp></td>
- </tr>
- <tr>
- <td>Asignación</td>
- <td>Asignar valores</td>
- <td><samp>a = b + 23</samp></td>
- </tr>
- <tr>
- <td>Operador a nivel de bit</td>
- <td>Manipula bits en bytes</td>
- <td><samp>12 ^ 9</samp></td>
- </tr>
- <tr>
- <td>Comparación</td>
- <td>Comparar dos valores </td>
- <td><samp>a < b</samp></td>
- </tr>
- <tr>
- <td>Incremento/decremento</td>
- <td>Sumar o restar en uno </td>
- <td><samp>a++</samp></td>
- </tr>
- <tr>
- <td>Lógico</td>
- <td>Booleano</td>
- <td><samp>a && b</samp></td>
- </tr>
- <tr>
- <td>String</td>
- <td>Concatenación</td>
- <td><samp>a + 'string'</samp></td>
- </tr>
- </table></div>
- <p>Cada operador admite un número diferente de operandos:</p>
- <ul>
- <li>Los <i>operadores unarios</i>, como el incremento (<samp>a++</samp>) o la negación (<samp>-a</samp>), admiten un solo operando.</li>
- <li>Los <i>operadores binarios</i>, que representan la mayoría de los operadores de JavaScript (incluyendo la suma, la resta, la multiplicación y la división) admiten dos operandos.</li>
- <li>El único <i>operador ternario</i>, que adopta la forma <samp>? x : y</samp>, requiere tres operandos. Es una declaración <samp>if</samp> concisa de una sola línea que elige entre dos expresiones en función de una tercera.</li>
- </ul>
- <h3 id="expresiones_control_flujo_javascript_precedencia_operadores">Precedencia de operadores<a href="#expresiones_control_flujo_javascript_precedencia_operadores"></a></h3>
- <p>Al igual que PHP, JavaScript utiliza la precedencia de operadores, en la que algunos operadores de una expresión se procesan antes que otros y, por lo tanto, se evalúan primero. La Tabla 15-2 enumera los operadores de JavaScript y sus precedencias.</p>
- <p><i>Tabla 15-2. Precedencia de los operadores de JavaScript (de mayor a menor)</i></p>
- <div class="table"><table>
- <tr>
- <th>Operador(es)</th>
- <th>Tipo(s)</th>
- </tr>
- <tr>
- <td><samp>()</samp> <samp>[]</samp> <samp>.</samp></td>
- <td>Paréntesis, llamada, y miembro</td>
- </tr>
- <tr>
- <td><samp>++</samp> <samp>--</samp></td>
- <td>Incremento/decremento</td>
- </tr>
- <tr>
- <td><samp>+</samp> <samp>-</samp> <samp>~</samp> <samp>!</samp></td>
- <td>Unario, operador a nivel de bit y lógico</td>
- </tr>
- <tr>
- <td><samp>*</samp> <samp>/</samp> <samp>%</samp></td>
- <td>Aritmético</td>
- </tr>
- <tr>
- <td><samp>+</samp> <samp>-</samp></td>
- <td>Aritmético y string</td>
- </tr>
- <tr>
- <td><samp><<</samp> <samp>>></samp> <samp>>>></samp></td>
- <td>Operador a nivel de bit</td>
- </tr>
- <tr>
- <td><samp><</samp> <samp>></samp> <samp><=</samp> <samp>>=</samp></td>
- <td>Comparación</td>
- </tr>
- <tr>
- <td><samp>==</samp> <samp>!=</samp> <samp>===</samp> <samp>!==</samp></td>
- <td>Comparación</td>
- </tr>
- <tr>
- <td><samp>&</samp> <samp>^</samp> <samp>|</samp></td>
- <td>Operador a nivel de bit</td>
- </tr>
- <tr>
- <td><samp>&&</samp></td>
- <td>Lógico</td>
- </tr>
- <tr>
- <td><samp>||</samp></td>
- <td>Lógico</td>
- </tr>
- <tr>
- <td><samp>?:</samp></td>
- <td>Ternario</td>
- </tr>
- <tr>
- <td><samp>=</samp> <samp>+=</samp> <samp>-=</samp> <samp>*=</samp> <samp>/=</samp> <samp>%=</samp></td>
- <td>Asignación</td>
- </tr>
- <tr>
- <td><samp><<=</samp> <samp>>>=</samp> <samp>>>>=</samp> <samp>&=</samp> <samp>^=</samp> <samp>|=</samp></td>
- <td>Asignación</td>
- </tr>
- <tr>
- <td><samp>,</samp></td>
- <td>Separador</td>
- </tr>
- </table></div>
- <h3 id="expresiones_control_flujo_javascript_asociatividad">Asociatividad<a href="#expresiones_control_flujo_javascript_asociatividad"></a></h3>
- <p>La mayoría de los operadores en JavaScript se procesan de izquierda a derecha en una ecuación. Pero algunos operadores en su lugar requieren un procesamiento de derecha a izquierda. La dirección del procesamiento se denomina <i>asociatividad del operador</i>.</p>
- <p>Esta asociatividad se vuelve importante cuando no fuerzas explícitamente la precedencia (lo cual deberías hacer siempre, por cierto, porque hace que el código sea más legible y menos propenso a errores). Por ejemplo, observe los siguientes operadores de asignación, mediante los cuales se establecen tres variables con en el valor <samp>0</samp>:</p>
- <div class="pre"><pre class="lineno">1<br></pre><code><span class="hl_v">level</span> <span class="hl_o">=</span> <span class="hl_v">score</span> <span class="hl_o">=</span> <span class="hl_v">time</span> <span class="hl_o">=</span> <span class="hl_n">0</span></code></div>
- <p>Esta asignación múltiple solo es posible porque la parte más a la derecha de la expresión se evalúa primero y luego el procesamiento continúa de derecha a izquierda. La Tabla 15-3 enumera los operadores de JavaScript y su asociatividad.</p>
- <p><i>Tabla 15-3. Operadores y asociatividad</i></p>
- <div class="table"><table>
- <tr>
- <th>Operador</th>
- <th>Descripción</th>
- <th>Asociatividad</th>
- </tr>
- <tr>
- <td><samp>++</samp> <samp>--</samp></td>
- <td>Incremento y decremento</td>
- <td>Ninguna</td>
- </tr>
- <tr>
- <td><samp>new</samp></td>
- <td>Crea un nuevo objecto</td>
- <td>Derecha</td>
- </tr>
- <tr>
- <td><samp>+</samp> <samp>-</samp> <samp>~</samp> <samp>!</samp></td>
- <td>Unario y operador a nivel de bit</td>
- <td>Derecha</td>
- </tr>
- <tr>
- <td><samp>?:</samp></td>
- <td>Ternario</td>
- <td>Derecha</td>
- </tr>
- <tr>
- <td><samp>=</samp> <samp>*=</samp> <samp>/=</samp> <samp>%=</samp> <samp>+=</samp> <samp>-=</samp></td>
- <td>Asignación</td>
- <td>Derecha</td>
- </tr>
- <tr>
- <td><samp><<=</samp> <samp>>>=</samp> <samp>>>>=</samp> <samp>&=</samp> <samp>^=</samp> <samp>|=</samp></td>
- <td>Asignación</td>
- <td>Derecha</td>
- </tr>
- <tr>
- <td><samp>,</samp></td>
- <td>Separador</td>
- <td>Izquierda</td>
- </tr>
- <tr>
- <td><samp>+</samp> <samp>-</samp> <samp>*</samp> <samp>/</samp> <samp>%</samp></td>
- <td>Aritmético</td>
- <td>Izquierda</td>
- </tr>
- <tr>
- <td><samp><<</samp> <samp>>></samp> <samp>>>></samp></td>
- <td>Operador a nivel de bit</td>
- <td>Izquierda</td>
- </tr>
- <tr>
- <td><samp><</samp> <samp><=</samp> <samp>></samp> <samp>>=</samp> <samp>==</samp> <samp>!=</samp> <samp>===</samp> <samp>!=</samp></td>
- <td>Aritmético</td>
- <td>Izquierda</td>
- </tr>
- </table></div>
- <h2 id="expresiones_control_flujo_javascript_operadores_relacionales">Operadores relacionales<a href="#expresiones_control_flujo_javascript_operadores_relacionales"></a></h2>
- <p>Los <i>operadores relacionales</i> comprueban dos operandos y devuelven un resultado booleano de <samp>true</samp> o <samp>false</samp>. Existen tres tipos de operadores relacionales: de <i>igualdad</i>, <i>comparación</i> y <i>lógico</i>.</p>
- <h3 id="expresiones_control_flujo_javascript_operadores_igualdad">Operadores de igualdad<a href="#expresiones_control_flujo_javascript_operadores_igualdad"></a></h3>
- <p>El operador de igualdad es <samp>==</samp> (que no debe confundirse con el operador de asignación <samp>=</samp>). En el Ejemplo 15-4, la primera instrucción asigna un valor, y la segunda comprueba si son iguales. Tal como está, no se imprimirá nada, porque a <samp>month</samp> se le asigna el valor del string <samp>July</samp>, y por lo tanto la comprobación de que tenga el valor de <samp>October</samp> fallará.</p>
- <p><i>Ejemplo 15-4. Asignación de un valor y prueba de igualdad</i></p>
- <div class="pre"><pre class="lineno">1<br>2<br>3<br>4<br></pre><code><span class="hl_o"><</span><span class="hl_v">script</span><span class="hl_o">></span>
- <span class="hl_v">month</span> <span class="hl_o">=</span> <span class="hl_s">"July"</span>
- <span class="hl_k">if</span> (<span class="hl_v">month</span> <span class="hl_o">==</span> <span class="hl_s">"October"</span>) <span class="hl_f">document.write</span>(<span class="hl_s">"It's the Fall"</span>)
- <span class="hl_o"></</span><span class="hl_v">script</span><span class="hl_o">></span></code></div>
- <p>Si los dos operandos de una expresión de igualdad son de diferentes tipos, JavaScript los convertirá al tipo dato más adecuado. Por ejemplo, cualquier string compuesto completamente por números será convertido a números cada vez que se compare con un número. En el Ejemplo 15-5, <samp>a</samp> y <samp>b</samp> son dos valores diferentes (uno es un número y el otro es un string), y por lo tanto, normalmente esperaríamos que ninguna de las sentencias <samp>if</samp> produzca un resultado.</p>
- <p><i>Ejemplo 15-5. Los operadores de igualdad e identidad</i></p>
- <div class="pre"><pre class="lineno">1<br>2<br>3<br>4<br>5<br>6<br></pre><code><span class="hl_o"><</span><span class="hl_v">script</span><span class="hl_o">></span>
- <span class="hl_v">a</span> <span class="hl_o">=</span> <span class="hl_n">3</span><span class="hl_v">.1415927</span>
- <span class="hl_v">b</span> <span class="hl_o">=</span> <span class="hl_s">"3.1415927"</span>
- <span class="hl_k">if</span> (<span class="hl_v">a</span> <span class="hl_o">==</span> <span class="hl_v">b</span>) <span class="hl_f">document.write</span>(<span class="hl_s">"1"</span>)
- <span class="hl_k">if</span> (<span class="hl_v">a</span> <span class="hl_o">===</span> <span class="hl_v">b</span>) <span class="hl_f">document.write</span>(<span class="hl_s">"2"</span>)
- <span class="hl_o"></</span><span class="hl_v">script</span><span class="hl_o">></span></code></div>
- <p>Sin embargo, si ejecutas el ejemplo, verás que imprime el número <samp>1</samp>, lo que significa que la primera sentencia <samp>if</samp> se evaluó como <samp>true</samp>. Esto se debe a que el valor del string de <samp>b</samp> se convirtió temporalmente a un número, y por lo tanto ambas mitades de la ecuación tenían un valor numérico de <samp>3.1415927</samp>.</p>
- <p>En contraste, la segunda sentencia <samp>if</samp> utiliza el <i>operador de identidad</i>, tres signos de igual uno a lado del otro, lo que evita que JavaScript convierta automáticamente los tipos. Por lo tanto, <samp>a</samp> y <samp>b</samp> son diferentes, por lo que no se muestra ningún resultado.</p>
- <p>Al igual que al forzar la precedencia de los operadores, siempre que tengas dudas sobre cómo JavaScript convertirá los tipos de datos de los operandos, puedes utilizar el operador de identidad para desactivar este comportamiento.</p>
- <h3 id="expresiones_control_flujo_javascript_operadores_comparacion">Operadores de comparación<a href="#expresiones_control_flujo_javascript_operadores_comparacion"></a></h3>
- <p>Utilizando operadores de comparación, puedes probar más que solo igualdad y desigualdad. JavaScript también te ofrece <samp>></samp> (es mayor que), <samp><</samp> (es menor que), <samp>>=</samp> (es mayor o igual que) y <samp><=</samp> (es menor o igual que) con los que puedes jugar. El Ejemplo 15-6 muestra como puedes utilizar estos operadores.</p>
- <p><i>Ejemplo 15-6. Los cuatro operadores de comparación</i></p>
- <div class="pre"><pre class="lineno">1<br>2<br>3<br>4<br>5<br>6<br>7<br></pre><code><span class="hl_o"><</span><span class="hl_v">script</span><span class="hl_o">></span>
- <span class="hl_v">a</span> <span class="hl_o">=</span> <span class="hl_n">7</span>; <span class="hl_v">b</span> <span class="hl_o">=</span> <span class="hl_n">11</span>
- <span class="hl_k">if</span> (<span class="hl_v">a</span> <span class="hl_o">></span> <span class="hl_v">b</span>) <span class="hl_f">document.write</span>(<span class="hl_s">"a is greater than b<br>"</span>)
- <span class="hl_k">if</span> (<span class="hl_v">a</span> <span class="hl_o"><</span> <span class="hl_v">b</span>) <span class="hl_f">document.write</span>(<span class="hl_s">"a is less than b<br>"</span>)
- <span class="hl_k">if</span> (<span class="hl_v">a</span> <span class="hl_o">>=</span> <span class="hl_v">b</span>) <span class="hl_f">document.write</span>(<span class="hl_s">"a is greater than or equal to b<br>"</span>)
- <span class="hl_k">if</span> (<span class="hl_v">a</span> <span class="hl_o"><=</span> <span class="hl_v">b</span>) <span class="hl_f">document.write</span>(<span class="hl_s">"a is less than or equal to b<br>"</span>)
- <span class="hl_o"></</span><span class="hl_v">script</span><span class="hl_o">></span></code></div>
- <p>En este ejemplo, donde <samp>a</samp> es <samp>7</samp> y <samp>b</samp> es <samp>11</samp>, se produce la siguiente salida (porque <samp>7</samp> es menor que <samp>11</samp> y también menor o igual a <samp>11</samp>):</p>
- <div class="pre"><pre>
- a is less than b
- a is less than or equal to b
- </pre></div>
- <h3 id="expresiones_control_flujo_javascript_operadores_logicos">Operadores lógicos<a href="#expresiones_control_flujo_javascript_operadores_logicos"></a></h3>
- <p>Los operadores lógicos producen resultados verdaderos o falsos y también se conocen como <i>operadores booleanos</i>. Hay tres de ellos en JavaScript (ver la Tabla 15-4).</p>
- <p><i>Tabla 15-4. Operadores lógicos de JavaScript</i></p>
- <div class="table"><table>
- <tr>
- <th>Operador lógico</th>
- <th>Descripción</th>
- </tr>
- <tr>
- <td><samp>&&</samp> <i>(and)</i></td>
- <td><samp>true</samp> si ambos operandos son <samp>true</samp></td>
- </tr>
- <tr>
- <td><samp>||</samp> <i>(or)</i></td>
- <td><samp>true</samp> si cualquiera de los dos operandos es <samp>true</samp></td>
- </tr>
- <tr>
- <td><samp>!</samp> <i>(not)</i></td>
- <td><samp>true</samp> si el operando es <samp>false</samp>, o <samp>false</samp> si el operando es <samp>true</samp></td>
- </tr>
- </table></div>
- <p>Puedes ver cómo se pueden utilizar en el Ejemplo 15-7, que produce <samp>0</samp>, <samp>1</samp> y <samp>true</samp>.</p>
- <p><i>Ejemplo 15-7. Los operadores lógicos en uso</i></p>
- <div class="pre"><pre class="lineno">1<br>2<br>3<br>4<br>5<br>6<br></pre><code><span class="hl_o"><</span><span class="hl_v">script</span><span class="hl_o">></span>
- <span class="hl_v">a</span> <span class="hl_o">=</span> <span class="hl_n">1</span>; <span class="hl_v">b</span> <span class="hl_o">=</span> <span class="hl_n">0</span>
- <span class="hl_f">document.write</span>(<span class="hl_v">(a</span> <span class="hl_o">&&</span> <span class="hl_v">b</span>) <span class="hl_o">+</span> <span class="hl_s">"<br>"</span>)
- <span class="hl_f">document.write</span>(<span class="hl_v">(a</span> <span class="hl_o">||</span> <span class="hl_v">b</span>) <span class="hl_o">+</span> <span class="hl_s">"<br>"</span>)
- <span class="hl_f">document.write</span>(<span class="hl_v">(</span> <span class="hl_o">!</span><span class="hl_v">b</span> ) <span class="hl_o">+</span> <span class="hl_s">"<br>"</span>)
- <span class="hl_o"></</span><span class="hl_v">script</span><span class="hl_o">></span></code></div>
- <p>La sentencia <samp>&&</samp> requiere que ambos operandos sean <samp>true</samp> para devolver un valor <samp>true</samp>, la sentencia <samp>||</samp> será <samp>true</samp> si cualquiera de los valores es <samp>true</samp>, y la tercera sentencia realiza un <samp>NOT</samp> en el valor de <samp>b</samp>, convirtiéndolo de <samp>0</samp> a un valor <samp>true</samp>.</p>
- <p>El operador <samp>||</samp> puede causar problemas involuntarios, porque el segundo operando no se evaluará si el primero se evalúa como <samp>true</samp>. En el Ejemplo 15-8, la función <samp>getnext</samp> nunca se llamará si <samp>finished</samp> tiene un valor de <samp>1</samp> (estos son puramente ejemplos, y la acción de <samp>getnext</samp> es irrelevante para esta explicación, solo piénselo como una función que hace <i>algo</i> cuando se llama).</p>
- <p><i>Ejemplo 15-8. Una sentencia utilizando el operador <samp>||</samp></i></p>
- <div class="pre"><pre class="lineno">1<br>2<br>3<br></pre><code><span class="hl_o"><</span><span class="hl_v">script</span><span class="hl_o">></span>
- <span class="hl_k">if</span> (<span class="hl_v">finished</span> <span class="hl_o">==</span> <span class="hl_n">1</span> <span class="hl_o">||</span> <span class="hl_f">getnext</span>() <span class="hl_o">==</span> <span class="hl_n">1</span>) <span class="hl_v">done</span> <span class="hl_o">=</span> <span class="hl_n">1</span>
- <span class="hl_o"></</span><span class="hl_v">script</span><span class="hl_o">></span></code></div>
- <p>Si <i>necesitas</i> que <samp>getnext</samp> se llame en cada sentencia <samp>if</samp>, debes reescribir el código como se muestra en el Ejemplo 15-9.</p>
- <p><i>Ejemplo 15-9. La sentencia <samp>if</samp>...<samp>or</samp> modificada para asegurar la llamada a <samp>getnext</samp></i></p>
- <div class="pre"><pre class="lineno">1<br>2<br>3<br>4<br></pre><code><span class="hl_o"><</span><span class="hl_v">script</span><span class="hl_o">></span>
- <span class="hl_v">gn</span> <span class="hl_o">=</span> <span class="hl_f">getnext</span>()
- <span class="hl_k">if</span> (<span class="hl_v">finished</span> <span class="hl_o">==</span> <span class="hl_n">1</span> <span class="hl_o">||</span> <span class="hl_v">gn</span> <span class="hl_o">==</span> <span class="hl_n">1</span>) <span class="hl_v">done</span> <span class="hl_o">=</span> <span class="hl_n">1</span>;
- <span class="hl_o"></</span><span class="hl_v">script</span><span class="hl_o">></span></code></div>
- <p>En este caso, el código en la función <samp>getnext</samp> se ejecutará y su valor de retorno se almacenará en <samp>gn</samp> antes de la sentencia <samp>if</samp>.</p>
- <p>La Tabla 15-5 muestra todas las posibles variaciones del uso de los operadores lógicos. También debes tener en cuenta que <samp>!true</samp> es igual a <samp>false</samp> y <samp>!false</samp> es igual a <samp>true</samp>.</p>
- <p><i>Tabla 15-5. Todas las posibles expresiones lógicas</i></p>
- <div class="table"><table>
- <tr>
- <th colspan="2">Entrada
- <th colspan="2">Operadores y resultados
- </tr>
- <tr>
- <th>a</th>
- <th>b</th>
- <th>&&</th>
- <th>||</th>
- </tr>
- <tr>
- <td><samp>true</samp></td>
- <td><samp>true</samp></td>
- <td><samp>true</samp></td>
- <td><samp>true</samp></td>
- </tr>
- <tr>
- <td><samp>true</samp></td>
- <td><samp>false</samp></td>
- <td><samp>false</samp></td>
- <td><samp>true</samp></td>
- </tr>
- <tr>
- <td><samp>false</samp></td>
- <td><samp>true</samp></td>
- <td><samp>false</samp></td>
- <td><samp>true</samp></td>
- </tr>
- <tr>
- <td><samp>false</samp></td>
- <td><samp>false</samp></td>
- <td><samp>false</samp></td>
- <td><samp>false</samp></td>
- </tr>
- </table></div>
- <h2 id="expresiones_control_flujo_javascript_declaracion_with">Declaración with<a href="#expresiones_control_flujo_javascript_declaracion_with"></a></h2>
- <p>La declaración <samp>with</samp> no la has visto en los capítulos anteriores sobre PHP, porque es exclusiva de JavaScript, y también es una que, aunque necesitas conocerla, no deberías utilizarla. Con él (si me entiendes), puedes simplificar algunos tipos de declaraciones de JavaScript reduciendo muchas referencias a un objeto a una solo referencia. Se asume que las referencias a las propiedades y métodos dentro del bloque <samp>with</samp> se aplican a ese objeto.</p>
- <p>Por ejemplo, considerando el código del Ejemplo 15-10, en el cual la función <samp>document.write</samp> nunca hace referencia a la variable <samp>string</samp> por su nombre.</p>
- <p><i>Ejemplo 15-10. Utilizando la declaración <samp>with</samp></i></p>
- <div class="pre"><pre class="lineno">1<br>2<br>3<br>4<br>5<br>6<br>7<br>8<br>9<br></pre><code><span class="hl_o"><</span><span class="hl_v">script</span><span class="hl_o">></span>
- <span class="hl_v">string</span> <span class="hl_o">=</span> <span class="hl_s">"The quick brown fox jumps over the lazy dog"</span>
- <span class="hl_t">with</span> (<span class="hl_v">string</span>)
- {
- <span class="hl_f">document.write</span>(<span class="hl_s">"The string is "</span> <span class="hl_o">+</span> <span class="hl_v">length</span> <span class="hl_o">+</span> <span class="hl_s">" characters<br>"</span>)
- <span class="hl_f">document.write</span>(<span class="hl_s">"In upper case it's: "</span> <span class="hl_o">+</span> <span class="hl_f">toUpperCase</span>())
- }
- <span class="hl_o"></</span><span class="hl_v">script</span><span class="hl_o">></span></code></div>
- <p>Aunque <samp>string</samp> nunca es referenciada directamente mediante <samp>document.write</samp>, este código consigue mostrar lo siguiente:</p>
- <div class="pre"><pre>
- The string is 43 characters
- In upper case it's: THE QUICK BROWN FOX JUMPS OVER THE LAZY DOG
- </pre></div>
- <p>Así es como funciona el código: el intérprete de JavaScript reconoce que la propiedad <samp>length</samp> y el método <samp>toUpperCase</samp> deben aplicarse en algún objeto. Como son independientes, el intérprete asume que se aplican al objeto <samp>string</samp> especificado en la declaración <samp>with</samp>.</p>
- <div class="info"><p><span>Nota</span></p><p>Utilizar <samp>with</samp> ya no se recomienda y ahora está prohibido en el modo estricto de ECMAScript 5. La alternativa recomendada es asignar a una variable temporal el objeto cuyas propiedades deseas acceder. Asegúrate de tener esto en cuenta para poder actualizarlo (si es necesario) cuando lo veas en el código de otras personas, pero no lo uses tú mismo.</p></div>
- <h2 id="expresiones_control_flujo_javascript_utilizando_onerror">Utilizando onerror<a href="#expresiones_control_flujo_javascript_utilizando_onerror"></a></h2>
- <p>Utilizando el evento <samp>onerror</samp> o una combinación de las palabras reservadas <samp>try</samp> y <samp>catch</samp>, puedes capturar errores de JavaScript y manejarlos tú mismo.</p>
- <p>Los <i>eventos</i> son acciones que puede detectar JavaScript. Cada elemento de una página web tiene ciertos eventos que pueden activar funciones de JavaScript. Por ejemplo, el evento <samp>onclick</samp> de un elemento button se puede configurar para llamar a una función y hacer que se ejecute cada vez que un usuario haga clic en el botón.</p>
- <p><i>Ejemplo 15-11. Un script que emplea el evento <samp>onerror</samp></i></p>
- <div class="pre"><pre class="lineno">1<br>2<br>3<br>4<br>5<br>6<br>7<br>8<br>9<br>10<br>11<br>12<br>13<br>14<br>15<br></pre><code><span class="hl_o"><</span><span class="hl_v">script</span><span class="hl_o">></span>
- <span class="hl_v">onerror</span> <span class="hl_o">=</span> <span class="hl_v">errorHandler</span>
- <span class="hl_f">document.writ</span>(<span class="hl_s">"Welcome to this website"</span>) <span class="hl_c">// Deliberate error</span>
- <span class="hl_k">function</span> <span class="hl_f">errorHandler</span>(<span class="hl_v">message</span>, <span class="hl_v">url</span>, <span class="hl_v">line</span>)
- {
- <span class="hl_v">out</span> <span class="hl_o">=</span> <span class="hl_s">"Sorry, an error was encountered.\n\n"</span>;
- <span class="hl_v">out</span> <span class="hl_o">+=</span> <span class="hl_s">"Error: "</span> <span class="hl_o">+</span> <span class="hl_v">message</span> <span class="hl_o">+</span> <span class="hl_s">"\n"</span>;
- <span class="hl_v">out</span> <span class="hl_o">+=</span> <span class="hl_s">"URL: "</span> <span class="hl_o">+</span> <span class="hl_v">url</span> <span class="hl_o">+</span> <span class="hl_s">"\n"</span>;
- <span class="hl_v">out</span> <span class="hl_o">+=</span> <span class="hl_s">"Line: "</span> <span class="hl_o">+</span> <span class="hl_v">line</span> <span class="hl_o">+</span> <span class="hl_s">"\n\n"</span>;
- <span class="hl_v">out</span> <span class="hl_o">+=</span> <span class="hl_s">"Click OK to continue.\n\n"</span>;
- <span class="hl_f">alert</span>(<span class="hl_v">out</span>);
- <span class="hl_k">return</span> <span class="hl_t">true</span>;
- }
- <span class="hl_o"></</span><span class="hl_v">script</span><span class="hl_o">></span></code></div>
- <p>La primera línea de este script indica al evento de error que use la nueva función <samp>errorHandler</samp> a partir de ahora. Esta función toma tres parámetros: un mensaje (<samp>message</samp>), una URL (<samp>url</samp>) y un número de línea (<samp>line</samp>), por lo que es sencillo mostrar todo esto en una ventana emergente de alerta.</p>
- <p>Luego, para probar la nueva función, colocamos intencionalmente un error de sintaxis en el código con una llamada a <samp>document.writ</samp> en lugar de <samp>document.write</samp> (falta la <samp>e</samp> al final). La Figura 15-1 muestra el resultado de ejecutar este script en un navegador. Usar <samp>onerror</samp> de esta manera también puede ser bastante útil durante el proceso de depuración.</p>
- <div class="imgc"><img class="imgc" width="602" height="350" alt="figura_15-1.png" src=""></div>
- <div class="fig">Figura 15-1. Uso del evento onerror con un pop-up del método alert</div>
- <h2 id="expresiones_control_flujo_javascript_utilizando_try_catch">Utilizando try...catch<a href="#expresiones_control_flujo_javascript_utilizando_try_catch"></a></h2>
- <p>Las palabras clave <samp>try</samp> y <samp>catch</samp> son más estándar y más flexibles que la técnica <samp>onerror</samp> mostrada en la sección anterior. Estas palabras clave te permiten detectar errores en una sección de código determinado, en lugar de hacerlo para todos los scripts de un documento. Sin embargo, no detectan errores de sintaxis, para los cuales necesitas <samp>onerror</samp>.</p>
- <p>El constructor <samp>try...catch</samp> es compatible con todos los navegadores principales y es útil cuando quieres detectar una cierta condición que sabes que podría ocurrir en una parte específica de tu código.</p>
- <p>Por ejemplo, en el <a href="#funciones_objetos_arrays_javascript" onclick="c('funciones_objetos_arrays_javascript')">Capítulo 18</a> exploraremos las técnicas de Ajax que utilizan el objeto <samp>XMLHttpRequest</samp>. Por lo tanto, podemos utilizar <samp>try</samp> y <samp>catch</samp> para detectar este caso y hacer algo más si la función no está disponible. El ejemplo 15-12 muestra cómo hacerlo.</p>
- <p><i>Ejemplo 15-12. Detección de un error con <samp>try</samp> y <samp>catch</samp></i></p>
- <div class="pre"><pre class="lineno">1<br>2<br>3<br>4<br>5<br>6<br>7<br>8<br>9<br>10<br></pre><code><span class="hl_o"><</span><span class="hl_v">script</span><span class="hl_o">></span>
- <span class="hl_k">try</span>
- {
- <span class="hl_v">request</span> <span class="hl_o">=</span> <span class="hl_t">new</span> <span class="hl_f">XMLHttpRequest</span>()
- }
- <span class="hl_k">catch</span> (<span class="hl_v">err</span>)
- {
- <span class="hl_c">// Use a different method to create an XMLHttpRequest object</span>
- }
- <span class="hl_o"></</span><span class="hl_v">script</span><span class="hl_o">></span></code></div>
- <p>También hay otra palabra reservada asociada con <samp>try</samp> y <samp>catch</samp> llamada <samp>finally</samp> que siempre se ejecuta, independientemente de si ocurre un error en la cláusula <samp>try</samp>. Para usarlo, simplemente añade algo como las siguientes declaraciones después de una declaración <samp>catch</samp>:</p>
- <div class="pre"><pre class="lineno">1<br>2<br>3<br>4<br></pre><code><span class="hl_v">finally</span>
- {
- <span class="hl_f">alert</span>(<span class="hl_s">"The 'try' clause was encountered"</span>)
- }</code></div>
- <h2 id="expresiones_control_flujo_javascript_condicionales">Condicionales<a href="#expresiones_control_flujo_javascript_condicionales"></a></h2>
- <p>Las condicionales alteran el flujo del programa. Te permiten hacer preguntas sobre determinadas cosas y responder a las respuestas que obtienes de diferentes maneras. Hay tres tipos de condicionales no iterativos: la declaración <samp>if</samp>, la declaración <samp>switch</samp> y el operador <samp>?</samp>.</p>
- <h3 id="expresiones_control_flujo_javascript_declaracion_if">Declaración if<a href="#expresiones_control_flujo_javascript_declaracion_if"></a></h3>
- <p>Varios ejemplos en este capítulo ya han utilizado declaraciones <samp>if</samp>. El código dentro de tal declaración se ejecuta solo si la expresión dada se evalúa como <samp>true</samp>. Las sentencias <samp>if</samp> multilínea requieren llaves alrededor de ellas, pero al igual que en PHP, puedes omitir las llaves para una sola sentencia, aunque a menudo es una buena idea usarlas de todos modos, especialmente cuando escribes código en el que el número de acciones dentro de una declaración <samp>if</samp> podría cambiar a medida que avanza el desarrollo. Por lo tanto, las siguientes sentencias son válidas:</p>
- <div class="pre"><pre class="lineno">1<br>2<br>3<br>4<br>5<br>6<br>7<br></pre><code><span class="hl_k">if</span> (<span class="hl_v">a</span> <span class="hl_o">></span> <span class="hl_n">100</span>)
- {
- <span class="hl_v">b</span> <span class="hl_o">=</span> <span class="hl_n">2</span>
- <span class="hl_f">document.write</span>(<span class="hl_s">"a is greater than 100"</span>)
- }
- <span class="hl_k">if</span> (<span class="hl_v">b</span> <span class="hl_o">==</span> <span class="hl_n">10</span>) <span class="hl_f">document.write</span>(<span class="hl_s">"b is equal to 10"</span>)</code></div>
- <h3 id="expresiones_control_flujo_javascript_declaracion_else">Declaración else<a href="#expresiones_control_flujo_javascript_declaracion_else"></a></h3>
- <p>Cuando no se ha cumplido una condición, puedes ejecutar una alternativa utilizando una declaración <samp>else</samp>, así:</p>
- <div class="pre"><pre class="lineno">1<br>2<br>3<br>4<br>5<br>6<br>7<br>8<br></pre><code><span class="hl_k">if</span> (<span class="hl_v">a</span> <span class="hl_o">></span> <span class="hl_n">100</span>)
- {
- <span class="hl_f">document.write</span>(<span class="hl_s">"a is greater than 100"</span>)
- }
- <span class="hl_k">else</span>
- {
- <span class="hl_f">document.write</span>(<span class="hl_s">"a is less than or equal to 100"</span>)
- }</code></div>
- <p>A diferencia de PHP, JavaScript no tiene una declaración <samp>elseif</samp>, pero eso no es un problema porque puedes utilizar un <samp>else</samp> seguido de otro <samp>if</samp> para formar el equivalente de una declaración <samp>elseif</samp>, así:</p>
- <div class="pre"><pre class="lineno">1<br>2<br>3<br>4<br>5<br>6<br>7<br>8<br>9<br>10<br>11<br>12<br></pre><code><span class="hl_k">if</span> (<span class="hl_v">a</span> <span class="hl_o">></span> <span class="hl_n">100</span>)
- {
- <span class="hl_f">document.write</span>(<span class="hl_s">"a is greater than 100"</span>)
- }
- <span class="hl_k">else</span> <span class="hl_k">if</span> (<span class="hl_v">a</span> <span class="hl_o"><</span> <span class="hl_n">100</span>)
- {
- <span class="hl_f">document.write</span>(<span class="hl_s">"a is less than 100"</span>)
- }
- <span class="hl_k">else</span>
- {
- <span class="hl_f">document.write</span>(<span class="hl_s">"a is equal to 100"</span>)
- }</code></div>
- <p>Como puedes ver, es posible utilizar otro <samp>else</samp> después del nuevo <samp>if</samp>, al que podría seguir igualmente otra declaración <samp>if</samp>, y así sucesivamente. Aunque he mostrado llaves en las declaraciones, dado que cada una es una sola línea, el ejemplo anterior podría escribirse de la siguiente manera:</p>
- <div class="pre"><pre class="lineno">1<br>2<br>3<br></pre><code><span class="hl_k">if</span> (<span class="hl_v">a</span> <span class="hl_o">></span> <span class="hl_n">100</span>) <span class="hl_f">document.write</span>(<span class="hl_s">"a is greater than 100"</span>)
- <span class="hl_k">else</span> <span class="hl_k">if</span> (<span class="hl_v">a</span> <span class="hl_o"><</span> <span class="hl_n">100</span>) <span class="hl_f">document.write</span>(<span class="hl_s">"a is less than 100"</span>)
- <span class="hl_k">else</span> <span class="hl_f">document.write</span>(<span class="hl_s">"a is equal to 100"</span>)</code></div>
- <h3 id="expresiones_control_flujo_javascript_declaracion_switch">Declaración switch<a href="#expresiones_control_flujo_javascript_declaracion_switch"></a></h3>
- <p>La declaración <samp>switch</samp> es útil cuando una variable o el resultado de una expresión puede tener múltiples valores y quieres realizar una función diferente para cada valor.</p>
- <p>Por ejemplo, el siguiente código emplea el sistema de menú en PHP que construimos en el <a href="#expresiones_control_flujo_php" onclick="c('expresiones_control_flujo_php')">Capítulo 4</a> y lo convierte a JavaScript. Funciona pasando un único string al código del menú principal de acuerdo con lo que el usuario solicite. Digamos que las opciones son Inicio (<samp>Home</samp>), Acerca de (<samp>About</samp>), Noticias (<samp>News</samp>), Iniciar sesión (<samp>Login</samp>) y Enlaces (<samp>Links</samp>), y establecemos la variable <samp>page</samp> (página) en una de ellas en función de la entrada del usuario.</p>
- <p>El código escrito para esto utilizando <samp>if...else if...</samp> podría verse como en el Ejemplo 15-13.</p>
- <p><i>Ejemplo 15-13. Una declaración <samp>if...else if...</samp> de varias líneas</i></p>
- <div class="pre"><pre class="lineno">1<br>2<br>3<br>4<br>5<br>6<br>7<br></pre><code><span class="hl_o"><</span><span class="hl_v">script</span><span class="hl_o">></span>
- <span class="hl_k">if</span> (<span class="hl_v">page</span> <span class="hl_o">==</span> <span class="hl_s">"Home"</span>) <span class="hl_f">document.write</span>(<span class="hl_s">"You selected Home"</span>)
- <span class="hl_k">else</span> <span class="hl_k">if</span> (<span class="hl_v">page</span> <span class="hl_o">==</span> <span class="hl_s">"About"</span>) <span class="hl_f">document.write</span>(<span class="hl_s">"You selected About"</span>)
- <span class="hl_k">else</span> <span class="hl_k">if</span> (<span class="hl_v">page</span> <span class="hl_o">==</span> <span class="hl_s">"News"</span>) <span class="hl_f">document.write</span>(<span class="hl_s">"You selected News"</span>)
- <span class="hl_k">else</span> <span class="hl_k">if</span> (<span class="hl_v">page</span> <span class="hl_o">==</span> <span class="hl_s">"Login"</span>) <span class="hl_f">document.write</span>(<span class="hl_s">"You selected Login"</span>)
- <span class="hl_k">else</span> <span class="hl_k">if</span> (<span class="hl_v">page</span> <span class="hl_o">==</span> <span class="hl_s">"Links"</span>) <span class="hl_f">document.write</span>(<span class="hl_s">"You selected Links"</span>)
- <span class="hl_o"></</span><span class="hl_v">script</span><span class="hl_o">></span></code></div>
- <p>Pero usando una estructura <samp>switch</samp>, el código podría verse como en el Ejemplo 15-14.</p>
- <p><i>Ejemplo 15-14. Una estructura <samp>switch</samp></i></p>
- <div class="pre"><pre class="lineno">1<br>2<br>3<br>4<br>5<br>6<br>7<br>8<br>9<br>10<br>11<br>12<br>13<br>14<br>15<br>16<br>17<br>18<br>19<br>20<br></pre><code><span class="hl_o"><</span><span class="hl_v">script</span><span class="hl_o">></span>
- <span class="hl_k">switch</span> (<span class="hl_v">page</span>)
- {
- <span class="hl_k">case</span> <span class="hl_s">"Home"</span><span class="hl_o">:</span>
- <span class="hl_f">document.write</span>(<span class="hl_s">"You selected Home"</span>)
- <span class="hl_k">break</span>
- <span class="hl_k">case</span> <span class="hl_s">"About"</span><span class="hl_o">:</span>
- <span class="hl_f">document.write</span>(<span class="hl_s">"You selected About"</span>)
- <span class="hl_k">break</span>
- <span class="hl_k">case</span> <span class="hl_s">"News"</span><span class="hl_o">:</span>
- <span class="hl_f">document.write</span>(<span class="hl_s">"You selected News"</span>)
- <span class="hl_k">break</span>
- <span class="hl_k">case</span> <span class="hl_s">"Login"</span><span class="hl_o">:</span>
- <span class="hl_f">document.write</span>(<span class="hl_s">"You selected Login"</span>)
- <span class="hl_k">break</span>
- <span class="hl_k">case</span> <span class="hl_s">"Links"</span><span class="hl_o">:</span>
- <span class="hl_f">document.write</span>(<span class="hl_s">"You selected Links"</span>)
- <span class="hl_k">break</span>
- }
- <span class="hl_o"></</span><span class="hl_v">script</span><span class="hl_o">></span></code></div>
- <p>La variable <samp>page</samp> se menciona solo una vez al inicio de la declaración <samp>switch</samp>. Después, el comando <samp>case</samp> comprueba las coincidencias. Cuando ocurre una coincidencia, se ejecuta la declaración condicional correspondiente. Por supuesto, un programa real tendría código aquí para mostrar o saltar a una página, en lugar de simplemente decirle al usuario lo que ha seleccionado.</p>
- <div class="info"><p><span>Nota</span></p><p>
- <p>También puedes proporcionar múltiples casos para una sola acción. Por ejemplo:</p>
- <div class="pre"><pre class="lineno">1<br>2<br>3<br>4<br>5<br>6<br>7<br>8<br>9<br>10<br>11<br>12<br>13<br></pre><code><span class="hl_k">switch</span> (<span class="hl_v">heroName</span>)
- {
- <span class="hl_k">case</span> <span class="hl_s">"Superman"</span><span class="hl_o">:</span>
- <span class="hl_k">case</span> <span class="hl_s">"Batman"</span><span class="hl_o">:</span>
- <span class="hl_k">case</span> <span class="hl_s">"Wonder Woman"</span><span class="hl_o">:</span>
- <span class="hl_f">document.write</span>(<span class="hl_s">"Justice League"</span>)
- <span class="hl_k">break</span>
- <span class="hl_k">case</span> <span class="hl_s">"Iron Man"</span><span class="hl_o">:</span>
- <span class="hl_k">case</span> <span class="hl_s">"Captain America"</span><span class="hl_o">:</span>
- <span class="hl_k">case</span> <span class="hl_s">"Spiderman"</span><span class="hl_o">:</span>
- <span class="hl_f">document.write</span>(<span class="hl_s">"The Avengers"</span>)
- <span class="hl_k">break</span>
- }</code></div>
- </p></div>
- <h4 id="expresiones_control_flujo_javascript_ruptura">Ruptura<a href="#expresiones_control_flujo_javascript_ruptura"></a></h4>
- <p>Como puedes ver en el Ejemplo 15-14, al igual que con PHP, el comando <samp>break</samp> permite que tu código salga de la declaración <samp>switch</samp> una vez que se ha cumplido una condición. Recuerda incluir el <samp>break</samp> a menos que quieras seguir ejecutando las sentencias del siguiente <samp>case</samp>.</p>
- <h4 id="expresiones_control_flujo_javascript_accion_por_defecto">Acción por defecto<a href="#expresiones_control_flujo_javascript_accion_por_defecto"></a></h4>
- <p>Cuando no se cumple ninguna condición, puedes especificar una acción por defecto para una declaración <samp>switch</samp> utilizando la palabra reserveda <samp>default</samp>. El Ejemplo 15-15 muestra un fragmento de código que podría insertarse en el Ejemplo 15-14.</p>
- <p><i>Ejemplo 15-15. Una declaración por defecto para agregar al Ejemplo 15-14</i></p>
- <div class="pre"><pre class="lineno">1<br>2<br>3<br></pre><code><span class="hl_v">default</span><span class="hl_o">:</span>
- <span class="hl_f">document.write</span>(<span class="hl_s">"Unrecognized selection"</span>)
- <span class="hl_k">break</span></code></div>
- <h3 id="expresiones_control_flujo_javascript_operador">El operador ?<a href="#expresiones_control_flujo_javascript_operador"></a></h3>
- <p>El operador ternario (<samp>?</samp>), combinado con el caracter <samp>:</samp>, proporciona una forma rápida de realizar pruebas <samp>if...else</samp>. Con él puedes escribir una expresión para evaluar y luego acompañarla con el símbolo <samp>?</samp> y el código a ejecutar si la expresión es <samp>true</samp>. Después de eso, colocas un <samp>:</samp> y el código a ejecutar si la expresión se evalúa como <samp>false</samp>.</p>
- <p>El ejemplo 15-16 muestra el uso del operador ternario para imprimir si la variable <samp>a</samp> es menor o igual a <samp>5</samp> e imprime algo de cualquier manera.</p>
- <p><i>Ejemplo 15-16. Utilizando el operador ternario</i></p>
- <div class="pre"><pre class="lineno">1<br>2<br>3<br>4<br>5<br>6<br>7<br></pre><code><span class="hl_o"><</span><span class="hl_v">script</span><span class="hl_o">></span>
- <span class="hl_f">document.write</span>(
- <span class="hl_v">a</span> <span class="hl_o"><=</span> <span class="hl_n">5</span> <span class="hl_v">?</span>
- <span class="hl_s">"a is less than or equal to 5"</span> <span class="hl_o">:</span>
- <span class="hl_s">"a is greater than 5"</span>
- )
- <span class="hl_o"></</span><span class="hl_v">script</span><span class="hl_o">></span></code></div>
- <p>La declaración ha sido dividida en varias líneas para mayor claridad, pero es más probable que utilizes una declaración en una sola línea, de esta manera:</p>
- <div class="pre"><pre class="lineno">1<br></pre><code><span class="hl_v">size</span> <span class="hl_o">=</span> <span class="hl_v">a</span> <span class="hl_o"><=</span> <span class="hl_n">5</span> <span class="hl_v">?</span> <span class="hl_s">"short"</span> <span class="hl_o">:</span> <span class="hl_s">"long"</span></code></div>
- <h2 id="expresiones_control_flujo_javascript_bucles">Bucles<a href="#expresiones_control_flujo_javascript_bucles"></a></h2>
- <p>Nuevamente, encontrarás muchas similitudes cercanas entre JavaScript y PHP en lo que respecta a los bucles. Ambos lenguajes admiten bucles <samp>while</samp>, <samp>do...while</samp> y <samp>for</samp>.</p>
- <h3 id="expresiones_control_flujo_javascript_bucles_while">Bucles while<a href="#expresiones_control_flujo_javascript_bucles_while"></a></h3>
- <p>Un bucle <samp>while</samp> en JavaScript comprueba primero el valor de una expresión y comienza a ejecutar las instrucciones dentro del bucle solo si esa expresión es <samp>true</samp>. Si es <samp>false</samp>, la ejecución salta a la siguiente instrucción de JavaScript (si la hay).</p>
- <p>Al completar una iteración del bucle, la expresión se vuelve a evaluar para ver si es <samp>true</samp>, y el proceso continúa hasta que la expresión se evalúe a <samp>false</samp> o hasta que la ejecución se detenga de otra manera. El ejemplo 15-17 muestra este bucle.</p>
- <p><i>Ejemplo 15-17. Un bucle <samp>while</samp></i></p>
- <div class="pre"><pre class="lineno">1<br>2<br>3<br>4<br>5<br>6<br>7<br>8<br>9<br></pre><code><span class="hl_o"><</span><span class="hl_v">script</span><span class="hl_o">></span>
- <span class="hl_v">counter</span> <span class="hl_o">=</span> <span class="hl_n">0</span>
- <span class="hl_k">while</span> (<span class="hl_v">counter</span> <span class="hl_o"><</span> <span class="hl_n">5</span>)
- {
- <span class="hl_f">document.write</span>(<span class="hl_s">"Counter: "</span> <span class="hl_o">+</span> <span class="hl_v">counter</span> <span class="hl_o">+</span> <span class="hl_s">"<br>"</span>)
- <span class="hl_o">++</span><span class="hl_v">counter</span>
- }
- <span class="hl_o"></</span><span class="hl_v">script</span><span class="hl_o">></span></code></div>
- <p>Este script produce lo siguiente:</p>
- <div class="pre"><pre>
- Counter: 0
- Counter: 1
- Counter: 2
- Counter: 3
- Counter: 4
- </pre></div>
- <div class="warn"><p><span>Precaución</span></p><p>Si la variable <samp>counter</samp> (contador) no se incrementara dentro del bucle, es bastante posible que algunos navegadores no ofrezcan ninguna respuesta debido a un bucle interminable, y la página no sea fácil de cerrar ni siquiera con Escape o con el botón de Detener. Así que, ten cuidado con tus bucles de JavaScript.</p></div>
- <h3 id="expresiones_control_flujo_javascript_bucles_do_while">Bucles do...while<a href="#expresiones_control_flujo_javascript_bucles_do_while"></a></h3>
- <p>Cuando necesites que un bucle itere al menos una vez antes de realizar cualquier prueba, utiliza un bucle <samp>do...while</samp>, que es similar a un bucle <samp>while</samp>, excepto que la expresión de prueba se verifica solo después de cada iteración del bucle. Entonces, para mostrar los primeros siete resultados de la tabla del <samp>7</samp>, podrías usar un código como el del Ejemplo 15-18.</p>
- <p><i>Ejemplo 15-18. Un bucle <samp>do...while</samp></i></p>
- <div class="pre"><pre class="lineno">1<br>2<br>3<br>4<br>5<br>6<br>7<br>8<br></pre><code><span class="hl_o"><</span><span class="hl_v">script</span><span class="hl_o">></span>
- <span class="hl_v">count</span> <span class="hl_o">=</span> <span class="hl_n">1</span>
- <span class="hl_k">do</span>
- {
- <span class="hl_f">document.write</span>(<span class="hl_v">count</span> <span class="hl_o">+</span> <span class="hl_s">" times 7 is "</span> <span class="hl_o">+</span> <span class="hl_v">count</span> <span class="hl_o">*</span> <span class="hl_n">7</span> <span class="hl_o">+</span> <span class="hl_s">"<br>"</span>)
- } <span class="hl_k">while</span> (<span class="hl_o">++</span><span class="hl_v">count</span> <span class="hl_o"><=</span> <span class="hl_n">7</span>)
- <span class="hl_o"></</span><span class="hl_v">script</span><span class="hl_o">></span></code></div>
- <p>Como era de esperar, este bucle produce lo siguiente:</p>
- <div class="pre"><pre>
- 1 times 7 is 7
- 2 times 7 is 14
- 3 times 7 is 21
- 4 times 7 is 28
- 5 times 7 is 35
- 6 times 7 is 42
- 7 times 7 is 49
- </pre></div>
- <h3 id="expresiones_control_flujo_javascript_bucles_for">Bucles for<a href="#expresiones_control_flujo_javascript_bucles_for"></a></h3>
- <p>Un bucle <samp>for</samp> combina lo mejor de todos los mundos en una única estructura de bucle que te permite pasar tres parámetros en cada declaración:</p>
- <ul>
- <li>Una expresión de inicialización</li>
- <li>Una expresión de condición</li>
- <li>Una expresión de modificación</li>
- </ul>
- <p>Estos están separados por punto y coma, así: <samp>for (expr1; expr2; expr3)</samp>. La expresión de inicialización se ejecuta al inicio de la primera iteración del bucle. En el caso del código para la tabla de multiplicar del <samp>7</samp>, <samp>count</samp> se inicializaría con el valor <samp>1</samp>. Luego, cada vez que se recorre el bucle, se evalúa la expresión de condición (en este caso, <samp>count <= 7</samp>), y el bucle solo se ejecuta si la condición es <samp>true</samp>. Por último, al final de cada iteración, se ejecuta la expresión de modificación. En el caso de la tabla de multiplicar del <samp>7</samp>, la variable <samp>count</samp> se incrementa. El ejemplo 15-19 muestra cómo sería el código.</p>
- <p><i>Ejemplo 15-19. Utilizando un bucle <samp>for</samp></i></p>
- <div class="pre"><pre class="lineno">1<br>2<br>3<br>4<br>5<br>6<br></pre><code><span class="hl_o"><</span><span class="hl_v">script</span><span class="hl_o">></span>
- <span class="hl_k">for</span> (<span class="hl_v">count</span> <span class="hl_o">=</span> <span class="hl_n">1</span>; <span class="hl_v">count</span> <span class="hl_o"><=</span> <span class="hl_n">7</span>; <span class="hl_o">++</span><span class="hl_v">count</span>)
- {
- <span class="hl_f">document.write</span>(<span class="hl_v">count</span> <span class="hl_o">+</span> <span class="hl_s">"times 7 is "</span> <span class="hl_o">+</span> <span class="hl_v">count</span> <span class="hl_o">*</span> <span class="hl_n">7</span> <span class="hl_o">+</span> <span class="hl_s">"<br>"</span>);
- }
- <span class="hl_o"></</span><span class="hl_v">script</span><span class="hl_o">></span></code></div>
- <p>Al igual que en PHP, puedes asignar múltiples variables en el primer parámetro de un bucle <samp>for</samp> separándolas con una coma, así:</p>
- <div class="pre"><pre class="lineno">1<br></pre><code><span class="hl_k">for</span> (<span class="hl_v">i</span> <span class="hl_o">=</span> <span class="hl_n">1</span>, <span class="hl_v">j</span> <span class="hl_o">=</span> <span class="hl_n">1</span>; <span class="hl_v">i</span> <span class="hl_o"><</span> <span class="hl_n">10</span>; <span class="hl_v">i</span><span class="hl_o">++</span>)</code></div>
- <p>Asimismo, puedes realizar múltiples modificaciones en el último parámetro, de esta forma:</p>
- <div class="pre"><pre class="lineno">1<br></pre><code><span class="hl_k">for</span> (<span class="hl_v">i</span> <span class="hl_o">=</span> <span class="hl_n">1</span>; <span class="hl_v">i</span> <span class="hl_o"><</span> <span class="hl_n">10</span>; <span class="hl_v">i</span><span class="hl_o">++</span>, <span class="hl_o">--</span><span class="hl_v">j</span>)</code></div>
- <p>O puedes hacer ambas cosas al mismo tiempo:</p>
- <div class="pre"><pre class="lineno">1<br></pre><code><span class="hl_k">for</span> (<span class="hl_v">i</span> <span class="hl_o">=</span> <span class="hl_n">1</span>, <span class="hl_v">j</span> <span class="hl_o">=</span> <span class="hl_n">1</span>; <span class="hl_v">i</span> <span class="hl_o"><</span> <span class="hl_n">10</span>; <span class="hl_v">i</span><span class="hl_o">++</span>, <span class="hl_o">--</span><span class="hl_v">j</span>)</code></div>
- <h3 id="expresiones_control_flujo_javascript_ruptura_bucle">Ruptura de un bucle<a href="#expresiones_control_flujo_javascript_ruptura_bucle"></a></h3>
- <p>El comando <samp>break</samp>, que recordarás es importante dentro de una declaración <samp>switch</samp>, también está disponible dentro de los bucles <samp>for</samp>. Es posible que tengas que utilizar esto, por ejemplo, cuando busques algún tipo de coincidencia. Una vez que se encuentra la coincidencia, sabes que continuar solo sería una pérdida tiempo y harás que tu visitante tenga que esperar. El ejemplo 15-20 muestra cómo utilizar el comando <samp>break</samp>.</p>
- <p><i>Ejemplo 15-20. Utilizando el comando <samp>break</samp> en un bucle <samp>for</samp></i></p>
- <div class="pre"><pre class="lineno">1<br>2<br>3<br>4<br>5<br>6<br>7<br>8<br>9<br>10<br>11<br>12<br>13<br>14<br></pre><code><span class="hl_o"><</span><span class="hl_v">script</span><span class="hl_o">></span>
- <span class="hl_v">haystack</span> <span class="hl_o">=</span> <span class="hl_t">new</span> <span class="hl_f">Array</span>()
- <span class="hl_v">haystack</span>[<span class="hl_n">17</span>] <span class="hl_o">=</span> <span class="hl_s">"Needle"</span>
- <span class="hl_k">for</span> (<span class="hl_v">j</span> <span class="hl_o">=</span> <span class="hl_n">0</span>; <span class="hl_v">j</span> <span class="hl_o"><</span> <span class="hl_n">20</span>; <span class="hl_o">++</span><span class="hl_v">j</span>)
- {
- <span class="hl_k">if</span> (<span class="hl_v">haystack</span>[<span class="hl_v">j</span>] <span class="hl_o">==</span> <span class="hl_s">"Needle"</span>)
- {
- <span class="hl_f">document.write</span>(<span class="hl_s">"<br>- Found at location "</span> <span class="hl_o">+</span> <span class="hl_v">j</span>)
- <span class="hl_k">break</span>
- }
- <span class="hl_k">else</span> <span class="hl_f">document.write</span>(<span class="hl_v">j</span> <span class="hl_o">+</span> <span class="hl_s">", "</span>)
- }
- <span class="hl_o"></</span><span class="hl_v">script</span><span class="hl_o">></span></code></div>
- <p>Este script produce lo siguiente:</p>
- <div class="pre"><pre>
- 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16,
- - Found at location 17
- </pre></div>
- <h3 id="expresiones_control_flujo_javascript_declaracion_continue">Declaración continue<a href="#expresiones_control_flujo_javascript_declaracion_continue"></a></h3>
- <p>A veces no quieres salir completamente de un bucle, sino que deseas omitir las sentencias restantes solo para una iteración concreta del bucle. En tales casos, puedes utilizar el comando <samp>continue</samp>. El ejemplo 15-21 muestra cómo se utiliza este comando.</p>
- <p><i>Ejemplo 15-21. Utilizando el comando <samp>continue</samp> en un bucle <samp>for</samp></i></p>
- <div class="pre"><pre class="lineno">1<br>2<br>3<br>4<br>5<br>6<br>7<br>8<br>9<br>10<br>11<br>12<br>13<br>14<br>15<br>16<br>17<br></pre><code><span class="hl_o"><</span><span class="hl_v">script</span><span class="hl_o">></span>
- <span class="hl_v">haystack</span> <span class="hl_o">=</span> <span class="hl_t">new</span> <span class="hl_f">Array</span>()
- <span class="hl_v">haystack</span>[<span class="hl_n">4</span>] <span class="hl_o">=</span> <span class="hl_s">"Needle"</span>
- <span class="hl_v">haystack</span>[<span class="hl_n">11</span>] <span class="hl_o">=</span> <span class="hl_s">"Needle"</span>
- <span class="hl_v">haystack</span>[<span class="hl_n">17</span>] <span class="hl_o">=</span> <span class="hl_s">"Needle"</span>
- <span class="hl_k">for</span> (<span class="hl_v">j</span> <span class="hl_o">=</span> <span class="hl_n">0</span>; <span class="hl_v">j</span> <span class="hl_o"><</span> <span class="hl_n">20</span>; <span class="hl_o">++</span><span class="hl_v">j</span>)
- {
- <span class="hl_k">if</span> (<span class="hl_v">haystack</span>[<span class="hl_v">j</span>] <span class="hl_o">==</span> <span class="hl_s">"Needle"</span>)
- {
- <span class="hl_f">document.write</span>(<span class="hl_s">"<br>- Found at location "</span> <span class="hl_o">+</span> <span class="hl_v">j</span> <span class="hl_o">+</span> <span class="hl_s">"<br>"</span>)
- <span class="hl_k">continue</span>
- }
- <span class="hl_f">document.write</span>(<span class="hl_v">j</span> <span class="hl_o">+</span> <span class="hl_s">", "</span>)
- }
- <span class="hl_o"></</span><span class="hl_v">script</span><span class="hl_o">></span></code></div>
- <p>Nota cómo la segunda llamada a <samp>document.write</samp> no tiene que estar encerrada en una declaración <samp>else</samp> (como antes), porque el comando <samp>continue</samp> la omitirá si se ha encontrado una coincidencia. La salida de este script es la siguiente:</p>
- <div class="pre"><pre>
- 0, 1, 2, 3,
- - Found at location 4
- 5, 6, 7, 8, 9, 10,
- - Found at location 11
- 12, 13, 14, 15, 16,
- - Found at location 17
- 18, 19,
- </pre></div>
- <h2 id="expresiones_control_flujo_javascript_conversion_explicita">Conversión explícita<a href="#expresiones_control_flujo_javascript_conversion_explicita"></a></h2>
- <p>A diferencia de PHP, JavaScript no tiene una conversión explícita (casting) de tipos de datos como (<samp>int</samp>) o (<samp>float</samp>). En su lugar, cuando necesites que un valor sea de un tipo de dato específico, utiliza una de las funciones integradas de JavaScript, que se muestran en la Tabla 15-6.</p>
- <p><i>Tabla 15-6. Funciones de cambio de tipo en JavaScript</i></p>
- <div class="table"><table>
- <tr>
- <th>Cambiar al tipo</th>
- <th>Función que se utiliza</th>
- </tr>
- <tr>
- <td><samp>Int</samp>, <samp>Integer</samp></td>
- <td><samp>parseInt()</samp></td>
- </tr>
- <tr>
- <td><samp>Bool</samp>, <samp>Boolean</samp></td>
- <td><samp>Boolean()</samp></td>
- </tr>
- <tr>
- <td><samp>Float</samp>, <samp>Double</samp>, <samp>Real</samp></td>
- <td><samp>parseFloat()</samp></td>
- </tr>
- <tr>
- <td><samp>String</samp></td>
- <td><samp>String()</samp></td>
- </tr>
- <tr>
- <td><samp>Array</samp></td>
- <td><samp>split()</samp></td>
- </tr>
- </table></div>
- <p>Entonces, por ejemplo, para cambiar un número de punto flotante a un entero, podrías utilizar un código como el siguiente (que muestra el valor <samp>3</samp>):</p>
- <div class="pre"><pre class="lineno">1<br>2<br>3<br></pre><code><span class="hl_v">n</span> <span class="hl_o">=</span> <span class="hl_n">3</span><span class="hl_v">.1415927</span>
- <span class="hl_v">i</span> <span class="hl_o">=</span> <span class="hl_f">parseInt</span>(<span class="hl_v">n</span>)
- <span class="hl_f">document.write</span>(<span class="hl_v">i</span>)</code></div>
- <p>O puedes utilizar la forma compuesta:</p>
- <div class="pre"><pre class="lineno">1<br></pre><code><span class="hl_f">document.write</span>(<span class="hl_f">parseInt</span>(<span class="hl_n">3</span><span class="hl_v">.1415927</span>))</code></div>
- <p>Eso es todo sobre el flujo de control y las expresiones. El siguiente capítulo se centrará en el uso de funciones, objetos y arreglos en JavaScript.</p>
- <h2 id="expresiones_control_flujo_javascript_preguntas">Preguntas<a href="#expresiones_control_flujo_javascript_preguntas"></a></h2>
- <ol>
- <li>¿Cómo se manejan los valores booleanos de manera diferente en PHP y JavaScript?</li>
- <li>¿Qué caracteres se utilizan para definir un nombre de variable en JavaScript?</li>
- <li>¿Cuál es la diferencia entre los operadores unarios, binarios y ternarios?</li>
- <li>¿Cuál es la mejor manera de forzar la precedencia de operadores?</li>
- <li>¿Cuándo utilizarías el operador <samp>===</samp> (identidad)?</li>
- <li>¿Cuáles son las dos formas más simples de expresiones?</li>
- <li>Nombra los tres tipos de declaración de condicionales.</li>
- <li>¿Cómo interpretan las declaraciones <samp>if</samp> y <samp>while</samp> las expresiones condicionales de diferentes tipos de datos?</li>
- <li>¿Por qué un bucle <samp>for</samp> es más poderoso que un bucle <samp>while</samp>?</li>
- <li>¿Cuál es el propósito de la declaración <samp>with</samp>?</li>
- </ol>
- <p>Ver <a href="#soluciones_preguntas_capitulos_respuestas_capitulo_15" onclick="c('soluciones_preguntas_capitulos_respuestas_capitulo_15')">"Respuestas del Capítulo 15"</a> del <a href="#soluciones_preguntas_capitulos" onclick="c('soluciones_preguntas_capitulos')">Apéndice A</a> para comprobar las respuestas a estas preguntas.</p><br style="clear:both;"><label class="btn prev" accesskey="p" for="_explorando_javascript" title="Explorando JavaScript">Volver</label><label class="btn next" accesskey="n" for="_funciones_objetos_arrays_javascript" title="Funciones, objetos y arrays en JavaScript">Siguiente</label></div>
- <div class="page" rel="funciones_objetos_arrays_javascript"><div><ul class="breadcrumbs"><li><label class="home" for="_" title="Inicio"></label> »</li><li> Capítulo 16 »</li><li> Funciones, objetos y arrays en JavaScript</li></ul><hr></div>
- <h1 id="funciones_objetos_arrays_javascript">Funciones, objetos y arrays en JavaScript<a href="#funciones_objetos_arrays_javascript"></a></h1>
- <p>Al igual que PHP, JavaScript ofrece el acceso a funciones y objetos. De hecho, JavaScript está basado en objetos, porque, como has visto, tiene que acceder al DOM, lo que hace que cada elemento de un documento HTML esté disponible para manipularlo como un objeto.</p>
- <p>El uso y la sintaxis también son bastante similares a los de PHP, por lo que deberías sentirte como en casa mientras te guío en el uso de funciones y objetos en JavaScript, así como en la exploración en profundidad del manejo de arreglos.</p>
- <h2 id="funciones_objetos_arrays_javascript_funciones_javascript">Funciones en JavaScript<a href="#funciones_objetos_arrays_javascript_funciones_javascript"></a></h2>
- <p>Además de tener acceso a docenas de funciones (o métodos) integrados, como <samp>write</samp>, que ya has visto que se utiliza en <samp>document.write</samp>, puedes crear fácilmente tus propias funciones. Siempre que tengas un fragmento de código relativamente complejo que probablemente se reutilice, tienes un candidato para una función.</p>
- <h3 id="funciones_objetos_arrays_javascript_definicion_funcion">Definición de una función<a href="#funciones_objetos_arrays_javascript_definicion_funcion"></a></h3>
- <p>La sintaxis general para una función se muestra aquí:</p>
- <div class="pre"><pre class="lineno">1<br>2<br>3<br>4<br></pre><code><span class="hl_k">function</span> <span class="hl_f">function_name</span>([<span class="hl_v">parameter</span> [, <span class="hl_v">...</span>]])
- {
- <span class="hl_v">statements</span>
- }</code></div>
- <p>La primera línea de la sintaxis indica lo siguiente:</p>
- <ul>
- <li>La definición comienza con la palabra <samp>function</samp>.</li>
- <li>A continuación, sigue un nombre que debe comenzar con una letra o un guion bajo, seguido de cualquier número de letras, dígitos, signos de dólar o guiones bajos.</li>
- <li>Los paréntesis son obligatorios.</li>
- <li>Uno o más parámetros, separados por comas, son opcionales (indicados por los corchetes, que no forman parte de la sintaxis de la función).</li>
- </ul>
- <p>Los nombres de las funciones son sensibles a mayúsculas, por lo que todos los siguientes strings se refieren a diferentes funciones: <samp>getInput</samp>, <samp>GETINPUT</samp> y <samp>getinput</samp>.</p>
- <p>En JavaScript hay una convención general de nomenclaturas para funciones: la primera letra de cada palabra de un nombre se escribe en mayúsculas, excepto la primera letra, que se escribe en minúsculas. Por lo tanto, de los ejemplos anteriores, <samp>getInput</samp> sería el nombre preferido utilizado por la mayoría de los programadores. Esta convención se conoce comúnmente como <i>bumpyCaps</i>, <i>bumpyCase</i>, o (más frecuentemente) <i>camelCase</i>.</p>
- <p>La llave de apertura inicia las instrucciones que se ejecutarán cuando llames a la función; una llave de cierre correspondiente debe cerrarla. Estas declaraciones pueden incluir una o más declaraciones de <samp>return</samp>, que obligan a la función a detener su ejecución y regresar al código que la llamó. Si se adjunta un valor a la declaración de <samp>return</samp>, el código que la llama puede recuperarlo.</p>
- <h3 id="funciones_objetos_arrays_array_arguments">El array arguments<a href="#funciones_objetos_arrays_array_arguments"></a></h3>
- <p>El array <samp>arguments</samp> es un miembro de toda función. Con él, puedes determinar el número de variables pasadas a una función y cuáles son. Toma el ejemplo de una función llamada <samp>displayItems</samp>. El ejemplo 16-1 muestra una forma de escribirlo.</p>
- <p><i>Ejemplo 16-1. Definición de una función</i></p>
- <div class="pre"><pre class="lineno">1<br>2<br>3<br>4<br>5<br>6<br>7<br>8<br>9<br>10<br>11<br>12<br></pre><code><span class="hl_o"><</span><span class="hl_v">script</span><span class="hl_o">></span>
- <span class="hl_f">displayItems</span>(<span class="hl_s">"Dog"</span>, <span class="hl_s">"Cat"</span>, <span class="hl_s">"Pony"</span>, <span class="hl_s">"Hamster"</span>, <span class="hl_s">"Tortoise"</span>)
- <span class="hl_k">function</span> <span class="hl_f">displayItems</span>(<span class="hl_v">v1</span>, <span class="hl_v">v2</span>, <span class="hl_v">v3</span>, <span class="hl_v">v4</span>, <span class="hl_v">v5</span>)
- {
- <span class="hl_f">document.write</span>(<span class="hl_v">v1</span> <span class="hl_o">+</span> <span class="hl_s">"<br>"</span>)
- <span class="hl_f">document.write</span>(<span class="hl_v">v2</span> <span class="hl_o">+</span> <span class="hl_s">"<br>"</span>)
- <span class="hl_f">document.write</span>(<span class="hl_v">v3</span> <span class="hl_o">+</span> <span class="hl_s">"<br>"</span>)
- <span class="hl_f">document.write</span>(<span class="hl_v">v4</span> <span class="hl_o">+</span> <span class="hl_s">"<br>"</span>)
- <span class="hl_f">document.write</span>(<span class="hl_v">v5</span> <span class="hl_o">+</span> <span class="hl_s">"<br>"</span>)
- }
- <span class="hl_o"></</span><span class="hl_v">script</span><span class="hl_o">></span></code></div>
- <p>Cuando llames a este script en tu navegador, mostrará lo siguiente:</p>
- <div class="pre"><pre>
- Dog
- Cat
- Pony
- Hamster
- Tortoise
- </pre></div>
- <p>Todo esto está bien, pero ¿qué pasaría si quisieras pasar más de cinco elementos a la función? Además, reutilizar la llamada a <samp>document.write</samp> múltiples veces en lugar de emplear un bucle es un desperdicio de programación. Afortunadamente, el array <samp>arguments</samp> te da la flexibilidad para manejar un número variable de argumentos. El Ejemplo 16-2 muestra cómo puedes utilizarla para reescribir el ejemplo anterior de una manera mucho más eficiente.</p>
- <p><i>Ejemplo 16-2. Modificando la función para utilizar el array <samp>arguments</samp></i></p>
- <div class="pre"><pre class="lineno">1<br>2<br>3<br>4<br>5<br>6<br>7<br>8<br>9<br>10<br>11<br></pre><code><span class="hl_o"><</span><span class="hl_v">script</span><span class="hl_o">></span>
- <span class="hl_v">let</span> <span class="hl_v">c</span> <span class="hl_o">=</span> <span class="hl_s">"Car"</span>
- <span class="hl_f">displayItems</span>(<span class="hl_s">"Bananas"</span>, <span class="hl_n">32</span><span class="hl_v">.3</span>, <span class="hl_v">c</span>)
- <span class="hl_k">function</span> <span class="hl_f">displayItems</span>()
- {
- <span class="hl_k">for</span> (<span class="hl_v">j</span> <span class="hl_o">=</span> <span class="hl_n">0</span>; <span class="hl_v">j</span> <span class="hl_o"><</span> <span class="hl_v">displayItems.arguments.length</span>; <span class="hl_o">++</span><span class="hl_v">j</span>)
- <span class="hl_f">document.write</span>(<span class="hl_v">displayItems.arguments</span>[<span class="hl_v">j</span>] <span class="hl_o">+</span> <span class="hl_s">"<br>"</span>)
- }
- <span class="hl_o"></</span><span class="hl_v">script</span><span class="hl_o">></span></code></div>
- <p>Observa el uso de la propiedad <samp>length</samp>, que ya encontraste en el capítulo anterior, y también cómo hago referencia al array <samp>displayItems.arguments</samp> utilizando la variable <samp>j</samp> para desplazarnos sobre ella. También elegí mantener la función breve y concisa al no rodear el contenido del bucle <samp>for</samp> con llaves, ya que contiene solo una única instrucción. Recuerda que el bucle debe detenerse cuando <samp>j</samp> sea uno menos que <samp>length</samp>, no igual a <samp>length</samp>.</p>
- <p>Usando esta técnica, ahora tienes una función que puede tomar tantos (o tan pocos) argumentos como desees y actuar sobre cada argumento como desees.</p>
- <h3 id="funciones_objetos_arrays_javascript_devolviendo_valor">Devolviendo un valor<a href="#funciones_objetos_arrays_javascript_devolviendo_valor"></a></h3>
- <p>Las funciones no se utilizan solo para mostrar cosas. De hecho, se utilizan principalmente para realizar cálculos o manipulaciones de datos y luego devolver un resultado. La función <samp>fixNames</samp> en el Ejemplo 16-3 utiliza el array <samp>arguments</samp> (explicada en la sección anterior) para tomar una serie de string que se le pasan y devolverlas como un solo string. La "corrección" que realiza es convertir todos los caracteres de los argumentos a minúsculas, excepto el primer carácter de cada argumento, que se convertirá a mayúsculas.</p>
- <p><i>Ejemplo 16-3. Limpiando un nombre completo</i></p>
- <div class="pre"><pre class="lineno">1<br>2<br>3<br>4<br>5<br>6<br>7<br>8<br>9<br>10<br>11<br>12<br>13<br>14<br></pre><code><span class="hl_o"><</span><span class="hl_v">script</span><span class="hl_o">></span>
- <span class="hl_f">document.write</span>(<span class="hl_f">fixNames</span>(<span class="hl_s">"the"</span>, <span class="hl_s">"DALLAS"</span>, <span class="hl_s">"CowBoys"</span>))
- <span class="hl_k">function</span> <span class="hl_f">fixNames</span>()
- {
- <span class="hl_v">var</span> <span class="hl_v">s</span> <span class="hl_o">=</span> <span class="hl_s">""</span>
- <span class="hl_k">for</span> (<span class="hl_v">j</span> <span class="hl_o">=</span> <span class="hl_n">0</span>; <span class="hl_v">j</span> <span class="hl_o"><</span> <span class="hl_v">fixNames.arguments.length</span>; <span class="hl_o">++</span><span class="hl_v">j</span>)
- <span class="hl_v">s</span> <span class="hl_o">+=</span> <span class="hl_v">fixNames.arguments</span>[<span class="hl_v">j</span>]<span class="hl_f">.charAt</span>(<span class="hl_n">0</span>)<span class="hl_f">.toUpperCase</span>() <span class="hl_o">+</span>
- <span class="hl_v">fixNames.arguments</span>[<span class="hl_v">j</span>]<span class="hl_f">.substr</span>(<span class="hl_n">1</span>)<span class="hl_f">.toLowerCase</span>() <span class="hl_o">+</span> <span class="hl_s">" "</span>
- <span class="hl_k">return</span> <span class="hl_f">s.substr</span>(<span class="hl_n">0</span>, <span class="hl_v">s.length</span> <span class="hl_o">-</span> <span class="hl_n">1</span>)
- }
- <span class="hl_o"></</span><span class="hl_v">script</span><span class="hl_o">></span></code></div>
- <p>Cuando se llama con los parámetros <samp>the</samp>, <samp>DALLAS</samp> y <samp>CowBoys</samp>, por ejemplo, la función devuelve el string <samp>The Dallas Cowboys</samp>. Vamos a repasar la función.</p>
- <p>Primero inicializa la variable temporal (y local) <samp>s</samp> con el string vacío. Luego, un bucle <samp>for</samp> itera a través de cada uno de los parámetros pasados, aislando el primer carácter del parámetro utilizando el método <samp>charAt</samp> y convirtiéndolo a mayúsculas con el método <samp>toUpperCase</samp>. Los distintos métodos mostrados en este ejemplo están todos integrados en JavaScript y disponibles por defecto.</p>
- <p>Luego se utiliza el método <samp>substr</samp> para obtener el resto de cada string, que se convierte a minúsculas mediante el método <samp>toLowerCase</samp>. Una versión más completa del método <samp>substr</samp>, en este caso, especificaría cuántos caracteres son parte del substring como segundo argumento:</p>
- <div class="pre"><pre class="lineno">1<br></pre><code><span class="hl_f">substr</span>(<span class="hl_n">1</span>, (<span class="hl_v">arguments</span>[<span class="hl_v">j</span>]<span class="hl_v">.length</span>) <span class="hl_o">-</span> <span class="hl_n">1</span> )</code></div>
- <p>En otras palabras, este método <samp>substr</samp> dice: "Empieza con el carácter en la posición <samp>1</samp> (el segundo carácter) y devuelve el resto del string (la longitud menos uno)". Como un detalle agradable, sin embargo, el método <samp>substr</samp> asume que quieres el resto del string si omites el segundo argumento.</p>
- <p>Después de convertir todo el argumento al caso deseado, se añade un carácter de espacio al final y el resultado se agrega a la variable temporal <samp>s</samp>.</p>
- <p>Finalmente, se utiliza nuevamente el método <samp>substr</samp> para devolver el contenido de la variable <samp>s</samp>, excepto por el espacio final, que no se desea que aparezca. Lo eliminamos utilizando <samp>substr</samp> para devolver el string hasta el carácter final pero sin incluirlo.</p>
- <div class="pre"><pre class="lineno">1<br></pre><code><span class="hl_v">fixNames.arguments</span>[<span class="hl_v">j</span>]<span class="hl_f">.substr</span>(<span class="hl_n">1</span>)<span class="hl_f">.toLowerCase</span>()</code></div>
- <p>Tienes que interpretar la expresión dividiéndola mentalmente en partes en los puntos. JavaScript evalúa estos elementos de la declaración de izquierda a derecha de la siguiente manera:</p>
- <ol>
- <li>Comienza con el nombre de la función en sí: <samp>fixNames</samp>.</li>
- <li>Extrae el elemento <samp>j</samp> del array <samp>arguments</samp>, elemento que representa los argumentos de <samp>fixNames</samp>.</li>
- <li>Invoca a <samp>substr</samp> con el valor del parámetro en <samp>1</samp> para el elemento extraído. El resultado pasa en su totalidad, menos el primer carácter, a la siguiente sección
- de la expresión.</li>
- <li>Aplica el método <samp>toLowerCase</samp> al string que se ha pasado hasta ahora.</li>
- </ol>
- <p>Esta práctica a menudo se le conoce como <i>encadenamiento de métodos</i>. Entonces, por ejemplo, si el string <samp>mixedCASE</samp> se pasa a la expresión del ejemplo, pasará por las siguientes transformaciones:</p>
- <div class="pre"><pre>
- mixedCASE
- ixedCASE
- ixedcase
- </pre></div>
- <p>En otras palabras, <samp>fixNames.arguments[j]</samp> produce “mixedCASE”, luego <samp>substr(1)</samp> toma “mixedCASE” y produce “ixedCASE”, y finalmente <samp>toLowerCase()</samp> toma “ixedCASE” y produce “ixedcase”.</p>
- <p>Un recordatorio final: la variable <samp>s</samp> creada dentro de la función es local y, por lo tanto, no se puede acceder a ella fuera de la función. Al devolver <samp>s</samp> en la declaración <samp>return</samp>, hicimos que su valor estuviera disponible para el llamante, quien podría almacenarlo o utilizarlo de la forma que quisiera. Pero <samp>s</samp> en sí mismo desaparece al final de la función. Aunque podríamos hacer que una función opere sobre variables globales (y a veces eso es necesario), es mucho mejor simplemente devolver los valores que quieres preservar y dejar que JavaScript limpie el resto de variables utilizadas por la función.</p><br style="clear:both;"><label class="btn prev" accesskey="p" for="_expresiones_control_flujo_javascript" title="Expresiones y control de flujo en JavaScript">Volver</label><label class="btn next" accesskey="n" for="_validacion_manejo_errores_javascript_php" title="Validación y manejo de errores en JavaScript y PHP">Siguiente</label></div>
- <div class="page" rel="validacion_manejo_errores_javascript_php"><div><ul class="breadcrumbs"><li><label class="home" for="_" title="Inicio"></label> »</li><li> Capítulo 17 »</li><li> Validación y manejo de errores en JavaScript y PHP</li></ul><hr></div>
- <h1 id="validacion_manejo_errores_javascript_php">Validación y manejo de errores en JavaScript y PHP<a href="#validacion_manejo_errores_javascript_php"></a></h1>
- <h2 id="validacion_manejo_errores_javascript_php_validando_entrada_usuario_javascript">Validando la entrada del usuario con JavaScript<a href="#validacion_manejo_errores_javascript_php_validando_entrada_usuario_javascript"></a></h2><br style="clear:both;"><label class="btn prev" accesskey="p" for="_funciones_objetos_arrays_javascript" title="Funciones, objetos y arrays en JavaScript">Volver</label><label class="btn next" accesskey="n" for="_utilizando_comunicaciones_asincronas" title="Utilizando comunicaciones asíncronas">Siguiente</label></div>
- <div class="page" rel="utilizando_comunicaciones_asincronas"><div><ul class="breadcrumbs"><li><label class="home" for="_" title="Inicio"></label> »</li><li> Capítulo 18 »</li><li> Utilizando comunicaciones asíncronas</li></ul><hr></div>
- <h1 id="utilizando_comunicaciones_asincronas">Utilizando comunicaciones asíncronas<a href="#utilizando_comunicaciones_asincronas"></a></h1>
- <h2 id="utilizando_comunicaciones_asincronas_que_es_comunicacion_asincrona">¿Qué es la comunicación asíncrona?<a href="#utilizando_comunicaciones_asincronas_que_es_comunicacion_asincrona"></a></h2><br style="clear:both;"><label class="btn prev" accesskey="p" for="_validacion_manejo_errores_javascript_php" title="Validación y manejo de errores en JavaScript y PHP">Volver</label><label class="btn next" accesskey="n" for="_introduccion_css" title="Introducción a CSS">Siguiente</label></div>
- <div class="page" rel="introduccion_css"><div><ul class="breadcrumbs"><li><label class="home" for="_" title="Inicio"></label> »</li><li> Capítulo 19 »</li><li> Introducción a CSS</li></ul><hr></div>
- <h1 id="introduccion_css">Introducción a CSS<a href="#introduccion_css"></a></h1>
- <h2 id="introduccion_css_importando_hoja_estilos">Importando una hoja de estilos<a href="#introduccion_css_importando_hoja_estilos"></a></h2><br style="clear:both;"><label class="btn prev" accesskey="p" for="_utilizando_comunicaciones_asincronas" title="Utilizando comunicaciones asíncronas">Volver</label><label class="btn next" accesskey="n" for="_css_avanzado_css3" title="CSS avanzado con CSS3">Siguiente</label></div>
- <div class="page" rel="css_avanzado_css3"><div><ul class="breadcrumbs"><li><label class="home" for="_" title="Inicio"></label> »</li><li> Capítulo 20 »</li><li> CSS avanzado con CSS3</li></ul><hr></div>
- <h1 id="css_avanzado_css3">CSS avanzado con CSS3<a href="#css_avanzado_css3"></a></h1>
- <h2 id="css_avanzado_css3_selectores_atributos">Selectores de atributos<a href="#css_avanzado_css3_selectores_atributos"></a></h2><br style="clear:both;"><label class="btn prev" accesskey="p" for="_introduccion_css" title="Introducción a CSS">Volver</label><label class="btn next" accesskey="n" for="_accediendo_css_desde_javascript" title="Accediendo a CSS desde JavaScript">Siguiente</label></div>
- <div class="page" rel="accediendo_css_desde_javascript"><div><ul class="breadcrumbs"><li><label class="home" for="_" title="Inicio"></label> »</li><li> Capítulo 21 »</li><li> Accediendo a CSS desde JavaScript</li></ul><hr></div>
- <h1 id="accediendo_css_desde_javascript">Accediendo a CSS desde JavaScript<a href="#accediendo_css_desde_javascript"></a></h1>
- <h2 id="accediendo_css_desde_javascript_revisando_funcion_getelementbyid">Revisando la función getElementById<a href="#accediendo_css_desde_javascript_revisando_funcion_getelementbyid"></a></h2><br style="clear:both;"><label class="btn prev" accesskey="p" for="_css_avanzado_css3" title="CSS avanzado con CSS3">Volver</label><label class="btn next" accesskey="n" for="_introduccion_jquery" title="Introducción a jQuery">Siguiente</label></div>
- <div class="page" rel="introduccion_jquery"><div><ul class="breadcrumbs"><li><label class="home" for="_" title="Inicio"></label> »</li><li> Capítulo 22 »</li><li> Introducción a jQuery</li></ul><hr></div>
- <h1 id="introduccion_jquery">Introducción a jQuery<a href="#introduccion_jquery"></a></h1>
- <h2 id="introduccion_jquery_por_que_jquery">¿Por qué jQuery?<a href="#introduccion_jquery_por_que_jquery"></a></h2><br style="clear:both;"><label class="btn prev" accesskey="p" for="_accediendo_css_desde_javascript" title="Accediendo a CSS desde JavaScript">Volver</label><label class="btn next" accesskey="n" for="_introduccion_jquery_mobile" title="Introducción a jQuery Mobile">Siguiente</label></div>
- <div class="page" rel="introduccion_jquery_mobile"><div><ul class="breadcrumbs"><li><label class="home" for="_" title="Inicio"></label> »</li><li> Capítulo 23 »</li><li> Introducción a jQuery Mobile</li></ul><hr></div>
- <h1 id="introduccion_jquery_mobile">Introducción a jQuery Mobile<a href="#introduccion_jquery_mobile"></a></h1>
- <h2 id="introduccion_jquery_mobile_incluyendo_jquery_mobile">Incluyendo jQuery Mobile<a href="#introduccion_jquery_mobile_incluyendo_jquery_mobile"></a></h2><br style="clear:both;"><label class="btn prev" accesskey="p" for="_introduccion_jquery" title="Introducción a jQuery">Volver</label><label class="btn next" accesskey="n" for="_introduccion_react" title="Introducción a React">Siguiente</label></div>
- <div class="page" rel="introduccion_react"><div><ul class="breadcrumbs"><li><label class="home" for="_" title="Inicio"></label> »</li><li> Capítulo 24 »</li><li> Introducción a React</li></ul><hr></div>
- <h1 id="introduccion_react">Introducción a React<a href="#introduccion_react"></a></h1>
- <h2 id="introduccion_react_para_que_sirve_react">¿Para qué sirve React?<a href="#introduccion_react_para_que_sirve_react"></a></h2><br style="clear:both;"><label class="btn prev" accesskey="p" for="_introduccion_jquery_mobile" title="Introducción a jQuery Mobile">Volver</label><label class="btn next" accesskey="n" for="_introduccion_html5" title="Introducción a HTML5">Siguiente</label></div>
- <div class="page" rel="introduccion_html5"><div><ul class="breadcrumbs"><li><label class="home" for="_" title="Inicio"></label> »</li><li> Capítulo 25 »</li><li> Introducción a HTML5</li></ul><hr></div>
- <h1 id="introduccion_html5">Introducción a HTML5<a href="#introduccion_html5"></a></h1>
- <h2 id="introduccion_html5_canvas">Canvas<a href="#introduccion_html5_canvas"></a></h2><br style="clear:both;"><label class="btn prev" accesskey="p" for="_introduccion_react" title="Introducción a React">Volver</label><label class="btn next" accesskey="n" for="_canvas_html5" title="Canvas de HTML5">Siguiente</label></div>
- <div class="page" rel="canvas_html5"><div><ul class="breadcrumbs"><li><label class="home" for="_" title="Inicio"></label> »</li><li> Capítulo 26 »</li><li> Canvas de HTML5</li></ul><hr></div>
- <h1 id="canvas_html5">Canvas de HTML5<a href="#canvas_html5"></a></h1>
- <h2 id="canvas_html5_creando_accediendo_canvas">Creando y accediendo a Canvas<a href="#canvas_html5_creando_accediendo_canvas"></a></h2><br style="clear:both;"><label class="btn prev" accesskey="p" for="_introduccion_html5" title="Introducción a HTML5">Volver</label><label class="btn next" accesskey="n" for="_audio_video_html5" title="Audio y vídeo en HTML5">Siguiente</label></div>
- <div class="page" rel="audio_video_html5"><div><ul class="breadcrumbs"><li><label class="home" for="_" title="Inicio"></label> »</li><li> Capítulo 27 »</li><li> Audio y vídeo en HTML5</li></ul><hr></div>
- <h1 id="audio_video_html5">Audio y vídeo en HTML5<a href="#audio_video_html5"></a></h1>
- <h2 id="audio_video_html5_sobre_codecs">Sobre los códecs<a href="#audio_video_html5_sobre_codecs"></a></h2><br style="clear:both;"><label class="btn prev" accesskey="p" for="_canvas_html5" title="Canvas de HTML5">Volver</label><label class="btn next" accesskey="n" for="_otras_caracteristicas_html5" title="Otras características de HTML5">Siguiente</label></div>
- <div class="page" rel="otras_caracteristicas_html5"><div><ul class="breadcrumbs"><li><label class="home" for="_" title="Inicio"></label> »</li><li> Capítulo 28 »</li><li> Otras características de HTML5</li></ul><hr></div>
- <h1 id="otras_caracteristicas_html5">Otras características de HTML5<a href="#otras_caracteristicas_html5"></a></h1>
- <h2 id="otras_caracteristicas_html5_geolocalizacion_servicio_gps">Geolocalización y el servicio de GPS<a href="#otras_caracteristicas_html5_geolocalizacion_servicio_gps"></a></h2><br style="clear:both;"><label class="btn prev" accesskey="p" for="_audio_video_html5" title="Audio y vídeo en HTML5">Volver</label><label class="btn next" accesskey="n" for="_uniendo_todo" title="Uniendo todo">Siguiente</label></div>
- <div class="page" rel="uniendo_todo"><div><ul class="breadcrumbs"><li><label class="home" for="_" title="Inicio"></label> »</li><li> Capítulo 29 »</li><li> Uniendo todo</li></ul><hr></div>
- <h1 id="uniendo_todo">Uniendo todo<a href="#uniendo_todo"></a></h1>
- <h2 id="uniendo_todo_diseniando_aplicacion_redes_sociales">Diseñando una aplicación de redes sociales<a href="#uniendo_todo_diseniando_aplicacion_redes_sociales"></a></h2><br style="clear:both;"><label class="btn prev" accesskey="p" for="_otras_caracteristicas_html5" title="Otras características de HTML5">Volver</label><label class="btn next" accesskey="n" for="_soluciones_preguntas_capitulos" title="Soluciones a las preguntas de los capítulos">Siguiente</label></div>
- <div class="page" rel="soluciones_preguntas_capitulos"><div><ul class="breadcrumbs"><li><label class="home" for="_" title="Inicio"></label> »</li><li> Apéndice A »</li><li> Soluciones a las preguntas de los capítulos</li></ul><hr></div>
- <h1 id="soluciones_preguntas_capitulos">Soluciones a las preguntas de los capítulos<a href="#soluciones_preguntas_capitulos"></a></h1>
- <h2 id="soluciones_preguntas_capitulos_respuestas_capitulo_14">Respuestas del capítulo 14<a href="#soluciones_preguntas_capitulos_respuestas_capitulo_14"></a></h2>
- <ol>
- <li>Para incluir código JavaScript, utilizas las etiquetas <samp><script></samp> y <samp></script></samp>.</li>
- <li>Por defecto, el código JavaScript se mostrará en la parte del documento en la que reside. Si está en el encabezado, se mostrará en el <samp>head</samp>; si está en el cuerpo del documento, se mostrará en el <samp>body</samp>.</li>
- <li>Puedes incluir código JavaScript de otros archivos en tus documentos ya sea copiándolo y pegándolo o, lo más habitual, incluyéndolo como parte de una etiqueta <samp><script src='filename.js'></samp>.</li>
- <li>El equivalente de los comandos <samp>echo</samp> y <samp>print</samp> utilizados en PHP, es la función <samp>document.write</samp> de JavaScript (o método).</li>
- <li>Para crear un comentario en JavaScript, comienza con <samp>//</samp> para un comentario de una sola línea o incluirlo entre <samp>/*</samp> y <samp>*/</samp> para un comentario de varias líneas.</li>
- <li>El operador de concatenación de strings en JavaScript es el símbolo <samp>+</samp>.</li>
- <li>Dentro de una función de JavaScript, puedes definir una variable que tenga un alcance local iniciandola con la palabra reservada <samp>var</samp> , <samp>let</samp> o <samp>const</samp> en la primera asignación.</li>
- <li>
- Para mostrar la URL asignada al enlace con un <samp>id</samp> de <samp>thislink</samp> en los navegadores más importantes, puedes utilizar cualquiera de los dos siguientes comandos:
- <div class="pre"><pre class="lineno">1<br>2<br></pre><code><span class="hl_f">document.write</span>(<span class="hl_f">document.getElementById</span>(<span class="hl_v">'thislink'</span>)<span class="hl_v">.href</span>)
- <span class="hl_f">document.write</span>(<span class="hl_v">thislink.href</span>)</code></div>
- </li>
- <li>
- Los comandos para cambiar a la página anterior en el historial del navegador son:
- <div class="pre"><pre class="lineno">1<br>2<br></pre><code><span class="hl_f">history.back</span>()
- <span class="hl_f">history.go</span>(<span class="hl_n">-1</span>)</code></div>
- </li>
- <li>
- Para reemplazar el documento actual con la página principal del sitio web de O'Reilly (<a href="https://www.oreilly.com" target="new">https://www.oreilly.com</a>), podrías utilizar el siguiente comando:
- <div class="pre"><pre class="lineno">1<br></pre><code><span class="hl_v">document.location.href</span> <span class="hl_o">=</span> <span class="hl_v">'http</span><span class="hl_o">:</span><span class="hl_c">//www.oreilly.com'</span></code></div>
- </li>
- </ol>
- <h2 id="soluciones_preguntas_capitulos_respuestas_capitulo_15">Respuestas del capítulo 15<a href="#soluciones_preguntas_capitulos_respuestas_capitulo_15"></a></h2>
- <ol>
- <li>La diferencia más notable entre los valores booleanos de PHP y JavaScript es que PHP reconoce las palabras reservadas <samp>TRUE</samp>, <samp>true</samp>, <samp>FALSE</samp> y <samp>false</samp>, mientras que en JavaScript solo se admiten <samp>true</samp> y <samp>false</samp>. Además, en PHP, <samp>TRUE</samp> tiene un valor de <samp>1</samp>, y <samp>FALSE</samp> es <samp>NULL</samp>; en JavaScript están representados por <samp>true</samp> y <samp>false</samp>, que pueden ser devueltos como valores de string.</li>
- <li>A diferencia de PHP, no se utiliza ningún carácter (como <samp>$</samp>) para definir el nombre de una variable en JavaScript. Los nombres de las variables en JavaScript pueden comenzar y contener letras con mayúsculas y minúsculas, así como guiones bajos; los nombres también pueden incluir dígitos, pero no el primer carácter.</li>
- <li>La diferencia entre los operadores unarios, binarios y ternarios es el número de operandos que cada uno requiere (uno, dos y tres, respectivamente).</li>
- <li>La mejor manera de forzar tu propia precedencia de operadores es rodear las partes de una expresión que deben evaluarse primero con paréntesis.</li>
- <li>Utilizas el operador de identidad cuando deseas evitar el cambio automático del tipo de dato del operando de JavaScript.</li>
- <li>Las formas más simples de expresiones son las literales (como números y cadenas) y las variables, que simplemente se evalúan a sí mismas.</li>
- <li>Los tres tipos de declaraciones condicionales son <samp>if</samp>, <samp>switch</samp> y el operador <samp>?:</samp>.</li>
- <li>La mayoría de las expresiones condicionales en las declaraciones <samp>if</samp> y <samp>while</samp> son literales o booleanas y, por lo tanto, desencadenan la ejecución cuando se evalúan como <samp>true</samp>. Las expresiones numéricas desencadenan la ejecución cuando se evalúan a un valor distinto de cero. Las expresiones de string desencadenan la ejecución cuando se evalúan a un string no vacío. Un valor <samp>NULL</samp> se evalúa como <samp>false</samp> y, por lo tanto, no desencadena la ejecución.</li>
- <li>Los bucles que utilizan declaraciones <samp>for</samp> son más poderosos que los bucles <samp>while</samp> porque soportan dos parámetros adicionales para controlar el manejo del bucle.</li>
- <li>La declaración <samp>with</samp> toma un objeto como parámetro. Cuando la utilizamos, especificamos un objeto una sola vez; luego, para cada sentencia dentro del bloque <samp>with</samp>, se asume ese objeto.</li>
- </ol><br style="clear:both;"><label class="btn prev" accesskey="p" for="_uniendo_todo" title="Uniendo todo">Volver</label></div>
- <footer><hr><p>© Copyright 2021 Robin Nixon. Todos los derechos reservados.<br><small>Generated by <a href="https://gitlab.com/bztsrc/gendoc">gendoc</a> v1.0.0</small></p></footer>
- </div>
- </div>
- <script>function m(){document.getElementById("menuchk").checked=false;}function c(s){var r=document.getElementById(s);if(r!=undefined){if(r.tagName=="INPUT")r.checked=true;else document.getElementById("_"+r.parentNode.getAttribute("rel")).checked=true;}m();}function s(s){var r=document.getElementById("_s"),p=document.getElementById("_m").getElementsByClassName("page"),n,i,j,a,b,c,d;if(s){s=s.toLowerCase();document.getElementById("_t").style.display="none";r.style.display="block";while(r.firstChild)r.removeChild(r.firstChild);n=document.createElement("p");n.appendChild(document.createTextNode("Resultados de búsqueda"));r.appendChild(n);for(i=1;i<p.length;i++){a=p[i].getAttribute("rel");b="";c=p[i].childNodes;d=p[i].getElementsByTagName("H1")[0].innerText;for(j=1;j<c.length && c[j].className!="btn prev";j++){if(c[j].id!=undefined&&c[j].id!=""){a=c[j].id;d=c[j].innerText;}else if(a!=b&&c[j].innerText!=undefined&&c[j].innerText.toLowerCase().indexOf(s)!=-1){b=a;n=document.createElement("a");n.appendChild(document.createTextNode(d));n.setAttribute("href","#"+a);n.setAttribute("onclick","c('"+a+"');");r.appendChild(n);}}}}else{document.getElementById("_t").style.display="block";r.style.display="none";}}document.addEventListener("DOMContentLoaded",function(e){var i,r,n;document.getElementById("_q").style.display="inline-block";if(document.location.href.indexOf("?")!=-1)document.location.href=document.location.href.replace("?","#");else{r=document.querySelectorAll("LABEL:not(.menu)");while(r.length){l=r[0].getAttribute("for").substr(1);n=document.createElement("a");n.appendChild(document.createTextNode(r[0].innerText));n.setAttribute("href","#"+l);n.setAttribute("onclick","c('"+(l!=""?l:"_")+"');");if(r[0].getAttribute("class")!=undefined)n.setAttribute("class",r[0].getAttribute("class"));if(r[0].getAttribute("title")!=undefined&&l!="")n.setAttribute("title",r[0].getAttribute("title"));if(r[0].getAttribute("accesskey")!=undefined)n.setAttribute("accesskey",r[0].getAttribute("accesskey"));r[0].parentNode.replaceChild(n,r[0]);r=document.querySelectorAll("LABEL:not(.menu)");}try{c(document.location.href.split("#")[1]);}catch(e){}}});</script>
- </body>
- </html>
|