Swinging Words

Random words swing like they're hanging from the page

// ==UserScript==
// @name         Swinging Words
// @namespace    http://swing.words/
// @version      1.0
// @description  Random words swing like they're hanging from the page
// @match        *://*/*
// @grant        none
// @run-at       document-idle
// @license MIT
// ==/UserScript==

(function () {
  'use strict';

  const CHANCE = 0.1; // 10% of words swing

  const style = document.createElement("style");
  style.textContent = `
    @keyframes swing {
      0%   { transform: rotate(0deg); }
      25%  { transform: rotate(105deg); }
      50%  { transform: rotate(0deg); }
      75%  { transform: rotate(75deg); }
      100% { transform: rotate(0deg); }
    }

    .swinging-word {
      display: inline-block;
      transform-origin: bottom left;
      animation: swing 2s ease-in-out infinite;
      margin: 2px;
    }
  `;
  document.head.appendChild(style);

  const paragraphs = document.querySelectorAll("p");
  paragraphs.forEach(p => {
    const text = p.textContent;
    const words = text.split(/(\s+)/); // preserve spaces
    const frag = document.createDocumentFragment();

    words.forEach(word => {
      if (/\S/.test(word) && Math.random() < CHANCE) {
        const span = document.createElement("span");
        span.className = "swinging-word";
        span.textContent = word;
        frag.appendChild(span);
      } else {
        frag.appendChild(document.createTextNode(word));
      }
    });

    p.textContent = ""; // Clear original
    p.appendChild(frag);
  });

  console.log("🎯 Swinging words activated.");
})();

QingJ © 2025

镜像随时可能失效,请加Q群300939539或关注我们的公众号极客氢云获取最新地址