tabi/es/blog/javascript/index.html
2025-11-22 16:30:18 +00:00

2 lines
No EOL
16 KiB
HTML
Raw Blame History

This file contains invisible Unicode characters

This file contains invisible Unicode characters that are indistinguishable to humans but may be processed differently by a computer. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

<!doctype html><html lang=es><head><meta charset=UTF-8><meta content="default-src 'self';font-src 'self' data:;img-src 'self' https://* data:;media-src 'self' https://cdn.jsdelivr.net/;style-src 'self';frame-src player.vimeo.com https://www.youtube-nocookie.com;connect-src 'self' https://tabi-stats.osc.garden vhiweeypifbwacashxjz.supabase.co;script-src 'self' https://tabi-stats.osc.garden cdn.jsdelivr.net 'self'" http-equiv=Content-Security-Policy><meta content="width=device-width,initial-scale=1.0" name=viewport><meta content=https://welpo.github.io/tabi name=base><title>
~/tabi • Sin JavaScript obligatorio</title><link href=https://welpo.github.io/tabi/img/seedling.png rel=icon type=image/png><link href='data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><text y="50%" x="50%" dominant-baseline="central" text-anchor="middle" font-size="88">🌱</text></svg>' rel=icon><link title="~/tabi - Atom Feed" href=https://welpo.github.io/tabi/atom.xml rel=alternate type=application/atom+xml><link href="https://welpo.github.io/tabi/custom_subset.css?h=0b9535a28bc3d5bf2321" rel=stylesheet><link href="https://welpo.github.io/tabi/main.css?h=3716ab3457d2dd050b3c" rel=stylesheet><meta content="light dark" name=color-scheme><meta content=#087e96 name=theme-color><meta content="JavaScript solo se utiliza cuando HTML y CSS no son suficientes." name=description><meta content="JavaScript solo se utiliza cuando HTML y CSS no son suficientes." property=og:description><meta content="Sin JavaScript obligatorio" property=og:title><meta content=article property=og:type><meta content="https://welpo.github.io/tabi/blog/javascript/social_cards/es_blog_javascript.jpg?h=aff2f7bae8a3e00fff2e" property=og:image><meta content=1400 property=og:image:width><meta content=800 property=og:image:height><meta content="https://welpo.github.io/tabi/blog/javascript/social_cards/es_blog_javascript.jpg?h=aff2f7bae8a3e00fff2e" name=twitter:image><meta content=summary_large_image name=twitter:card><meta content=en_GB property=og:locale:alternate><link href=https://welpo.github.io/tabi/blog/javascript/ hreflang=en rel=alternate><meta content=es_ES property=og:locale:alternate><link href=https://welpo.github.io/tabi/es/blog/javascript/ hreflang=es rel=alternate><meta content=ca_ES property=og:locale:alternate><link href=https://welpo.github.io/tabi/ca/blog/javascript/ hreflang=ca rel=alternate><meta content=https://welpo.github.io/tabi/es/blog/javascript/ property=og:url><meta content=~/tabi property=og:site_name><noscript><link href=https://welpo.github.io/tabi/no_js.css rel=stylesheet></noscript><script src=https://welpo.github.io/tabi/js/initializeTheme.min.js></script><script defer src=https://welpo.github.io/tabi/js/themeSwitcher.min.js></script><script async data-goatcounter=https://tabi-stats.osc.garden/count src=https://tabi-stats.osc.garden/count.js></script><script src="https://welpo.github.io/tabi/js/searchElasticlunr.min.js?h=3626c0ef99daa745b31e" defer></script><script defer src=https://welpo.github.io/tabi/js/lunr/lunrStemmerSupport.min.js></script><script defer src=https://welpo.github.io/tabi/js/lunr/lunr.es.min.js></script><body><a href=#main-content id=skip-link>Saltar al contenido</a><header><nav class=navbar><div class=nav-title><a class=home-title href=https://welpo.github.io/tabi/es/>~/tabi</a></div><div class=nav-navs><ul><li><a class="nav-links no-hover-padding" href=https://welpo.github.io/tabi/es/blog/>blog </a><li><a class="nav-links no-hover-padding" href=https://welpo.github.io/tabi/es/archive/>archivo </a><li><a class="nav-links no-hover-padding" href=https://welpo.github.io/tabi/es/tags/>etiquetas </a><li><a class="nav-links no-hover-padding" href=https://welpo.github.io/tabi/es/projects/>proyectos </a><li class=menu-icons-container><ul class=menu-icons-group><li class="js menu-icon"><div aria-label="Haz clic o usa $SHORTCUT para abrir la búsqueda" class="search-icon interactive-icon" title="Haz clic o usa $SHORTCUT para abrir la búsqueda" id=search-button role=button tabindex=0><svg viewbox="0 -960 960 960" xmlns=http://www.w3.org/2000/svg><path d="M784-120 532-372q-30 24-69 38t-83 14q-109 0-184.5-75.5T120-580q0-109 75.5-184.5T380-840q109 0 184.5 75.5T640-580q0 44-14 83t-38 69l252 252-56 56ZM380-400q75 0 127.5-52.5T560-580q0-75-52.5-127.5T380-760q-75 0-127.5 52.5T200-580q0 75 52.5 127.5T380-400Z"/></svg></div><li class=language-switcher><details class=dropdown><summary aria-label="Selección de idioma" title="Selección de idioma" aria-haspopup=true role=button><div class=language-switcher-icon></div></summary> <div class=dropdown-content role=menu>Español<a aria-label=Català href=https://welpo.github.io/tabi/ca/blog/javascript/ lang=ca role=menuitem>Català</a><a aria-label=English href=https://welpo.github.io/tabi/blog/javascript/ lang=en role=menuitem>English</a><a aria-label=العربية href=https://welpo.github.io/tabi/ar/blog/javascript/ lang=ar role=menuitem>العربية</a></div></details><li class="theme-switcher-wrapper js"><div aria-label="Cambiar a modo oscuro" title="Cambiar a modo oscuro/claro" aria-pressed=false class=theme-switcher role=button tabindex=0></div><div aria-label="Restablecer modo a configuración predeterminada" class="theme-resetter arrow" title="Restablecer modo a configuración predeterminada" aria-hidden=true role=button tabindex=0></div></ul></ul></div></nav></header><div class=content id=main-content><main><article class=h-entry><h1 class="p-name article-title">Sin JavaScript obligatorio</h1><a class="u-url u-uid" href=https://welpo.github.io/tabi/es/blog/javascript/></a><ul class=meta><li><time class=dt-published datetime=2023-01-06>6 ene 2023</time><li title="422 palabras"><span aria-hidden=true class=separator></span>3 mins de lectura<li class=tag><span aria-hidden=true class=separator></span>Etiquetas: <li class=tag><a class=p-category href=https://welpo.github.io/tabi/es/tags/funcionalidad/>funcionalidad</a>, <li class=tag><a class=p-category href=https://welpo.github.io/tabi/es/tags/tutorial/>tutorial</a></ul><ul class="meta last-updated"><li><time class=dt-updated datetime=2025-02-21>Actualizado el 21 feb 2025</time><li><span aria-hidden=true class=separator></span><a class=external href=https://github.com/welpo/tabi/commits/main/content/blog/javascript/index.es.md>Ver cambios</a></ul><p class=p-summary hidden>JavaScript solo se utiliza cuando HTML y CSS no son suficientes.<section class="e-content body"><p>Este tema no requiere JavaScript de manera obligatoria. Opcionalmente, puede cargar una cantidad mínima de JavaScript para añadir algunas características que son imposibles de lograr con solo HTML y CSS.<h2 id=opciones-habilitadas-globalmente><a aria-label="Anchor link for: opciones-habilitadas-globalmente" class="header-anchor no-hover-padding" href=#opciones-habilitadas-globalmente><span aria-hidden=true class=link-icon></span></a> Opciones habilitadas globalmente</h2><ul><li><p><a href=https://welpo.github.io/tabi/es/blog/mastering-tabi-settings/#busqueda><strong>Búsqueda</strong></a>. Habilitada estableciendo un idioma por defecto y <code>build_search_index = true</code> en la sección principal de <code>config.toml</code>. (~23KB de JavaScript)</p><li><p>El <strong>interruptor de modo claro/oscuro</strong> puede habilitarse configurando <code>theme_switcher = true</code> en la sección <code>[extra]</code> de tu <code>config.toml</code> (~1KB de JavaScript).</p><li><p><strong>Descodificación de correo electrónico</strong> (~400 bytes). Para proteger contra bots que recopilan correos electrónicos desde tu sitio web, puedes configurar <code>encode_plaintext_email = true</code>. Si tu sitio está en un repositorio público, para mayor protección, considera configurar tu <code>email</code> como una cadena codificada en base64<sup class=footnote-reference id=fr-1-1><a href=#fn-1>1</a></sup>.</p></ul><h2 id=opciones-que-se-pueden-sobreescribir-de-forma-jerarquica><a aria-label="Anchor link for: opciones-que-se-pueden-sobreescribir-de-forma-jerarquica" class="header-anchor no-hover-padding" href=#opciones-que-se-pueden-sobreescribir-de-forma-jerarquica><span aria-hidden=true class=link-icon></span></a> Opciones que se pueden sobreescribir de forma jerárquica</h2><p>Las siguientes opciones pueden especificarse para publicaciones, secciones y a nivel global, siguiendo la jerarquía de <code>página > sección > config.toml</code>:<ul><li><a href=https://welpo.github.io/tabi/es/blog/markdown/#katex><strong>Soporte de KaTeX</strong></a>. Habilitado al configurar <code>katex = true</code> (274 KB). Para renderizar fórmulas sin JS, prueba <a class=external href=https://developer.mozilla.org/docs/Web/MathML/>MathML</a>.<li><a href=https://welpo.github.io/tabi/es/blog/shortcodes/#diagramas-de-mermaid><strong>Diagramas de Mermaid</strong></a>. Habilitado al configurar <code>mermaid = true</code> (~2.5 MB).<li><a href=https://welpo.github.io/tabi/es/blog/markdown/#bloque-de-codigo><strong>Copia de bloques de código con un solo clic</strong></a>. Habilitado al configurar <code>copy_button = true</code> (~700 bytes).<li><a href=https://welpo.github.io/tabi/es/blog/shortcodes/#mostrar-ruta-o-url><strong>Nombres de bloques de código clicables</strong></a>. Se activa configurando <code>code_block_name_links = true</code>. (~400 bytes)<li><a href=https://welpo.github.io/tabi/es/blog/mastering-tabi-settings/#filtrar-proyectos><strong>Filtraje por etiquetas</strong> para cuadrículas de tarjetas</a> (p. ej. <a href=https://welpo.github.io/tabi/es/projects/>proyectos</a>) (~2KB). Habilitado al configurar <code>enable_cards_tag_filtering = true</code>.</ul><p>Para especificar estas opciones:<ul><li><strong>Globalmente</strong>: Añádelas en la sección <code>[extra]</code> de tu <code>config.toml</code>.<li><strong>Para una sección</strong>: Añádelas en la sección <code>[extra]</code> del front matter del <code>_index.md</code> de la sección.<li><strong>Para una publicación individual</strong>: Configura las variables correspondientes en la sección <code>[extra]</code> del front matter de la publicación.</ul><h2 id=opciones-que-pueden-habilitarse-globalmente-o-para-publicaciones-individuales><a aria-label="Anchor link for: opciones-que-pueden-habilitarse-globalmente-o-para-publicaciones-individuales" class="header-anchor no-hover-padding" href=#opciones-que-pueden-habilitarse-globalmente-o-para-publicaciones-individuales><span aria-hidden=true class=link-icon></span></a> Opciones que pueden habilitarse globalmente o para publicaciones individuales</h2><ul><li><a href=https://welpo.github.io/tabi/es/blog/comments/><strong>Comentarios</strong></a>. giscus (2 KB), utterances (1 KB), Hyvor Talk (~800 bytes) o Isso (1KB) pueden habilitarse globalmente configurando <code>enabled_for_all_posts = true</code> en la sección apropiada de tu <code>config.toml</code> (<code>[extra.giscus]</code>, <code>[extra.utterances]</code>, <code>[extra.hyvortalk]</code> o <code>[extra.isso]</code>). Para habilitar comentarios en publicaciones individuales, configura el nombre del sistema <code>= true</code> (por ejemplo, <code>hyvortalk = true</code>) en el front matter de la publicación.</ul><p>Aparte de eso, es un tema rápido con HTML y CSS que funciona con JavaScript deshabilitado. Justo como debería ser (la mayoría de) la web :-)<hr><section class=footnotes><ol class=footnotes-list><li id=fn-1><p>Para codificar tu correo electrónico en base64 puedes usar <a class=external href=https://www.base64encode.org/>herramientas en línea</a> o, en tu terminal, ejecutar: <code>printf 'mail@example.com' | base64</code>. <a href=#fr-1-1></a></p></ol></section></section><form action="https://vhiweeypifbwacashxjz.supabase.co/rest/v1/rpc/increment_hits?apikey=sb_publishable_EoB7MFJhCmb6PiAk-GPJ4w_PGhQ44Ru" class=iine-form method=post><input name=page_slug type=hidden value=/blog/javascript/><button aria-label="Me gusta esta publicación" title="Me gusta esta publicación" class=iine-button data-icon=thumbs_up data-slug=/blog/javascript/>👍</button></form><nav class="full-width article-navigation"><div><a aria-describedby=left_title aria-label=Siguiente href=https://welpo.github.io/tabi/es/blog/markdown/><span class=arrow></span> Siguiente</a><p aria-hidden=true id=left_title>Ejemplos de Markdown</div><div><a aria-describedby=right_title aria-label=Anterior href=https://welpo.github.io/tabi/es/blog/toc/>Anterior <span class=arrow></span></a><p aria-hidden=true id=right_title>Tabla de contenido</div></nav></article></main><span class=hidden id=copy-success> Copiado! </span><span class=hidden id=copy-init> Copiar código al portapapeles </span><script defer src=https://welpo.github.io/tabi/js/copyCodeToClipboard.min.js></script><script defer src=https://cdn.jsdelivr.net/gh/welpo/iine@main/iine.mini.js></script></div><footer><section><nav class="socials nav-navs"><ul><li><a class="nav-links no-hover-padding social" href=https://welpo.github.io/tabi/es/atom.xml> <img alt=feed loading=lazy src=https://welpo.github.io/tabi/social_icons/rss.svg title=feed> </a><li class=js><a class="nav-links no-hover-padding social" data-encoded-email=dGFiaUBvc2MuZ2FyZGVu href=#><img alt=email loading=lazy src=https://welpo.github.io/tabi/social_icons/email.svg title=email> </a><li><a class="nav-links no-hover-padding social" rel=" me" href=https://github.com/welpo/> <img alt=github loading=lazy src=https://welpo.github.io/tabi/social_icons/github.svg title=github> </a><li><a class="nav-links no-hover-padding social" rel=" me" href=https://soundcloud.com/oskerwyld> <img alt=soundcloud loading=lazy src=https://welpo.github.io/tabi/social_icons/soundcloud.svg title=soundcloud> </a><li><a class="nav-links no-hover-padding social" rel=" me" href=https://instagram.com/oskerwyld> <img alt=instagram loading=lazy src=https://welpo.github.io/tabi/social_icons/instagram.svg title=instagram> </a><li><a class="nav-links no-hover-padding social" rel=" me" href=https://youtube.com/@oskerwyld> <img alt=youtube loading=lazy src=https://welpo.github.io/tabi/social_icons/youtube.svg title=youtube> </a><li><a class="nav-links no-hover-padding social" rel=" me" href=https://open.spotify.com/artist/5Hv2bYBhMp1lUHFri06xkE> <img alt=spotify loading=lazy src=https://welpo.github.io/tabi/social_icons/spotify.svg title=spotify> </a></ul></nav><nav class=nav-navs><small> <ul><li><a class="nav-links no-hover-padding" href=https://welpo.github.io/tabi/es/about/> sobre mí </a><li><a class="nav-links no-hover-padding" href=https://welpo.github.io/tabi/es/privacy/> política de privacidad </a><li><a class="nav-links no-hover-padding" href=https://tabi-stats.osc.garden/> estadísticas del sitio </a><li><a class="nav-links no-hover-padding" href=https://welpo.github.io/tabi/sitemap.xml> mapa del sitio </a></ul> </small></nav><div class=credits><small> Impulsado por <a href=https://www.getzola.org>Zola</a> y <a href=https://github.com/welpo/tabi>tabi</a><a href=https://github.com/welpo/tabi> Código del sitio </a></small></div></section><script async src=https://welpo.github.io/tabi/js/decodeMail.min.js></script><div class="search-modal js" aria-labelledby=modalTitle id=searchModal role=dialog><h1 class=visually-hidden id=modalTitle>Buscar</h1><div id=modal-content><div id=searchBar><div aria-hidden=true class=search-icon><svg viewbox="0 -960 960 960" xmlns=http://www.w3.org/2000/svg><path d="M784-120 532-372q-30 24-69 38t-83 14q-109 0-184.5-75.5T120-580q0-109 75.5-184.5T380-840q109 0 184.5 75.5T640-580q0 44-14 83t-38 69l252 252-56 56ZM380-400q75 0 127.5-52.5T560-580q0-75-52.5-127.5T380-760q-75 0-127.5 52.5T200-580q0 75 52.5 127.5T380-400Z"/></svg></div><input aria-controls=results-container aria-expanded=false autocomplete=off id=searchInput placeholder=Buscar… role=combobox spellcheck=false><div class="close-icon interactive-icon" title="Borrar búsqueda" id=clear-search role=button tabindex=0><svg viewbox="0 -960 960 960" xmlns=http://www.w3.org/2000/svg><path d="m256-200-56-56 224-224-224-224 56-56 224 224 224-224 56 56-224 224 224 224-56 56-224-224-224 224Z"/></svg></div></div><div id=results-container><div id=results-info><span id=zero_results> No hay resultados</span><span id=one_results> $NUMBER resultado</span><span id=many_results> $NUMBER resultados</span><span id=two_results> $NUMBER resultados</span><span id=few_results> $NUMBER resultados</span></div><div id=results role=listbox></div></div></div></div></footer>