MSCSTSTS-TOOLS

自用工具库,命名空间mscststs

이 스크립트는 직접 설치하는 용도가 아닙니다. 다른 스크립트에서 메타 지시문 // @require https://update.greasyfork.org/scripts/38220/1026406/MSCSTSTS-TOOLS.js을(를) 사용하여 포함하는 라이브러리입니다.

이 스크립트를 설치하려면 Tampermonkey, Greasemonkey 또는 Violentmonkey와 같은 확장 프로그램이 필요합니다.

You will need to install an extension such as Tampermonkey to install this script.

이 스크립트를 설치하려면 Tampermonkey 또는 Violentmonkey와 같은 확장 프로그램이 필요합니다.

이 스크립트를 설치하려면 Tampermonkey 또는 Userscripts와 같은 확장 프로그램이 필요합니다.

이 스크립트를 설치하려면 Tampermonkey와 같은 확장 프로그램이 필요합니다.

이 스크립트를 설치하려면 유저 스크립트 관리자 확장 프로그램이 필요합니다.

(이미 유저 스크립트 관리자가 설치되어 있습니다. 설치를 진행합니다!)

이 스타일을 설치하려면 Stylus와 같은 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 Stylus와 같은 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 Stylus와 같은 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 유저 스타일 관리자 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 유저 스타일 관리자 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 유저 스타일 관리자 확장 프로그램이 필요합니다.

(이미 유저 스타일 관리자가 설치되어 있습니다. 설치를 진행합니다!)

var mscststs = new class {
  sleep(miliseconds) {
    return new Promise(resolve => {
      setTimeout(() => { resolve(); }, miliseconds);
    });
  }
  async _Step(selector, callback, need_content, timeout) {
    while (timeout--) {
      if (document.querySelector(selector) === null) {
        await this.sleep(100);
        continue;
      } else {
        if (need_content) {
          if (document.querySelector(selector).innerText.length == 0) {
            await this.sleep(100);
            continue;
          }
        }
      }
      break;
    }

    callback(selector);
  }
  wait(selector, need_content = false, timeout = Infinity) {
    return new Promise(resolve => {
      this._Step(selector, function (selector) { resolve(document.querySelector(selector)); }, need_content, timeout);
    });
  }

  hijackXMLHttpRequest(options, selfWindow = self) {
    const rawXHR = selfWindow.XMLHttpRequest;
    selfWindow.XMLHttpRequest = function (...args) {
      const xhrInstance = new rawXHR(...args);
      // 下面将 xhrInstance 添加
      const xhrProxy = new Proxy(xhrInstance, {
        get: function (target, property) {
          if (typeof target[property] === "function") {
            return function (...args) {
              const before = options['before' + property] || ((...args) => { return args });
              const after = options['after' + property] || (_=>_);
              return after(target[property](...before(...args)));
              //return target[property](...args)
            }

          } else {
            return target[property]
          }
        }
      });
      return xhrProxy;
    }
    return function abort() {
      selfWindow.XMLHttpRequest = rawXHR;
    }
  }
}();