手记

5个必备的 HTML 和 CSS 技巧,来代替 JavaScript

让我们谈谈什么时候不应该使用JavaScript,以及为什么HTML和CSS在很多情况下是更好的工具。这听起来可能有点违反直觉——特别是来自一个JavaScript开发者——但到最后你会明白的,放心!

我并不厌恶JavaScript。我每天都在用它编写代码为富文本文档编辑器。但随着时间的推移,我发现通过使用HTML和CSS来处理许多工作,这不仅使我的代码更简单,更易维护,而且通常也更高效。这种方法基于一个核心的网络开发原则,即最小力量规则

最小权限原则

最小权限原则很简单:使用适合任务的最弱语言。在网页开发中,这意味着在可能的情况下优先使用HTML而不是CSS,优先使用CSS而不是JavaScript。这种做法的逻辑是:

  • HTML 是声明性的,轻量级的,非常适合用来结构化内容。
  • CSS 同样是声明式的,用于样式定义,提供了许多不需要 JavaScript 的布局和交互选项。
  • JavaScript ,虽然功能强大,但也带来了复杂性、性能损耗和潜在的错误。

让我们通过一些真实的例子来深入了解,在这些例子中,你可能会使用JavaScript,但仅使用HTML和CSS可以获得更好的效果。这些例子展示了你可以如何用更少的代码保持功能和性能。比如,你可以在这个GitHub仓库中找到这些例子。

例子 1: 自定义选项(不使用 JS 的复选框)

我们都建過自定義開關。這通常需要用到大量的JavaScript來處理點擊和切換狀態。但這裏要告訴你如何只用HTML和CSS就能做出功能完善、可訪問的開關。

GitHub 仓库

HTML

<label class="switch">
  <input type="checkbox" class="switch-input">
  <span class="switch-slider"></span>
</label>
这是用于创建开关的HTML代码,其中包含一个复选框和滑块。

切换到视频全屏模式,退出视频全屏模式。

CSS 样式表

    /* 开关的外部容器 */ /* The outer container for the switch */
    .switch { 
      position: relative;
      display: inline-block;
      width: 60px;
      height: 34px;
    }

    /* 隐藏的复选框 */
    .switch-input {
      opacity: 0;
      width: 0;
      height: 0;
    }

    /* 开关的可见滑块 */
    .switch-slider {
      position: absolute;
      cursor: pointer;
      top: 0;
      left: 0;
      right: 0;
      bottom: 0;
      background-color: #ccc;
      transition: .4s;
    }

    /* 开关内的圆形滑块 */
    .switch-slider:before {
      position: absolute;
      content: "";
      height: 26px;
      width: 26px;
      left: 4px;
      bottom: 4px;
      background-color: white;
      transition: .4s;
    }

    /* 当复选框被选中时,背景色变为#2196F3 */
    .switch-input:checked + .switch-slider {
      background-color: #2196F3;
    }

    /* 当开关选中时,滑块向右移动26px */
    .switch-input:checked + .switch-slider:before {
      transform: translateX(26px);
    }

点击全屏模式/退出全屏

这个设置创建了一个无需JavaScript即可工作的切换开关,利用:checked伪类来调整样式。该伪类用于选择处于“选中”状态的元素(如复选框),当复选框被选中时,触发切换的样式变化,例如改变背景颜色和移动滑块。

为什么这更棒:

  • 无需 JavaScript: 组件更少,出错几率也更低。
  • 开箱即用: 自动支持键盘和鼠标,维护更简单。
示例2:使用 <datalist> 实现自动补全功能

自动完成功能一般通过库或自定义JavaScript来实现。然而,利用HTML的<datalist>元素,您可以轻松地创建自动建议输入,而无需太多努力。

Github 仓库

HTML 标签

    <input type="text" list="suggestions" placeholder="请选择一个选项...">
    <datalist id="suggestions">
      <option value="Open AI">
      <option value="Open Source">
      <option value="Open Source Software">
    </datalist>

请全屏 请退出全屏

CSS样式

    .container {
      width: 300px; 
      display: block; 
    }

    input {
      padding: 10px;
      font-size: 18px;
      width: 100%;
      box-sizing: border-box;
    }

全屏模式(点击进入/退出)

在这里,<datalist> 在用户开始输入时提供了一些建议的列表。无需使用基于 JavaScript 的自动完成功能。

为什么这更棒:

  • 轻量级: 它内置于浏览器,因此更快速高效。
  • 简单: 无需额外的JS、依赖项或复杂逻辑。
例子3:用CSS实现流畅滚动

在很多网站上,页面的平滑滚动是通过jQuery或自定义JavaScript函数实现的。然而,现在可以通过一行CSS来实现这个效果或者功能。

GitHub仓库

HTML 标签

    <nav>
      <a href="#section1">跳转到第一节</a>
      <a href="#section2">跳转到第二节</a>
      <a href="#section3">跳转到第三节</a>
    </nav>

    <!-- 节1 -->
    <section id="section1">
      <h2>第一节</h2>
    </section>

    <!-- 节2 -->
    <section id="section2">
      <h2>第二节</h2>
    </section>

    <!-- 节3 -->
    <section id="section3">
      <h2>第三节</h2>
    </section>

进入全屏,退出全屏

