Resize Images

Resize images over 600px

目前為 2023-07-07 提交的版本,檢視 最新版本

您需要先安裝使用者腳本管理器擴展,如 TampermonkeyGreasemonkeyViolentmonkey 之後才能安裝該腳本。

您需要先安裝使用者腳本管理器擴充功能,如 TampermonkeyViolentmonkey 後才能安裝該腳本。

您需要先安裝使用者腳本管理器擴充功能,如 TampermonkeyViolentmonkey 後才能安裝該腳本。

您需要先安裝使用者腳本管理器擴充功能,如 TampermonkeyUserscripts 後才能安裝該腳本。

你需要先安裝一款使用者腳本管理器擴展,比如 Tampermonkey,才能安裝此腳本

您需要先安裝使用者腳本管理器擴充功能後才能安裝該腳本。

(我已經安裝了使用者腳本管理器,讓我安裝!)

你需要先安裝一款使用者樣式管理器擴展,比如 Stylus,才能安裝此樣式

你需要先安裝一款使用者樣式管理器擴展,比如 Stylus,才能安裝此樣式

你需要先安裝一款使用者樣式管理器擴展,比如 Stylus,才能安裝此樣式

你需要先安裝一款使用者樣式管理器擴展後才能安裝此樣式

你需要先安裝一款使用者樣式管理器擴展後才能安裝此樣式

你需要先安裝一款使用者樣式管理器擴展後才能安裝此樣式

(我已經安裝了使用者樣式管理器,讓我安裝!)

// ==UserScript==
// @name         Resize Images
// @namespace    http://tampermonkey.net/
// @version      0.2
// @description  Resize images over 600px
// @author       udontkn0wme
// @match        *://*/*
// @icon         https://opu.peklo.biz/p/23/07/05/1688548365-c5a3a.jpg
// @license      MIT
// @grant        none

// ==/UserScript==

(function () {
  'use strict';

  // Function to resize elements
  function resizeElements(elements) {
    elements.forEach(element => {
      // Check if the element height is greater than 600px
      if (element.clientHeight > 600) {
        // Set the height to 600px and width to 'auto'
        element.style.height = '600px';
        element.style.width = 'auto';
      }
    });
  }

  // Function to observe DOM changes and resize elements accordingly
  function observeDOMChanges() {
    const targetNode = document.body;

    // Callback function to handle DOM changes
    const callback = function(mutationsList) {
      for (const mutation of mutationsList) {
        if (mutation.type === 'childList') {
          // Resize the elements whenever new elements are added to the DOM
          const elements = document.querySelectorAll('img.embed-me-image, img');
          resizeElements(elements);
        }
      }
    };

    // Create a new MutationObserver instance
    const observer = new MutationObserver(callback);

    // Start observing the target node for DOM changes
    observer.observe(targetNode, { childList: true, subtree: true });
  }

  // Resize the initial elements
  const elements = document.querySelectorAll('img.embed-me-image, img');
  resizeElements(elements);

  // Observe DOM changes to resize newly added elements
  observeDOMChanges();
})();