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?

Noticias » Cómo usar las nuevas variables CSS

Cómo usar las nuevas variables CSS


0 Febrero 07, 2019
Compartir

Compartir
Twitter Pinterest LinkedIn Tumblr WhatsApp Email
Las variables CSS, técnicamente llamadas propiedades CSS no estándar, simplifican tus archivos CSS y permiten crear efectos tan interesantes como cambiar dinámicamente los estilos aplicados en una página y mejorar las características de las propiedades CSS estándar.

Por qué son necesarias estas variables

Cuando se diseña un sitio o aplicación web es habitual reutilizar una serie de colores para dar consistencia al diseño. El problema es que repetir los mismos colores una y otra vez no solo es muy aburrido sino que es muy propenso a cometer errores. Cuando quieras cambiar un color, aunque hagas un "Buscar y reemplazar" en tu editor de código, seguro que te dejarás sin cambiar algún color en algún archivo.

Por supuesto desde hace tiempo muchos diseñadores usan preprocesadores como Sass o LESS y definen variables para guardar estos valores. Sin embargo, estas variables tienen una limitación muy importante: no se pueden modificar en tiempo real mientras la página se muestra en el navegador.

Las variables CSS sí que permiten estos cambios en tiempo real, por lo que es posible por ejemplo diseñar varios temas para el sitio de manera que el pueda elegir el estilo que más le guste.

Las variables CSS en la práctica

Las variables CSS añaden dos nuevas funcionalidades a los archivos CSS tradicionales:

  • Permiten asignar cualquier valor a una propiedad cuyo nombre podemos elegir libremente.
  • Permiten reutilizar esos valores en cualquier otra propiedad gracias a la función var()
Este ejemplo sencillo muestra cómo definir y usar una variable CSS:
:root {
  --tl-principal: #1d1d1d;
}

#footer h1 {
  color: var(--color-principal);
}
--tl-principal es una propiedad CSS definida arbitrariamente por el creador de esta hoja de estilos y cuyo valor es #1d1d1d. Aunque puedes elegir cualquier nombre para las variables, estos siempre tienen que empezar con dos guiones medios (--).

La función var()obtiene el valor de la propiedad cuyo nombre se indica y lo inserta en el lugar donde se llama a la función. De esta manera, el ejemplo anterior es equivalente a:
#footer h1 {
  color: #1d1d1d;
}
La sintaxis de las variables CSS resulta un poco extraña al principio. La pregunta más habitual suele ser: ¿y por qué no se puede declarar la variable simplemente como $footer en vez de --footer? La respuesta es que la sintaxis $footer está reservada para en el futuro poder definir "macros", tal y como se explica en este artículo.

Sintaxis de las variables CSS

La sintaxis que definen las variables CSS o "propiedades CSS no estándar" es muy simple:
--color-cabecera: #1d1d1d;
El nombre de las propiedades distingue mayúsculas de minúsculas, por lo que --color-cabecera y --color-Cabecera se consideran diferentes propiedades. No pienses que estas variables solo sirven para guardar valores simples. Por ejemplo, la siguiente sintaxis también es válida:
--footer: if(x > 5) this.width = 10;
Aunque esta propiedad no sería útil como variable CSS y aunque no se puede usar como valor de ninguna otra propiedad CSS, este valor podría procesarse en el navegador mediante jаvascript para ejecutar alguna tarea compleja. Esta funcionalidad abre la puerta a muchos trucos y técnicas avanzadas que son imposibles con los preprocesadores CSS actuales (Sass y LESS).

Herencia

Las propiedades CSS no estándar también siguen las mismas reglas de "herencia en cascada" de las propiedades CSS estándar, por lo que puedes definir la misma variable con diferentes niveles de especificidad:
:root { --color: blue; }
div { --color: green; }
#alert { --color: red; }
* { color: var(--color); }
<p>Este contenido se ve azul (definido por ":root")</p>
<div>Este contenido se ve verde (definido por "div")</div>
<div id="alert">
  Este contenido se ve rojo (definido por "#alert")
  <p>este contenido también se ve rojo
     (heredado de su elemento padre)</p>
</div>
De esta manera, puedes combinar las variables CSS con las media queries en tus diseños "responsive". El siguiente ejemplo muestra cómo incrementar el margen de un elemento a medida que el tamaño de la pantalla aumenta:
:root {
  --separacion: 4px;
}

section {
  margin: var(--separacion);
}

@media (min-width: 600px) {
  :root {
    --separacion: 16px;
  }
}
Este ejemplo de nuevo es imposible de hacer con los preprocesadores ya que no se pueden definir variables dentro de los media queries.


Por otra parte, el valor de una variable se puede definir a partir de otras variables, lo que es muy útil para definir el tema de un sitio:
:root {
  --color-principal: red;
  --texto-logotipo: var(--color-principal);
}
La función var()
La función var() obtiene el valor de la propiedad indicada. Su sintaxis completa es la siguiente:

var(<nombre-propiedad> [, <valor-por-defecto> ]? )
El primer argumento (<nombre-propiedad>) es el nombre completo de la propiedad cuyo valor se quiere obtener. El segundo argumento (<valor-por-defecto>) es opcional y es el valor utilizado cuando la propiedad no existe.

