Cerrar menu
Tutoriales En Linea
  • Tutoriales
    • Aprendizaje
    • Video Tutorial
    • Manuales
    • Hagalo usted mismo
    • Explorar todo
  • Adobe
    • After Effects
    • Dreamweaver
    • Premiere Pro CC
    • Photoshop
    • Photoshop Mix
    • Lightroom
    • Illustrator
    • Adobe Muse
    • Creative Cloud
  • Android
    • Developer Android
    • Aplicaciones
    • Android Studio
    • Android Wear
    • Desarrolladores
    • SDK Platform-Tools
    • ADB...depuración Bridge
    • Fastboot
    • Root
    • Recovery
  • Apple
    • iPhone y iPad
    • iPhone
    • iPad
    • Mac OS
    • iCloud
    • iTunes
  • Cursos
    • Actívate
    • Autoempleo
    • Idiomas
    • Curso De HTML
    • Curso de C++
    • Javascript
    • jQuery
    • Matematicas
    • Programacion
    • Python
    • Udacity
    • Diseño Web adaptativo
  • Ciberseguridad
    • Malware
    • Ransomware
    • Virus
    • Troyano
    • Dorkbot
    • Filecoders
    • keylogger
    • Spyware
    • Jackware
    • DDoS
    • HackerOne
    • Interpol
  • Criptomonedas
    • Blockchain
    • Mineria de Criptomonedas
    • Bitcoin (BTC)
    • Bitcoin Cash (BCH)
    • DASH (Dash)
    • Dogecoin (Doge)
    • Ethereum (ETH)
    • Litecoin (LTC)
    • Monero (XMR)
    • Ripple (XRP)
    • Zcash (ZEC)
    • Forex
    • Trading
  • Desarrollo Web
    • Sistema de gestion de contenidos
    • AMP
    • Datalife Engine
    • Blogger
    • WordPress
    • Joomla
    • Bootstrap
    • Plantillas
    • @font-face
    • Schema
    • Website
    • Desarrolladores
    • Lenguaje Web
  • Diseño Web
    • Web Responsive
    • Lenguaje Web
    • Datos estructurados
    • HTML
    • CSS3
    • JavaScript
    • Ajax
    • jQuery
    • PHP
  • Entretenimiento
  • Encuestas
    • GlobalTestMarket
    • Centro de opinion
    • Ipsos i-Say
    • Triaba
    • opinea
    • Toluna
    • YouGov
    • ClixSense
    • ySense
    • Cint
    • Beruby
  • Electricidad
  • Electronica
  • Ganar dinero comprando
    • CashbackDeals
    • Cashback
    • Por ir de compras
    • Aklamio
    • Intercambio de tráfico
    • Justificante de pagos
    • Webs estafas
  • Google
    • Google Pay
    • Adsense
    • Gmail
    • Google Apps
    • Google Chrome
    • Google Cloud Platform
    • Google Consumer Surveys
    • Google Desarrolladores
    • Google Fit
    • Google Maps
    • Google Photos
    • Google Play
    • Google Translation
    • DoubleClick
    • YouTube
    • Chromebooks
  • Marketing
    • SEM
    • SEO
    • Posicionamiento
    • Contenido
    • Publisuites
    • Space Content
    • Coobis
    • Marketing
  • Computadora u ordenador
    • Sistemas operativos
      • Windows
      • Mac OS
      • Android
      • Linux
      • Ubuntu
      • Kali Linux
      • Wifislax
    • hardware
    • Software
    • BIOS
    • Unidad de disco duro
    • Programacion
    • Dispositivos
    • Internet
  • Ofimática
    • Microsoft
    • Suite Ofimatica
    • Access
    • Word
    • Excel
    • Powerpoint
    • Outlook
    • Microsoft Publisher
  • PTC
    • No pierdas tiempo con estas web
  • Redes Sociales
    • Delicious
    • Facebook
    • Instagram
    • linkedin
    • Snapchat
    • TikTok
    • Twitter
    • Pinterest
    • Spotify
    • Vkontakte - VK
    • WhatsApp
  • Smartphone
    • Telefonos
    • Telefonia movil y telecomunicaciones
    • Desbloquear
    • Códigos NCK
    • Liberar
    • Tarjeta SIM
    • Tablet
  • Sitio Web
    • Dominios
    • Hosting
    • Servidores
    • Demo DLE
    • Documentación sobre Datalife Engine
    • Modulos DLE
    • Hack
    • Optimizacion
    • Google Adsense
    • Plantillas
  • Tips
    • Cabello
    • Consejos
    • Cremas
    • Cosmético
    • Cuerpo
    • Dieta
    • Exfoliantes
    • Entrenamiento
    • Ejercicio
    • Estilo
    • Fitness
    • Habitos
    • Hidratante
    • Look
    • Maquillaje
    • Moda
    • Piel Radiante
    • Recetas
    • Ropa
    • Rutina
    • Salud
    • Tratamientos
  • Trabajos
    • Atencion al cliente
    • Asistente virtual
    • Transcripcíon
    • Transcripcíones medica
    • Entrada de datos
    • De edicion y correccion
    • Mystery Shopping
    • Micro trabajos
    • Contabilidad
    • Tutoria y aprendizaje
    • Mas ingresos extras
    • Git
    • GitHub
    • Criptografia
    • Deep Web
    • Hacker
    • FTP
    • Indexar
    • Newsletter
    • Redes y VPN
    • Herramientas online
  • Windows
    • Skype
    • Windows
    • Windows 11
    • Windows 10
    • Windows 8
    • Windows 7
    • Puerta trasera de Windows
    • Microsoft Edge
