当前位置:首页 > JavaScript

js实现spinner

2026-03-14 08:47:28JavaScript

使用纯CSS实现Spinner

通过CSS的@keyframesanimation属性可以轻松创建一个旋转的spinner效果。以下是一个简单的实现示例:

<style>
  .spinner {
    width: 40px;
    height: 40px;
    border: 4px solid rgba(0, 0, 0, 0.1);
    border-radius: 50%;
    border-top-color: #09f;
    animation: spin 1s linear infinite;
  }

  @keyframes spin {
    to {
      transform: rotate(360deg);
    }
  }
</style>

<div class="spinner"></div>

使用SVG实现Spinner

SVG提供了更精细的控制,适合需要复杂动画的场景:

js实现spinner

<svg class="spinner" viewBox="0 0 50 50">
  <circle cx="25" cy="25" r="20" fill="none" stroke="#09f" stroke-width="4"></circle>
</svg>

<style>
  .spinner {
    animation: rotate 2s linear infinite;
    width: 40px;
    height: 40px;
  }

  @keyframes rotate {
    100% {
      transform: rotate(360deg);
    }
  }
</style>

使用JavaScript控制Spinner

如果需要动态控制spinner的显示/隐藏,可以结合JavaScript:

function showSpinner() {
  document.getElementById('spinner').style.display = 'block';
}

function hideSpinner() {
  document.getElementById('spinner').style.display = 'none';
}

使用第三方库

对于更复杂的需求,可以考虑使用第三方库如Spin.js:

js实现spinner

var opts = {
  lines: 12, // 线条数量
  length: 7, // 每条线长度
  width: 5, // 线宽
  radius: 10, // 内圆半径
  color: '#000', // 颜色
  speed: 1, // 旋转速度
  trail: 60, // 拖尾百分比
  shadow: false // 是否显示阴影
};

var target = document.getElementById('spinner-container');
var spinner = new Spinner(opts).spin(target);

响应式Spinner实现

确保spinner在不同设备上都能正常显示:

.spinner {
  width: 5vw;
  height: 5vw;
  min-width: 40px;
  min-height: 40px;
  /* 其余样式保持不变 */
}

可访问性考虑

为spinner添加ARIA属性,提升无障碍体验:

<div class="spinner" role="status" aria-label="Loading..."></div>

标签: jsspinner
分享给朋友:

相关文章

js 进度条的实现

js 进度条的实现

使用 HTML 和 CSS 创建基础进度条 HTML 结构可以简单使用一个 div 元素作为容器,内部嵌套另一个 div 表示进度: <div class="progress-containe…

js实现乘

js实现乘

JavaScript 实现乘法运算 在 JavaScript 中实现乘法运算可以通过多种方式完成,包括基本运算符、函数封装以及高级算法(如大数乘法)。以下是几种常见方法: 使用基本乘法运算符 Jav…

jquery.js

jquery.js

jQuery 是一个快速、简洁的 JavaScript 库,简化了 HTML 文档遍历、事件处理、动画设计和 Ajax 交互等操作。以下是关于 jQuery.js 的核心信息和使用方法: 获取 jQ…

js实现投球

js实现投球

实现投球动画的基本思路 使用JavaScript和CSS动画结合的方式模拟投球效果。核心是通过改变元素的位置、旋转和缩放属性,配合定时器或CSS过渡实现平滑动画。 创建基础HTML结构 <…

js实现视口

js实现视口

js实现视口检测的方法 使用JavaScript检测元素是否进入视口(viewport)可以通过Intersection Observer API或手动计算元素位置实现。以下是两种常见方法: Int…

js实现下拉菜单

js实现下拉菜单

使用HTML和CSS创建基础结构 HTML部分需要包含一个触发下拉的按钮和隐藏的下拉菜单内容: <div class="dropdown"> <button class="dr…