CSS

    /* 用于分段的基本样式 */
    section {
        height: 100vh;
        padding: 20px;
        font-size: 24px;
        display: flex;
        justify-content: center;
        align-items: center;
    }

    /* 每个分段的不同背景色 */
    #section1 {
        background-color: 浅珊瑚色;
    }

    #section2 {
        background-color: 浅海绿色;
    }

    #section3 {
        background-color: 浅蓝色;
    }

    /* 导航栏的样式 */
    nav {
        position: 固定;
        top: 10px;
        left: 10px;
    }

    nav a {
        display: block;
        margin-bottom: 10px;
        text-decoration: none;
        color: white;
        padding: 10px 20px;
        background-color: #333;
        border-radius: 5px;
    }

    nav a:hover {
        background-color: #555;
    }

全屏模式(点击进入/退出)

当用户点击某个部分的锚点链接时,页面会顺畅地滚动到该部分。

为什么,这更好呢:

  • 更少的代码: 用一行 CSS 代码实现平滑滚动,而不是使用复杂的 JavaScript,减少代码的复杂度。
  • 更好的性能: 原生 CSS滚动比基于 JavaScript 的解决方案更快、更高效。
  • 浏览器一致性: CSS 确保平滑滚动在各种浏览器和设备上都能一致地工作。
示例 4:使用 <details><summary> 的手风琴布局

手风琴菜单通常用JavaScript来切换内容的显示。不过,HTML还提供了<details><summary>元素,无需额外代码即可实现这种特性。

Github 仓库页面

HTML

    <details>
      <summary>点击展开</summary>
      <p>这里有一些内容。</p>
    </details>

切换到全屏 退出全屏

CSS样式表

    details {
      width: 300px;
      background-color: #f9f9f9;
      padding: 20px;
      border: 1px solid #ddd;
      font-size: 18px;
    }

    summary {
      cursor: pointer;
      font-size: 20px;
      font-weight: bold;
    }

    details[open] summary {
      color: #2196F3;
    }

切换到全屏模式;切换出全屏模式

这种简单的标记语言使我们拥有一个可交互且可访问的 accordion,并且无需使用任何 JavaScript。它可以展开和折叠。

为什么这样做更好呢:

  • 原生: 这个功能是浏览器的功能,所以既快又可靠。
  • 可访问性: 浏览器帮助您管理焦点和交互方式。

例子 5:用 CSS 控制的滚动动画

根据滚动位置来动画元素通常使用JavaScript库来完成。但是,通过使用scroll-margin属性和scroll-behavior CSS,你可以创建更流畅且更具可访问性的动画。

Github 页面

HTML标签

    <body>
         <!-- 带有锚点链接的导航 -->
         <nav >
            <a href="#section1">第一节</a>
            <a href="#section2">第二节</a>
            <a href="#section3">第三节</a>
            <a href="#section4">第四节</a>
        </nav>

        <!-- 第一节 -->
        <section id="section1">
            <h2>欢迎来到第一节</h2>
        </section>

        <!-- 第二节 -->
        <section id="section2">
            <h2>欢迎来到第二节</h2>
        </section>

        <!-- 第三节 -->
        <section id="section3">
            <h2>欢迎来到第三节</h2>
        </section>

        <!-- 第四节 -->
        <section id="section4">
            <h2>欢迎来到第四节</h2>
        </section>
    </body>

进入全屏,退出全屏

CSS

    html {
        scroll-behavior: smooth;
    }

    /* 删除 body 的边距 */
    body {
        margin: 0;
    }

    /* 带有居中内容的section占据整个视口高度 */
    section {
        display: flex;
        justify-content: center;
        align-items: center;
        height: 100vh;
        background-color: #f0f0f0;
        transition: background-color 0.6s ease-in-out;
    }

    /* 标题样式 */
    section h2 {
        font-size: 36px;
        margin: 0;
        transition: transform 0.6s ease, opacity 0.6s ease;
        opacity: 0;
        transform: translateY(30px);
    }

    /* 添加边距以支持滚动捕捉 */
    section:nth-child(odd) {
        background-color: #ffcccb;
    }

    section:nth-child(even) {
        background-color: #d0e7ff;
    }

    /* 滚动时触发的动画效果 */
    section:target h2 {
        opacity: 1;
        transform: translateY(0);
    }

全屏 退出全屏

为什么这更好些

  • 不需要 JavaScript: 您可以仅用 CSS 就搞定平滑的滚动触发动画。
  • 性能: 动画因此实现更平滑、更高效的过渡效果,而无需 JavaScript 的复杂性。
  • 更易于维护: 使用 CSS 减少了复杂的 JavaScript 滚动跟踪代码,让代码更新和维护更简单。

你可以通过利用浏览器自带的功能和巧妙的 CSS 技术完全避开 JavaScript 的复杂性。

随着我们在编码和聊天导向编程中看到AI助手的崛起,采用和实施简单的HTML和CSS解决方案变得更为关键。AI工具可以快速生成JavaScript代码。但是,确保核心功能的实现,利用HTML和CSS使代码既可维护又易于理解和使用,无论是人还是AI。通过使用最简解决方案来完成工作,你不仅让代码更容易访问,也使得AI能够以更高效和优化的方式帮助。

HTML和CSS提供了构建交互式、可访问性和响应性的网页组件的强大工具——无需使用复杂的JavaScript。所以下次当你考虑使用JavaScript时,不妨考虑一下,是否可以通过HTML和CSS实现一个更简单甚至更好的方案。

查看本文所有示例的 Github 仓库。同时,访问 TinyMCE 博客 获取更多信息,了解最佳实践和教程,或者现在就通过注册 14天免费试用 开始您的 TinyMCE 之旅。

编程愉快!

0人推荐
随时随地看视频
慕课网APP