Facebook X (Twitter) Instagram
  • Sobre nosotros
  • Últimos artículos
  • Herramientas SEO
  • Ver mas temas
  • Más sitios que te gustarán
Facebook X (Twitter) Instagram Pinterest Youtube
  • Secciones
    1. Android
    2. Adobe
    3. Bricolaje
    4. Bachillerato
    5. Cursos
    6. Criptomonedas
    7. Criptografia
    1. Diseño Web
    2. Encuestas
    3. Empleo
    4. Electricidad
    5. Electronica
    6. Forex
    7. Fisica
    1. Google
    2. Hardware
    3. Herramientas Ofimaticas
    4. Herramientas
    5. Internet
    6. Idiomas
    7. IPTV
    1. Programacion
    2. Libros
    3. Microsoft
    4. Manuales
    5. Matematica
    6. Newsletter
    7. Optimizacion
    1. Redes Sociales
    2. Software
    3. Seguridad
    4. Telefonia
    5. WebSite
    6. Ver todas las categorias
    7. Post promocionado
  • Smartphone

    Comprendre les Différences entre les Chargeurs USB et les Chargeurs USB-C : Un Guide Complet

    Huawei Smartphones: Las Mejores Ofertas del Black Friday para Aprovechar

    Gadgets imprescindibles para tu configuración de oficina en casa

    ¡Descubre las tendencias más emocionantes en el mundo de los videojuegos!

    Tendencias en sistemas operativos en smartphone

  • Tecnología
    1. Móviles
    2. Ordenadores
    3. Software
    4. Hardware
    5. Seguridad
    6. Ver todo

    Comprendre les Différences entre les Chargeurs USB et les Chargeurs USB-C : Un Guide Complet

    Huawei Smartphones: Las Mejores Ofertas del Black Friday para Aprovechar

    Gadgets imprescindibles para tu configuración de oficina en casa

    ¡Descubre las tendencias más emocionantes en el mundo de los videojuegos!

    Cómo limpiar la unidad C de archivos innecesarios

    Descubre el misterioso mundo del hash de archivos: ¡todo lo que necesitas saber!

    Los componentes fundamentales que todo PC debería tener

    Que es la tecla TAB

    Cifrado | Seguridad Local

    Maximiza tu productividad: Descubre el sistema interactivo que revolucionará la gestión de proyectos en tu empresa

    Cómo limpiar la unidad C de archivos innecesarios

    Como jugar online y resolver un sudoku

    Que es la tecla TAB

    Cómo deshabilitar la desfragmentación de SSD y HDD en Windows 10 y 11

    Benefits Of Vertical Dual Monitors For Coding And Programming

    AMD ha identificado la causa de la quema de los procesadores Ryzen 7000 y ha lanzado un nuevo AGESA para corregir el problema

    Cifrado | Seguridad Local

    Descubre el misterioso mundo del hash de archivos: ¡todo lo que necesitas saber!

    Virus en el sistema DataLife Engine (DLE) y cómo tratarlos

    La ciberseguridad: Vital Para Las Apuestas Online en España

    ¡Descubre las tendencias más emocionantes en el mundo de los videojuegos!

    ¿Aburrido de tu viejo televisor? Descubre las últimas tendencias en televisores

    Generador de Video IA: La Revolución en la Creación Audiovisual

    Los últimos celulares para que estés a la última

  • Estilo de vida
    1. Entrenamiento
    2. Maquillaje
    3. Dieta
    4. Moda
    5. Trucos y tips
    6. Ver todo

    Desarrolla un cuerpo fuerte y saludable

    ¿Qué es la forma física?

    Mejora los resultados de tu entrenamiento de estabilidad y fuerza

    Consejos para maximizar las caminatas diarias

    ¿Por qué es importante preparar la piel antes de maquillarla?

    Consejos para aplicar pestañas postizas

    Consejos para una piel perfecta este invierno

    La nutrición y un cabello saludable

    Cosas que le pasan a tu cuerpo cuando comes salmón todos los días

    Batidos de proteínas pueden ayudar a mejorar sus hábitos alimenticios

    Batidos de proteinas - Una guía para principiantes

    Snacks nutritivos para cada antojo

    Inspiración de traje de otoño

    La dura verdad sobre las modelos de talla grande

    Razones por las que las marcas de moda de lujo son tan caras

    Cuales son las mejores frutas para adelgazar

    Como enseñar a leer y a escribir

    Como generar cuentas Disneyplus

    Calcular porcentajes con la Calculadora de Windows 10

    Bricolaje para la decoración del hogar

    Top 10 de posturas de yoga

    ¿Por qué es importante preparar la piel antes de maquillarla?

    Inspiración de traje de otoño

    Consejos de belleza para lucir fresca en el verano

  • Marketing

    ¿Sirven de algo los diseñadores Web?… ¿y los redactores de contenido?

    ¿Qué es un Link Dofollow?

    ¿Qué es Nofollow?

    ¿Qué es el remarketing?

    ¿Qué es el posicionamiento web (SEO) y lo necesito para mi sitio web?

  • Juegos

    Para qué se pueden usar las Gafas VR PS4

    La nueva generación de realidad virtual de PlayStation®VR2 y PlayStation®5

    Colaboración entre Sony INZONE y EXCEL Esports

    Sony prohíbe cuatro juegos de terceros en Xbox

    Prepárate para el futuro: Project Trinity llega a finales de 2024

  • Herramientas