El valor por defecto puede ser en realidad una lista de varios valores separados por comas. Por ejemplo, si utilizas var(--font-stack, "Roboto", "Helvetica"); y la propiedad --font-stack no existe, el valor devuelto será "Roboto", "Helvetica" todo junto.

Cuidado con los atajos en las propiedades CSS como margin y padding. En este caso, como sus valores no están separados por comas, el valor por defecto tampoco debe contener comas. Ejemplo:
p {
  padding: var(--separacion, 10px 15px 20px);
}
Los valores por defecto son muy útiles al diseñar componentes ya que permiten realizar un "diseño defensivo" que está preparado frente a los errores ajenos. Ejemplo:
/* Estilos definidos por el componente: */
.component .header {
  color: var(--color-cabecera, blue);
}
.component .text {
  color: var(--color-texto, black);
}

/* estilos de la aplicación: */
.component {
  --color-texto: #080;
  /* la variable --color-cabecera no está definida en la aplicación,
     así que se usará el valor por defecto definido en el componente */
}
Esta técnica también es útil para aplicar temas a los componentes que usan "Shadow DOM". El diseñador del componente crea un estilo inicial con los valores por defecto y después permite su personalización mediante algunas variables CSS:
<!-- definición del componente web: -->
<x-foo>
  #shadow
    <style>
      p {
        background-color: var(--color-fondo-texto, blue);
      }
    </style>

    <p>
      Este texto tiene un color de fondo amarillo porque la aplicación
      así lo ha definido. Si no, el fondo sería de color azul.
    </p>
</x-foo>
/* en los estilos de la aplicación: */
x-foo {
  --color-fondo-texto: yellow;
}
La función var() también tiene algunas limitaciones. En primer lugar, las variables no se pueden usar como nombre de la propiedad CSS. Por eso el siguiente ejemplo no es equivalente al estilo margin-top: 20px; y el navegador mostraría un mensaje de error:
.foo {
  --lado: margin-top;
  var(--lado): 20px;
}
Igualmente, no puedes usar el valor de una variable como parte del valor de una propiedad. Por eso el siguiente ejemplo tampoco es equivalente a margin-top: 20px y el navegador mostraría un mensaje de error:
.foo {
  --separacion: 20;
  margin-top: var(--separacion)px;
}
En este último caso, la solución sería utilizar otra función llamada calc(), tal y como se explica en la siguiente sección.

Generando valores con la función calc()

La función calc()es muy útil para realizar cálculos al definir los valores de las propiedades CSS. Todos los navegadores modernos la soportan sin problemas y se puede combinar con las variables CSS. Ejemplo:
.foo {
  --separacion: 20;
  margin-top: calc(var(--separacion) * 1px);
}

Usando variables CSS con jаvascript

El valor de las variables CSS se puede obtener en jаvascript mediante el método getPropertyValue() del objeto CSSStyleDeclaration. Ejemplo:
<style type="text/css">
:root {
  --color-principal: red;
}

p {
  color: var(--color-principal);
}
</style>
<p>Este párrafo es de color rojo.</p>
<script type="text/jаvascript">
var estilosCss = getComputedStyle(document.documentElement);
var valor = String(estilosCss.getPropertyValue('--color-principal')).trim();
// valor = 'red'
</script>
Igualmente, para cambiar el valor de una variable CSS en el propio navegador, utiliza el método setProperty() del objeto CSSStyleDeclaration.
<style type="text/css">
:root {
  --color-principal: red;
}

p {
  color: var(--color-principal);
}
</style>
<p>Este párrafo es de color verde.</p>
<script type="text/jаvascript">
document.documentElement.style.setProperty('--color-principal', 'green');
</script>
Añade la función var() en la llamada al método setProperty() para usar el valor de una variable CSS como valor de otra variable CSS:
<style type="text/css">
:root {
  --color-principal: red;
  --color-secundario: blue;
}
</style>
<p>Y ahora este párrafo es de color azul.</p>
<script type="text/jаvascript">
document.documentElement.style.setProperty(
  '--color-principal', 'var(--color-secundario)'
);
</script>
Como además las variables CSS pueden hacer referencia a otras variables CSS de otras hojas de estilos, esta manipulación en tiempo real mediante jаvascript permite realizar comportamientos dinámicos muy avanzados.
Síguenos en
Google News Flipboard
  • 100
  • 1
  • 2
  • 3
  • 4
  • 5
El mito del contenido es el rey
Cambiando el diseño de las barras de scroll con CSS
Tutoriales En Linea
Tutoriales En Linea
  • Website
  • Facebook
  • Twitter
  • LinkedIn
  • Pinterest
  • Instagram

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

Artículos Relacionados


Ecuaciones 2º grado, bicuadradas, sistemas lineales, sistemas no lineales y problemas de la 4º ESO

Ecuaciones 2º grado, bicuadradas, sistemas lineales, sistemas no lineales y problemas de la 4º ESO

Cita motivacional - El Camino

Cita motivacional - El Camino

Protocol Open Graph para Facebook

Protocol Open Graph para Facebook


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 572

Como instalar SS IPTV en una Smart Tv Samsung

Ene 22 10 372

Como podemos conseguir proxies

Jun 21 11 598

Historia de los sistemas operativos

Mayo 16 31 049

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

Web




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.