Implementación del Modo Oscuro en Sitios Web

Home PDF Audio

Implementación del Modo Oscuro en mi blog de Jekyll.

Alternar

<script>
  const rootElement = document.documentElement;
  const themeToggleBtn = document.getElementById('themeToggle');
  const sunIcon = document.getElementById('sunIcon');
  const moonIcon = document.getElementById('moonIcon');
  const avatarImg = document.getElementById('avatarImg'); // referencia a la etiqueta <img>

const savedTheme = localStorage.getItem(‘theme’); if (savedTheme === ‘dark’) { rootElement.classList.add(‘dark-mode’); }

function updateIconsAndAvatar() {
    const isDark = rootElement.classList.contains('dark-mode');
    sunIcon.style.display = isDark ? 'inline-block' : 'none';
    moonIcon.style.display = isDark ? 'none' : 'inline-block';
    avatarImg.src = isDark
      ? '/assets/images/avatar_dark.png'
      : '/assets/images/avatar.jpg';
}

actualizarIconosYAvatar();

themeToggleBtn.addEventListener('click', function () {
    rootElement.classList.toggle('dark-mode');
    if (rootElement.classList.contains('dark-mode')) {
      localStorage.setItem('theme', 'dark');
    } else {
      localStorage.setItem('theme', 'light');
    }
    updateIconsAndAvatar();
  });
</script>

CSS

.dark-mode {
  // Sobrescribe el color de fondo principal
  body {
    background-color: $dark-main-bg-color;
    color: white;
  }
.main-content {
    background-color: $dark-main-bg-color;
}
    h6,
    blockquote {
      color: $dark-section-headings-color;
    }
    a {
      color: white !important;
    }
  }
.page-header {
    // Si necesitas un fondo más oscuro
    background-image: linear-gradient(120deg, $dark-main-bg-color, #222);
    background-color: #2f2f2f !important;
    // O elige un color oscuro diferente, por ejemplo, #1f1f1f, #3a3a3a, etc.
}

// Color de fondo del bloque pre/code (antes era #e0d9cf) pre { background-color: #3a3a3a !important; // o #2f2f2f, etc. }

// Sobrescribir el color de la fecha (era gris oscuro) .date { color: #aaa !important; // o #ccc, #bbb, etc. }

.main-content h1,
.main-content h2,
.main-content h3,
.main-content h4,
.main-content h5,
.main-content h6 {
  color: $dark-section-link-color;
}
// etc. - sobrescribir según sea necesario
}

Sintaxis de Markdown

@import "syntax";
@import "syntax-dark";
.dark-mode {
  .highlight {
    table {
      td {
        padding: 5px;
      }
pre {
  margin: 0;
}
    color: $color_1;
    background-color: $background-color_1;
.w {
  color: $color_1;
  background-color: $background-color_1;
}
}
}

Imagen en Markdown

.magnet-image {
  width: 300px;
  /* Ancho completo en pantallas pequeñas */
  min-height: 300px;
  /* Ajustar según sea necesario */
  background-image: url('/assets/images/magnet/magnet.jpg');
  background-size: cover;
}
.dark-mode .magnet-image {
  background-image: url('/assets/images/magnet/magnet_dark.jpg');
}
<picture>
  <source srcset="/assets/images/magnet/magnet_dark.jpg" media="(prefers-color-scheme: dark)">
  <img src="/assets/images/magnet/magnet.jpg" alt="Imagen de Magnet">
</picture>

Back 2025.01.18 Donate