Búsqueda extendida

Escriba arriba y presione Enter para buscar.

¡Bienvenido de nuevo!

Inicie sesión o Regístrate ahora

VK

o con Email

¿Has olvidado tu contraseña?

Programacion » Los atributos data y el dataset API

Los atributos data y el dataset API


0 Agosto 07, 2019
Compartir

Compartir
Twitter Pinterest LinkedIn Tumblr WhatsApp Email
Los atributos data y el dataset APIEl atributo data, o más bien, los atributos data-*, introducidos en HTML5, permiten definir datos personalizados asociados a elementos DOM de una forma estandarizada. Si volvemos a HTML4, los datos asociados a elementos DOM eran almacenados en otros atributos, tales como class, id o rel, según las preferencias del desarrollador. No había una recomendación estándar. Incluso había quién definía sus propios atributos (con todo el trabajo extra que ello requería, por ejemplo había que declarar el namespace xmlns propio en la etiqueta <html> para que el documento fuese estrictamente válido).

Vayamos con un ejemplo básico. Supongamos que queremos asociar un <div> con la información del juan. Podríamos utilizar el atributo rel:
<div id="card" rel="-juan">
    Información del  Juan
</div>
Ahora, al trabajar con jаvascript podríamos buscar el div de id="card", obtener el valor del atributo rel y buscar el texto que comience con -* para obtener el relacionado. A medida que se necesitan más datos asociados, más complejo se vuelve el atributo rel y más difícil se hace su análisis con jаvascript. Por ejemplo:
<div id="card" rel="-juan card-type-summary show-avatar-size-480">
    Información del  Juan
</div>

Los atributos data


El atributo data-* permite definir datos personalizados ilimitados y asociarlos a un elemento DOM utilizando cualquier nombre en minúsculas con el prefijo data-. El ejemplo anterior quedaría:
<div id="card" data-="juan" data-card-type="summary" data-show-avatar-size="480">
    Información del  Juan
</div>
El atributo data-* es ampliamente utilizado y para evitar posibles conflictos, es recomendable que incluyas en el nombre algún tipo de identificador de tu aplicación. Por ejemplo, yo podría utilizar data-cyb-height en lugar de un genético data-height que pueda ser utilizado por otras aplicaciones. El nombre puede incluir _ y : pero no se recomienda que incluya caracteres especiales distintos a [a-z].


