我的常用js代码库

我常用的js代码库

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

此腳本不應該直接安裝,它是一個供其他腳本使用的函式庫。欲使用本函式庫,請在腳本 metadata 寫上: // @require https://update.gf.qytechs.cn/scripts/479598/1279035/%E6%88%91%E7%9A%84%E5%B8%B8%E7%94%A8js%E4%BB%A3%E7%A0%81%E5%BA%93.js

// ==UserScript==
// @name         我的常用js代码库
// @namespace    http://tampermonkey.net/
// @version      0.3
// @description  我常用的js代码库
// @author       zyb
// @match        http://*/*
// @icon         
// @grant        none
// ==/UserScript==

(function() {
    'use strict';

    // Your code here...

    class MyJSCodeLibrary {
        constructor() {

        }
        /**
         * 创建css样式
         * @param {string} styleStr css样式
         */
        createStyleFuc(styleStr = "") {
            // 创建style节点
            const style = document.createElement("style");
            style.setAttribute("type", "text/css");
            style.appendChild(document.createTextNode(styleStr));
            document.head.appendChild(style);
        }

        /**
         * 异步获取dom节点
         * @param {string} selector dom节点的选择器文本
         * @param {number} time 间隔时间
         * @returns
         */
        getDomByIntervalAsyncFuc(selector, time = 100) {
            let dom = document.querySelectorAll(selector)[0];
            let timeId = null;
            let times = 0;
            return new Promise((res) => {
                timeId = setInterval(() => {
                    times++;
                    if (dom || times > 10) {
                        res(dom);
                        clearInterval(timeId);
                    } else {
                        dom = document.querySelectorAll(selector)[0];
                    }
                }, time)
            })
        }

        /**
         * 异步获取dom节点
         * @param {string} selector dom节点的选择器文本
         * @param {number} time 间隔时间
         * @returns
         */
        getDomByTimeoutAsyncFuc(selector = "", time = 2000) {
            return new Promise((res) => {
                setTimeout(() => {
                    let dom = document.querySelectorAll(selector)[0];
                    res(dom);
                }, time)
            })
        }
    }

    let myJSCodeLibrary = new MyJSCodeLibrary();
})();

QingJ © 2025

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