Mercurial > ec-userscripts
view soranews-image.user.js @ 124:6d280338e113
Apparently both are required? or recommended
author | nanaya <me@nanaya.net> |
---|---|
date | Sat, 21 Jan 2023 02:08:29 +0900 |
parents | 8de2d53a4cb1 |
children |
line wrap: on
line source
// ==UserScript== // @name Soranews image fix // @namespace https://nanaya.net // @version 1.0.3 // @description Soranews lazy load image fix // @author nanaya // @match https://soranews24.com/* // @grant none // @downloadURL https://hg.nanaya.net/ec-userscripts/raw-file/tip/soranews-image.user.js // ==/UserScript== 'use strict'; const fix = function (image) { // basic sanity check if (!image.classList.contains('lazy')) { return; } image.classList.remove('lazy'); image.removeAttribute('src'); image.setAttribute('srcset', image.dataset.scoSrcset); }; // loop through passed nodes (or body if called without arguments) const run = function (nodes) { if (nodes == null) { nodes = [document.body]; } for (let i = 0; i < nodes.length; i++) { // find all the images inside (and self) const images = [nodes[i], ...nodes[i].querySelectorAll('.lazy')]; for (let j = 0; j < images.length; j++) { fix(images[j]); } } }; const onMutate = function (mutations) { for (const mutation in mutations) { run(mutation.addedNodes); } }; // the observer const observer = new window.MutationObserver(onMutate); // start the observer observer.observe(document, { childList: true, subtree: true }); // initial run on existing document run();