Además, has de saber que:

  • El valor del atributo data-* puede ser cualquier cadena de texto. Puede contener números pero el tipo de datos es string. Por ejemplo, data-age="30" tendría como valor el texto 30, que es diferente al número 30.
  • Los atributos data-* son privados del documento HTML. Esto quiere decir que cualquier sistema externo debería ignorarlos, incluyendo motores de búsqueda. Por tanto, no son adecuados para estructurar datos semánticamente, a diferencia de los microdatos como schema.org u otra especificación1.
  • El atributo data-* no debería ser utilizado si existe otro atributo o elemento específico para representar un dato. Por ejemplo, datos de fecha y hora deberían ser incluidos en el elemento <time>.
  • El atributo data-* no debería utilizarse como selector CSS o cualquier otro propósito de estilo, pues implica importancia directa para el y, por tanto, esos datos deberían representarse de una forma más accesible.

Trabajando con data-* en jаvascript


Con la introducción de data-* en HTML5 también se introdujeron métodos de y modificación desde jаvascript. En concreto, se introdujo el API dataset (no confundir con datalist), aunque se puede trabajar también con getAttribute y setAttribute, métodos que ya existían antes y no son específicos para los atributos data-*.

Dataset API


El API Dataset permite obtener y establecer los valores de los atributos data-* de un forma muy sencilla. Cada elemento del DOM tiene asociada la propiedad dataset, que es un objeto tipo DOMStringMap con todos sus atributos data-*. Por ejemplo, si tomamos el anterior HTML, podríamos acceder al elemento mediante getElementById y acceder a la propiedad dataset del elemento.

Hay que tener en cuenta que el nombre del atributo en el dataset es transformado eliminando el prefijo data- y del restante se eliminan los guiones y el nombre se transforma a formato camelCase. Por ejemplo, tomemos los atributos data-* del ejemplo anterior. Esta es su correspondencia en el dataset:

  • data- →
  • data-card-type → cardType (nota como se elimina el prefijo data- y del restante se eliminan los guiones y se transforma a notación camelCase).
  • data-show-avatar-size → showAvatarSize (fíjate aquí también en la notación camelCase).
Y se accedería a su valor del siguiente modo:
// Obtenemos un referencia al elemento
var card = document.getElementById("card");

// En la propiedad dataset del elemento estarán todos los atributos data-*
var name = card.dataset.;
var cardtype = card.dataset.cardType;
var avatarsize = card.dataset.showAvatarSize;
Es decir, el card.dataset sería el siguiente objeto:
{
    : "juan",
    cardType: "summary",
    showAvatarSize: "480"
}
Modificar el valor de un atributo data-*, por ejemplo cambiar data-card-type a «full», es tan fácil como asignarle el nuevo valor:
// Asignamos un nuevo valor al elemento cardType del dataset,
// el cual hacía referencia al atributo data-card-type
card.dataset.cardType = "full";
Para eliminar un valor podríamos asignarle el valor null o un string vacío, pero si queremos eliminar realmente el atributo data-* hay que utilizar el operador delete (tras utilizar el operador delete, si intentamos obtener el valor del atributo obtendremos undefined):
delete card.dataset.cardType;
El dataset API es soportado en todos los navegadores principales pero en IE sólo está disponible desde la versión IE11. Hay algunas bibliotecas js para implementar el dataset API o puedes utilizar algunos de los siguientes métodos.

getAttribute, setAttribute y removeAttribute


Con estos tres métodos se puede obtener y establecer el valor de los atributos data-* así como eliminarlos, incluso en navegadores que no soportan el dataset API.
// Obtenemos un referencia al elemento
var card = document.getElementById("card");

// Accedemos a los atributos data-*
var name = card.getAttribute( "data-" );
var cardtype = card.getAttribute( "data-card-type" );
var avatarsize = card.getAttribute( "data-show-avatar-size" );

// Establecer el valor de un atributo data-*
card.setAttribute( 'data-card-type', 'full' );

// Eliminar un atributo con removeAttribute, se le asigna el valor null
card.removeAttribute( 'data-card-type' );

jQuery .data()


El método .data() de jQuery ofrece una alta compatibilidad entre diversos navegadores y sería el método de elección si utilizas esta biblioteca. Para acceder a los atributos data-* con este método sólo necesitas el nombre del atributo sin el prefijo data-. Es muy importante saber que el método .data() no afecta al DOM, lo que supone una diferencia importante con el dataset API y con los métodos getAttribute, setAttribute y removeAttribute.

// Obtenemos un referencia al elemento
var card = $("#card");

// Accedemos a los atributos data-*
var name = card.data( "" );
var cardtype = card.data( "card-type" );
var avatarsize = card.data( "show-avatar-size" );

// Establecer el valor de un atributo data-*
card.data( 'card-type', 'full' );
// En la alerta saldrá el nuevo valor "full"
alert( card.data( "card-type" ) );

// removeData elimina un data previamente almacenado con el método .data()
// Como .data no afecta al DOM, tras utilizar removeData el valor vuelve al inicial "summary"
card.removeData( 'card-type' );
// En la alerta saldrá el valor inicial "summary"
alert( card.data( "card-type" ) );
También se puede acceder a todos los atributos data a la vez:
// data será un objeto con todos los atributos data-*
var data = $("#card").data();
var name = data.;
var cardtype = data.cardType;
var avatarsize = data.showAvatarSize;
Cómo ventaja adicional, jQuery tratará de convertir los datos almacenados en un atributo data-* al tipo correcto: lógico, integer, objeto, etc. Por ejemplo, en el siguiente código el atributo data-months es un array.
<div id="miDiv" data-months="[1, 5, 12]">
</div>
Con dataset API tendríamos que convertir el string a un array mientras que jQuery lo hace automáticamente:
var months = $('#miDiv').data( 'months' ); // months = [1, 5, 12]

Referencias


  • W3: Embedding custom non-visible data with the data-* attributes
  • HTMLElement.dataset
  • jQuery API: .data()
Síguenos en
Google News Flipboard
  • 100
  • 1
  • 2
  • 3
  • 4
  • 5
Ajax con JSON y PHP con JavaScript
Qué son las HTTP cookies y como funcionan
Tutoriales En Linea
Tutoriales En Linea
  • Website
  • Facebook
  • Twitter
  • LinkedIn
  • Pinterest
  • Instagram

Sobre mi: CEO de Tutoriales En Linea:
https://tutorialesenlinea.futbolgratis.org
Fundador y CEO de Tutoriales En Linea...Leer mas...

Artículos Relacionados


Ajax con jQuery, JSON y PHP: ejemplo paso a paso

Ajax con jQuery, JSON y PHP: ejemplo paso a paso

Ajax con JSON y PHP con JavaScript

Ajax con JSON y PHP con JavaScript

Qué son las HTTP cookies y como funcionan

Qué son las HTTP cookies y como funcionan


Comentarios



Información
s que no esten registrados no pueden dejar comentarios, te invitamos a que te registre!

Destacados

Lista IPTV con canales para colombia

Mayo 23 43 996

Como instalar SS IPTV en una Smart Tv Samsung

Ene 22 10 390

Como podemos conseguir proxies

Jun 21 11 622

Historia de los sistemas operativos

Mayo 16 31 069

Lo mas leidos

Herramientas SEO para posicionamiento de nuestra web 2024

Por 17-06-24

Herramienta online de generador de datos estructurados

Por Tutoriales En Linea 17-06-24

Las 7 mejores páginas para descargar películas en .torrent en español

Por 26-09-24

Etiquetas

Lenguajes De Programacion




Sobre nosotros

Tutoriales En Linea

¡Bienvenidos a Tutoriales En Línea, el sitio web perfecto para encontrar todas las herramientas necesarias para mejorar tus habilidades de forma gratuita! En Tutoriales En Linea se encuentran tutoriales, cursos online y aprendizaje de calidad, muy útiles para desarrollar tus capacidades... Leer mas...

Tiene una pregunta? ar...

Enlaces

  • Sobre nosotros
  • Ultimos tutoriales
  • Publicar tutorial
  • Ver mas temas
  • Ultimos comentarios
  • ¿Preguntas Frecuentes?
  • Derechos de autor
  • Politica de cookies
  • Nuestro equipo
  • Normas

Herramientas online

  • Buscador de recetas
  • Prueba de diseño web
  • Codificar en binarios, hexadecimales...
  • Cual es mi IP
  • Test de velocidad
  • Editor HTML
  • Test de escritura
  • Test de nutricion
  • Descargar Videos
  • Generador de datos estructurados

Recursos

  • Analisis de tus problemas de SEO
  • Herramientas SEO
  • Generar palabras claves
  • Referencia de CSS3
  • Convertir HTML a XML
  • Acortador de URL
  • Selector de colores
  • Contador de palabras
  • Comprimir imagenes
  • Conversor a URI de datos
  • Suscribirse
Facebook Twitter Instagram Pinterest Linkedin Youtube
  • Anunciarse
  • Socios externos
  • Política de privacidad
  • Términos y Condiciones
  • Sobre nosotros
  • ar
© Tutoriales En Linea. Reservados todos los derechos, queda prohibida la reproducción parcial o total sin previa autorización.