BlogFocusPro - 旨在优化博客网站布局 (长期更新)

此用户脚本部分基于Blog-UI, 旨在提供一个更清爽的浏览体验,专门针对 blog.csdn, cloud.tencent.com/developer/*, 等技术博客页面。它通过移除页面上的非核心内容(如广告、推荐栏目、订阅通知等),同时保留必要元素(如超链接小标题等), 使用户能专注于阅读技术文章,无干扰。该脚本适用于希望提高阅读效率的开发者和技术爱好者。特此感谢: https://greasyfork.org/zh-CN/scripts/451555

// ==UserScript==
// @name         BlogFocusPro - 旨在优化博客网站布局 (长期更新)
// @namespace    http://tampermonkey.net/
// @version      2024.06.25.01
// @description  此用户脚本部分基于Blog-UI, 旨在提供一个更清爽的浏览体验,专门针对 blog.csdn, cloud.tencent.com/developer/*,  等技术博客页面。它通过移除页面上的非核心内容(如广告、推荐栏目、订阅通知等),同时保留必要元素(如超链接小标题等), 使用户能专注于阅读技术文章,无干扰。该脚本适用于希望提高阅读效率的开发者和技术爱好者。特此感谢: https://greasyfork.org/zh-CN/scripts/451555
// @author       崔真志
// @match        https://blog.csdn.net/*
// @icon         https://www.google.com/s2/favicons?sz=64&domain=csdn.net
// @resource css https://cdn.jsdelivr.net/gh/cuizhenzhi/BlogFocusPro/index.css
// @grant        unsafeWindow
// @grant        GM_addStyle
// @grant        GM_getResourceText
// @grant        GM_setValue
// @grant        GM_getValue
// @grant        GM_deleteValue
// @grant        GM_listValues
// @license      MIT License
// @license MIT
// ==/UserScript==

(function () {
  'use strict';

// @match        https://developer.aliyun.com/*
// @match        https://jingyan.baidu.com/*
// @match        https://zhidao.baidu.com/*
  const TITLE = 'Better-Blog';
  const VERSION = '1.0';
  let mainFixed = false;

  /**
   * @desc 对特定网站的元素执行配置操作。
   * 此函数依据给定的配置数组(每个配置对象针对特定网站),在当前网站的DOM中查找和操作元素。
   * 根据配置,可以在操作前后执行全局或局部的前置/后置操作。
   *
   * @param {Object[]} configs - 网站操作的配置数组,每个对象包含:
   *   @param {string} site - 网站的URL部分,用于确定是否执行该配置。
   *   @param {Function} [globalBeforeAction] - 在执行任何操作之前可选地执行的全局前置操作。
   *   @param {Function} [globalAfterAction] - 在所有操作执行后可选地执行的全局后置操作。
   *   @param {Object[]} operations - 针对特定元素的操作数组,每个操作对象包含:
   *     @param {string} [fromSelector='body'] - 用于定位起始元素的选择器,默认为<body>。
   *     @param {number} [num=null] - 指定要操作的元素数量,如果为null,则操作所有符合条件的元素。
   *     @param {Object} selector - 用于进一步从 `from` 元素中筛选元素的选择器对象。
   *     @param {Function} [filter=null] - 过滤函数,用于进一步筛选元素。
   *     @param {Function} action - 对每个符合条件的元素执行的操作。
   *     @param {Function} [beforeAction=null] - 在操作特定元素之前可选地执行的前置操作。
   *     @param {Function} [afterAction=null] - 在操作特定元素之后可选地执行的后置操作。
   */
  function processSiteElements(configs) {
    configs.forEach(config => {
      const {
        site,
        operations,
        globalBeforeAction = null,
        globalAfterAction = null
      } = config;

      if (!window.location.href.includes(site)) {
        return;
      }
      // 全局前置操作
      executeAction(globalBeforeAction);

      operations.forEach(operation => {
        const {
          fromSelector = 'body',
          num = null,
          selector = {},
          filter = null,
          action = (element) => element.parentNode.removeChild(element),
          beforeAction = null,
          afterAction = null
        } = operation;

        // 从特定站点执行操作
        //if (window.location.href.includes(site))
        //{
        // 前置操作
        executeAction(beforeAction);


        const from = document.querySelector(fromSelector);
        if (!from) {
          console.error('Specified `from` element does not exist.');
          return;
        }

        let elements = Array.from(from.querySelectorAll(buildQuery(selector)));
        if (filter) {
          elements = elements.filter(filter);
        }

        elements.slice(0, num).forEach(action);

        // 后置操作
        executeAction(afterAction);

        //}
      });

      // 全局后置操作
      executeAction(globalAfterAction);

    });
  }

  function maximizeAndPrune(element) {
    let currentNode = element;
    while (currentNode !== document.body) {
      currentNode.style.width = '100%';
      let parent = currentNode.parentNode;
      Array.from(parent.childNodes).forEach(child => {
        if (child !== currentNode && !['STYLE', 'LINK'].includes(child.tagName)) {
          parent.removeChild(child);
        }
      });
      currentNode = parent;
    }
  }


  function addDirectoryToMainBox(config) {
    let {main, directory, fromSelector = 'body', beforeAction, afterAction} = config;

    const from = document.querySelector(fromSelector);
    if (!from) {
      console.error("未找到指定的 `from` 元素:", fromSelector);
      return;
    }

    main = resolveElement(main, from);
    directory = resolveElement(directory, from);

    if (!main || !directory) {
      console.error("[目录调整]没有元素: main, directory:", main, directory);
      return;
    }

    executeAction(beforeAction, {main, directory, from});

    // 添加目录到 main 元素中
    main.appendChild(directory);

    executeAction(afterAction, {main, directory, from});

  }

  function executeAction(action, params) {
    if (action) {
      action(params);
    }
  }

  function resolveElement(selectorConfig, context = document.body) {
    return selectorConfig?.selector ? context.querySelector(buildQuery(selectorConfig.selector)) : selectorConfig;
  }

  function resolveElements(selectorConfig, context = document.body) {
    return selectorConfig?.selector ? context.querySelectorAll(buildQuery(selectorConfig.selector)) : selectorConfig;
  }

  /**
   * 构建一个CSS选择器字符串,基于给定的ID,标签名,和类名。
   * 函数接受一个对象参数,其中可以包括id(字符串),tag(字符串),以及classname(字符串或字符串数组)。
   * 根据提供的id,tag和classname(如果有的话),生成一个合适的CSS选择器。
   * 如果classname是一个字符串数组,每个元素都将转换成.class形式并添加到选择器中。
   * 返回的字符串可以直接用于querySelector或querySelectorAll等DOM方法。
   *
   * @param {Object} config - 选择器配置对象,包含可能的id, tag和classname。
   *   @param {string[]} [config.classname=[]] - 类名,可以是单个字符串或字符串数组。
   *   @param {string} [config.id=""] - 元素的ID。
   *   @param {string} [config.tag=""] - 元素的标签名。
   * @return {string} 完整的CSS选择器字符串。
   */
  function buildQuery({classname = [], id = "", tag = ""}) {
    const parts = [];
    if (tag) parts.push(tag);
    if (id) parts.push(`#${id}`);
    if (classname) {
      const classList = Array.isArray(classname) ? classname : [classname]; // 支持字符串或数组输入
      classList.forEach(cls => {
        if (cls = cls?.trim()) parts.push(`.${cls}`); // 避免添加空的类名
      });
    }
    return parts.join('');
  }


  /**
   * 根据提供的配置点击页面元素。配置可以是单一对象或对象数组。
   * 对于每个配置,选择器可以是单一字符串或字符串数组。
   * 可以为每个操作指定过滤函数、元素数量限制、前置操作和后置操作。
   *
   * @param {Object|Object[]} configs - 单一配置对象或配置对象数组。每个配置对象包含:
   *   @param {string|string[]} selector - 单一CSS选择器或选择器数组,用于查找要点击的元素。
   *   @param {Function} [filter] - 可选的过滤函数,用于进一步筛选元素。应返回布尔值。
   *   @param {number} [limit] - 可选的数值,限制要点击的元素数量。
   *   @param {Function} [beforeAction] - 可选的前置操作函数,执行点击之前的操作。
   *   @param {Function} [afterAction] - 可选的后置操作函数,执行点击之后的操作。
   */
  function clickElements(configs) {
    // 确保configs总是数组
    if (!Array.isArray(configs)) {
      configs = [configs];
    }

    configs.forEach(config => {
      const {
        selector,
        filter = () => true,
        limit,
        beforeAction,
        afterAction
      } = config;

      // 确保selector总是数组
      const selectors = Array.isArray(selector) ? selector : [selector];

      if (beforeAction) {
        beforeAction();
      }

      selectors.forEach(sel => {
        const elements = Array.from(document.querySelectorAll(sel)).filter(filter);
        elements.slice(0, limit || elements.length).forEach(element => {
          element.click();
        });
      });

      if (afterAction) {
        afterAction();
      }
    });
  }


  const configs = [
    {
      site: 'blog.csdn.net',
      globalBeforeAction: () => {
        console.log('Starting operations for CSDN')

        clickElements([
          //{ selector: '.contentImg-no-view', limit: 1, beforeAction: () => console.log('即将点击提交按钮') },
          {
            selector: ['.btn-readmore', '.contentImg-no-view'], afterAction: () => {//console.log('选项框已点击')
            }
          }
        ]);


        addDirectoryToMainBox({
          directory: {
            selector: {id: "directory"}
          },
          main: {
            selector: {classname: ["blog-content-box"]}
          },
          afterAction: ({main, directory}) => {
            if (directory && main) {
              directory.style.backgroundColor = "rgba(216,255,213,0.4)";
              directory.style.position = "fixed";
              directory.style.top = "0px";
              directory.style.right = "0px";
              directory.style.zIndex = "1000";
              directory.style.boxShadow = "-6px 3px 10px gray";
              main.appendChild(directory);
            } else {
              console.error("未找到所需的元素");
            }
          }
        });
      },
      operations: [
        {
          fromSelector: 'body',
          selector: {classname: ['blog-content-box']},
          num: 1,
          action: maximizeAndPrune,
          afterAction: () => console.log('Cleared unwanted elements')
        }
      ],
      globalAfterAction: () => {
        console.log('Finished operations for CSDN')
        // 这里放置原代码的后续样式修改
        let main = document.body.getElementsByTagName('main')[0];
        if (main) main.style['margin-bottom'] = '0px';
        document.body.style['min-width'] = '0px';
        let m = document.getElementsByClassName('main_father')[0];
        if (m) m.classList.remove('d-flex');//, 'main_father'
        let treeSkill = document.getElementById('treeSkill');
        if (treeSkill) treeSkill.parentNode.removeChild(treeSkill);
        let blogHuaweiyunAdvert = document.getElementById('blogHuaweiyunAdvert');
        if (blogHuaweiyunAdvert) blogHuaweiyunAdvert.parentNode.removeChild(blogHuaweiyunAdvert);
        let blogColumnPayAdvert = document.getElementById('blogColumnPayAdvert');
        if (blogColumnPayAdvert) blogColumnPayAdvert.parentNode.removeChild(blogColumnPayAdvert);
        let aib = document.getElementsByClassName('article-info-box')[0];
        if (aib) aib.parentNode.removeChild(aib);
        let ai_abstract = document.querySelector('.ai-abstract');
        if (ai_abstract) ai_abstract.remove();
        document.body.style.setProperty('background-color', '#f5f5f5', 'important');
        document.body.style.setProperty('background-image', 'none', 'important');
        let title = document.querySelector('.aside-title')
        if (title) {
          title.style.fontSize = '10px';
          let h4 = document.createElement('h4');
          h4.style.fontSize = '20px';
          h4.style.paddingBottom = '10px';
          h4.style.backgroundColor = 'white'
          h4.innerText = document.querySelector('.title-article').innerText;
          title.parentNode.insertBefore(h4, title.parentNode.firstChild);
        }
      }
    },
    {
      site: 'developer.aliyun.com',
      globalBeforeAction: () => {
        console.log('Starting operations for  developer.aliyun')
        let title = document.getElementsByClassName('article-title')[0];
        let content = document.getElementsByClassName('article-inner')[0];
        if (title && content) {
          content.insertBefore(title, content.firstChild)
        }
        addDirectoryToMainBox({
          directory: {
            selector: {classname: ["right-item-nav-content"]}
          },
          main: {
            selector: {classname: ['article-inner']}
          },
          afterAction: ({main, directory}) => {
            if (directory && main) {
              directory.style.backgroundColor = "rgba(216,255,213,0.4)";
              directory.style.position = "fixed";
              directory.style.top = "0px";
              directory.style.right = "0px";
              directory.style.zIndex = "1000";
              main.appendChild(directory);
              console.log("main: ", main, directory);
            } else {
              console.error("未找到所需的元素");
            }
          }
        });
      },
      operations: [
        {
          fromSelector: 'body',
          selector: {classname: ['article-inner']},
          num: 1,
          action: maximizeAndPrune,
          afterAction: () => console.log('Cleared unwanted elements')
        }
      ],
      globalAfterAction: () => {
        console.log('Finished operations for  developer.aliyun')
        let bankquote = document.getElementsByTagName('blockquote')[0]
        if (bankquote) bankquote.remove();

        let title = document.querySelector('.right-item-nav-title')
        if (title) {
          title.style.fontSize = '10px';
          let h4 = document.createElement('h4');
          h4.style.fontSize = '20px';
          h4.style.paddingBottom = '10px';
          h4.style.backgroundColor = 'white'
          h4.innerText = document.querySelector('.article-title').innerText;
          h4.style.maxWidth = window.getComputedStyle(title.parentElement, null).width;//title.parentElement.style.width;

          h4.style.marginBlockStart = '10px'
          title.parentNode.insertBefore(h4, title.parentNode.firstChild);
        }
        setTimeout(() => {
          let wrapper = resolveElement({selector: {classname: ['content-wrapper']}})
          let content = resolveElement({selector: {classname: ['article-content']}})
          if (wrapper) {
            maximizeAndPrune(content)
          }
        }, 3000)
      }
    },
    {
      site: 'jingyan.baidu.com',
      globalBeforeAction: () => {
        console.log('Starting operations for  developer.aliyun')
        clickElements([
          //{ selector: '.contentImg-no-view', limit: 1, beforeAction: () => console.log('即将点击提交按钮') },
          {
            selector: ['.read-whole'], afterAction: () => {//console.log('选项框已点击')
            }
          }
        ]);
      },
      operations: [
        {
          fromSelector: 'body',
          selector: {classname: ['exp-article']},
          num: 1,
          action: maximizeAndPrune,
          afterAction: () => console.log('Cleared unwanted elements')
        }
      ],
      globalAfterAction: () => {
        console.log('Finished operations for  developer.aliyun')
        document.querySelector('.prompt').remove()
      }
    },
    {
      site: 'zhidao.baidu.com',
      globalBeforeAction: () => {
        console.log('Starting operations for  developer.aliyun')
        clickElements([
          //{ selector: '.contentImg-no-view', limit: 1, beforeAction: () => console.log('即将点击提交按钮') },
          {
            selector: ['.read-whole'], afterAction: () => {//console.log('选项框已点击')
            }
          }
        ]);
      },
      operations: [
        {
          fromSelector: 'body',
          selector: {classname: ['grid', 'qb-content']},
          num: 1,
          action: maximizeAndPrune,
          afterAction: () => console.log('Cleared unwanted elements')
        }
      ],
      globalAfterAction: () => {
        console.log('Finished operations for  developer.aliyun')
        document.querySelector('.prompt')?.remove()
        document.querySelector('.line.qb-section') ? document.querySelector('.line.qb-section').style.paddingLeft = '30px' : () => {
        };//mod-merger-push
        document.querySelector('.mod-merger-push')?.remove();
        document.querySelector('.wgt-bottom-union')?.remove();//
        Array.from(document.querySelectorAll('.wgt-ads')).forEach(ad => {
          ad.remove()
        })
      }
    }

  ];

  //setTimeout( ()=>processSiteElements(configs), 5000);
  configs.filter(config => {
    return window.location.href.includes(config.site);
  })
  //processSiteElements(configs)


  GM_addStyle(GM_getResourceText("css"));
  let ISH5 = null
  let CURRENTPAGES = null
  const BLOGUICONFIG = {
    2: {
      webType: "CSDN",
      pc: [
        {
          title: "查看模式",
          children: [
            // {type: "radio", for: "CsdnRadioC", label: "居中显示", checked: true, getEvent: 'csdnRadioC'},
            // {type: "radio", for: "CsdnRadioP", label: "铺平展示", checked: false, getEvent: 'csdnRadioP'},
            {type: "radio", for: "CsdnRadioImmerse", label: "沉浸式阅读", checked: true, getEvent: 'csdnRadioImmerse'},
            // {type: "radio", for: "CsdnRadioNormal", label: "原始大小", checked: false, getEvent: 'csdnRadioNormal'},
          ]
        },
        {
          title: "右侧选项",
          children: [
            // 左侧
            {type: "checked", domId: "#asideProfile", for: "CsdnAuthorInfo", label: "作者信息", checked: true},
            {
              type: "checked",
              domId: "#asidedirectory",
              for: "CsdnDirectory",
              label: "目录",
              checked: false,
              getEvent: 'csdnDirectory'
            },
            {type: "checked", domId: "#asideSearchArticle", for: "CsdnSerch", label: "搜索博主文章", checked: false},
            {type: "checked", domId: "#asideRank", for: "CsdnAsideRank", label: "是否入选", checked: false},
            {type: "checked", domId: "#asideHotArticle", for: "CsdnHotPage", label: "热门文章", checked: false},
            {type: "checked", domId: "#asideCategory", for: "CsdnCategory", label: "分类专栏", checked: false},
            {type: "checked", domId: "#asideNewComments", for: "CsdnComments", label: "最新评论", checked: false},
            {type: "checked", domId: "#asideNewNps", for: "CsdnNewNps", label: "推荐博客", checked: false},
            {type: "checked", domId: "#asideArchive", for: "CsdnArchive", label: "最新文章", checked: false},
            {type: "checked", domId: "#asideWriteGuide", for: "CsdnWriteGuide", label: "发布文章", checked: false},
          ]
        },
        {
          title: "文章底部",
          children: [
            {type: "checked", domId: ".recommend-box", for: "CsdnRecommend", label: "底部相关推荐", checked: false},
            {type: "checked", domId: "#pcCommentBox", for: "CsdnpcCommentBox", label: "评论", checked: false},
            {
              type: "checked",
              domId: "#blogExtensionBox",
              for: "CsdnblogExtensionBox",
              label: "引流信息",
              checked: false
            },
            {type: "checked", domId: "#treeSkill", for: "CsdntreeSkill", label: "知识档案匹配", checked: false},
          ]
        }, {
          title: "顶部导航",
          children: [
            {
              type: "checked",
              domId: "",
              for: "Csdn2top",
              label: "顶部导航信息",
              checked: false,
              getEvent: 'removeTopbar'
            },
          ]
        },
        // {
        //   title: "右下角悬浮",
        //   children: [
        //     {
        //       type: "checked",
        //       domId: "",
        //       for: "CsdnSideToolbar",
        //       label: "侧边悬浮(略有延迟)",
        //       checked: false,
        //       getEvent: 'removeSideToolbar'
        //     },
        //   ]
        // },
        {
          title: "其他",
          children: [
            {
              type: "checked",
              domId: "",
              for: "whiteBack",
              label: "白色背景(对于暗色主题兼容并不好)",
              checked: true,
              getEvent: 'whiteBack'
            },
          ]
        },
        {
          title: "操作",
          children: [
            {
              type: "button",
              class: "buttoncolor1",
              label: "初始化当前页面配置",
              getEvent: 'clearCache("BLOGUICONFIG", "2")'
            }
          ]
        }
      ],
    }
  };
  let asideWidth = '0px'

  function initUrl() {
    let url = window.location.href
    let urlResList = [
      {platform: 'CSDN', reg: /.*blog.csdn.net.*\/details\/.*/, title: 'CSDN详情优化', key: 2},
      {platform: 'CSDN', reg: /.*blog.csdn.net\/nav.*/, title: 'CSDN文章类型列表优化', key: 3},
      // { platform: 'CSDN', reg: /.*blog.csdn.net\.*/, title: 'CSDN文章类型推荐优化', key: 3.1 },
      {platform: 'CSDN', reg: /.*so.csdn.net\/.*/, title: 'CSDN搜索页面', key: 4},
    ]

    for (let i = 0; i < urlResList.length; i++) {
      if (urlResList[i].reg.test(url)) {
        CURRENTPAGES = urlResList[i].key
        return urlResList[i]
      }
    }
  }

// 外链跳转
  function jumpLink() {
    let url = document.URL
    let target_url = ''
    let flag = false

    if (/https:\/\/link\.csdn\.net\/.*/.test(url)) {
      flag = true
      target_url = url.split("target=")[1]
      setTimeout(() => {
        let github = getElement('.loading-btn-github')
        flag = github && github.length !== 0 ? false : true
        getElement('.loading-topic span')[0].innerText = flag ? 'Blog-UI 正在跳转到: ' : '当前链接可以使用github加速请自行选择: '
        if (flag) {
          target_url = decodeURIComponent(target_url) // 编码
          setTimeout(() => {
            window.location.href = target_url;
          }, 500)
        }
      }, 500)
    }
    if (/https:\/\/link\.juejin\.cn\/.*/.test(url) || /https:\/\/link\.zhihu\.com\/.*/.test(url)) {
      target_url = url.split("target=")[1]
      // setTimeout(() => { getElement('.content .title')[0].innerText = 'Blog-UI 正在跳转到: ' })
      initDialog('body', "Blog-UI 正在跳转")
      target_url = decodeURIComponent(target_url) // 编码
      setTimeout(() => {
        window.location.href = target_url;
      }, 500)
    }
  }

  function addEvent(className, eventType, callback) {
    let dom = getElement(className)[0]
    dom.addEventListener(eventType, callback)
  }

  // 设置缓存更改 配置文件
  function generalCetch() {
    let parentConfig = BLOGUICONFIG[CURRENTPAGES][ISH5 ? 'h5' : 'pc']
    if (parentConfig.length !== 0) {
      // 设置缓存中的内容 并更新 源配置文件
      parentConfig.forEach((item) => {
        item.children.forEach((childrenItem, index, arr) => {
          // 如果没有for 就证明不需要缓存
          if (!childrenItem.for) {
            return
          }
          if (GM_listValues().includes(childrenItem.for)) {
            arr[index].checked = GM_getValue(childrenItem.for)
          } else {
            GM_setValue(childrenItem.for, childrenItem.checked)
          }
        })
      })
      addMain(parentConfig, BLOGUICONFIG[CURRENTPAGES].webType)  // 生成虚拟节点
    }
  }

  // 生成虚拟节点
  function addMain(config, type) {

    let parentDom = getElement('.blog-ui-setting')[0]
    let parentVDom = render({
      tag: 'div',
      prop: {class: "blog-ui-csdn"},
      children: [
        {
          tag: 'div',
          prop: {class: "blog-ui-csdn-main"},
        }
      ]
    })

    parentDom.appendChild(parentVDom)
    let itemDom = getElement('.blog-ui-csdn-main')[0]

    config.forEach((configItem, index) => {
      let vDom = render({
        tag: 'div',
        prop: {class: "blog-ui-item"},
        children: [
          {
            tag: 'div',
            prop: {class: "blog-ui-config-title"},
            children: configItem.title
          },
          {
            tag: 'div',
            prop: {class: "blog-ui-config-center", parentIndex: index},
            children: actionDom(configItem.children, type)
          }
        ]
      })
      itemDom.appendChild(vDom)
    })
  }

  // 操作区
  function actionDom(configItem, type) {
    let actionDom = []
    for (let i = 0; i < configItem.length; i++) {
      let checkObj = null
      if (configItem[i].type === 'checked') {
        checkObj = checkBox(configItem[i], type)
      } else if (configItem[i].type === 'button') {
        checkObj = buttonBox(configItem[i])
      } else if (configItem[i].type === 'radio') {
        checkObj = radioBox(configItem[i])
      }
      actionDom.push(checkObj)

    }
    return actionDom
  }


  // 生成多选框
  function checkBox(item, type) {
    let checkObj = {
      tag: "input",
      prop: {
        "type": "checkbox",
        "id": item.for,
        "domId": item.domId,
        "index": item.index,
        "event": item.getEvent,
        "on": {
          change: (e) => {
            var target = e.target,
              targetTag = target.tagName;
            if (targetTag === "INPUT") {
              if (GM_listValues().includes(target.id)) {
                GM_setValue(target.id, target.checked)
              }
              var event = target.getAttribute('event')
              event != 'undefined' ? eval(`${event}(${target.checked}, '${target.attributes.domId.value}')`) : setDomEvent(target, type)
            }
          }
        }
      }
    }

    if (item.checked) {
      checkObj.prop.checked = true
    }

    let currentDom = {
      tag: 'div',
      prop: {
        "class": "setting-item"
      },
      children: [
        checkObj,
        {
          tag: "label",
          prop: {
            "class": "form-check-label",
            "for": item.for,
            "domId": item.domId
          },
          children: item.label
        }
      ]
    }
    return currentDom
  }

  // 生成按钮
  function buttonBox(item) {
    return {
      tag: "button",
      prop: {
        class: item.class,
        "on": {
          click: (e) => {
            var target = e.target,
              targetTag = target.tagName;
            if (targetTag == 'BUTTON') {
              eval(`${item['getEvent']}`)
            }
          }
        }
      },
      children: item.label
    }
  }

  // 生成单选
  function radioBox(item) {
    let radio = {
      tag: "input",
      prop: {
        'type': item.type,
        'name': 'radio',
        "id": item.for,
        "on": {
          change: (e) => {
            var target = e.target,
              targetTag = target.tagName;

            if (targetTag == 'INPUT') {
              eval(`${item['getEvent']}()`)
            }
          }
        }
      }
    }

    if (item.checked) {
      radio.prop.checked = true
    }

    let radioVdom = {
      tag: 'div',
      prop: {
        class: 'radio-item'
      },
      children: [
        radio,
        {
          tag: 'span',
          prop: {class: 'radio-label'},
          children: item.label
        }
      ]
    }
    return radioVdom
  }

  // 初始化当前页面配置
  function clearCache(plat, key) {
    let config = eval(`${plat}[${key}]`)
    config[ISH5 ? 'h5' : 'pc'].forEach(item => {
      item.children.forEach(detailItem => {
        if (detailItem.for && GM_listValues().includes(detailItem.for)) {
          GM_deleteValue(detailItem.for)
        }
      })
    })
    location.reload();
  }

  // 添加主页面
  function domHtml(urlObject) {
    let DomHtml =
      `
                <div class='position'>
                    <svg t="1661751782189" id="blog-ui-main" class="icon" viewBox="0 0 1024 1024" version="1.1" xmlns="http://www.w3.org/2000/svg" p-id="1727">
                        <path
                            d="M392.2432 477.3376H244.0192c-49.3056 0-89.2928-39.9872-89.2928-89.2928V239.8208c0-49.3056 39.9872-89.2928 89.2928-89.2928h148.224c49.3056 0 89.2928 39.9872 89.2928 89.2928v148.224c0 49.3056-39.9872 89.2928-89.2928 89.2928zM392.2432 868.3008H244.0192c-49.3056 0-89.2928-39.9872-89.2928-89.2928V630.784c0-49.3056 39.9872-89.2928 89.2928-89.2928h148.224c49.3056 0 89.2928 39.9872 89.2928 89.2928v148.224c0 49.3056-39.9872 89.2928-89.2928 89.2928zM785.0496 868.3008h-148.224c-49.3056 0-89.2928-39.9872-89.2928-89.2928V630.784c0-49.3056 39.9872-89.2928 89.2928-89.2928h148.224c49.3056 0 89.2928 39.9872 89.2928 89.2928v148.224c0 49.3056-39.9872 89.2928-89.2928 89.2928zM647.7824 467.0464l-90.0096-90.0096c-34.8672-34.8672-34.8672-91.4432 0-126.3104l90.0096-90.0096c34.8672-34.8672 91.4432-34.8672 126.3104 0l90.0096 90.0096c34.8672 34.8672 34.8672 91.4432 0 126.3104l-90.0096 90.0096c-34.9184 34.8672-91.4432 34.8672-126.3104 0z"
                            fill="#31cdac" p-id="1728">
                        </path>
                    </svg>
                    <div id="blog-main">
                     <div id="blog-fix-main">
                    <svg style="display: none" class="fix-main" id="fix-main-fill" fill="#d21e6c" version="1.1"  xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" width="201px" height="201px" viewBox="-5 -5 60.00 60.00" xml:space="preserve" stroke="#d21e6c" transform="rotate(45)" stroke-width="0.0005000200000000001"><g id="SVGRepo_bgCarrier" stroke-width="0"></g><g id="SVGRepo_tracerCarrier" stroke-linecap="round" stroke-linejoin="round" stroke="#b5b5b5" stroke-width="0.300012"></g><g id="SVGRepo_iconCarrier"> <g> <path d="M40.194,24.752c-0.498,0-1.022-0.343-1.143-0.771L32.381,2.829c-0.118-0.421,0.181-0.767,0.679-0.767h0.547 c0.517,0,0.92-0.355,0.92-0.792V0.792c0-0.433-0.403-0.792-0.92-0.792H16.397c-0.517,0-0.92,0.359-0.92,0.792l0.001,0.479 c0,0.437,0.403,0.794,0.921,0.794l0.547-0.003c0.497,0,0.813,0.346,0.677,0.767l-6.672,21.153 c-0.118,0.427-0.645,0.771-1.143,0.771H9.241c-0.497,0-0.9,0.351-0.9,0.788v2.541c0,0.438,0.403,0.797,0.9,0.797h10.772 c0.497,0,0.979,0.348,1.065,0.782l3.776,20.021c0.087,0.428,0.206,0.428,0.295,0l3.793-20.021c0.067-0.435,0.551-0.782,1.047-0.782 h10.771c0.497,0,0.899-0.359,0.899-0.797l0.001-2.541c0-0.437-0.402-0.788-0.898-0.788L40.194,24.752L40.194,24.752z"></path> </g> </g></svg>
                    <svg style="display: block"  class="fix-main" fill="#ffffff" version="1.1" id="fix-main-empty" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" width="201px" height="201px" viewBox="-5 -5 60.00 60.00" xml:space="preserve" stroke="#ffffff" transform="rotate(45)" stroke-width="0.0005000200000000001"><g id="SVGRepo_bgCarrier" stroke-width="0"></g><g id="SVGRepo_tracerCarrier" stroke-linecap="round" stroke-linejoin="round" stroke="#b5b5b5" stroke-width="4.6001840000000005"> <g> <path d="M40.194,24.752c-0.498,0-1.022-0.343-1.143-0.771L32.381,2.829c-0.118-0.421,0.181-0.767,0.679-0.767h0.547 c0.517,0,0.92-0.355,0.92-0.792V0.792c0-0.433-0.403-0.792-0.92-0.792H16.397c-0.517,0-0.92,0.359-0.92,0.792l0.001,0.479 c0,0.437,0.403,0.794,0.921,0.794l0.547-0.003c0.497,0,0.813,0.346,0.677,0.767l-6.672,21.153 c-0.118,0.427-0.645,0.771-1.143,0.771H9.241c-0.497,0-0.9,0.351-0.9,0.788v2.541c0,0.438,0.403,0.797,0.9,0.797h10.772 c0.497,0,0.979,0.348,1.065,0.782l3.776,20.021c0.087,0.428,0.206,0.428,0.295,0l3.793-20.021c0.067-0.435,0.551-0.782,1.047-0.782 h10.771c0.497,0,0.899-0.359,0.899-0.797l0.001-2.541c0-0.437-0.402-0.788-0.898-0.788L40.194,24.752L40.194,24.752z"></path> </g> </g><g id="SVGRepo_iconCarrier"> <g> <path d="M40.194,24.752c-0.498,0-1.022-0.343-1.143-0.771L32.381,2.829c-0.118-0.421,0.181-0.767,0.679-0.767h0.547 c0.517,0,0.92-0.355,0.92-0.792V0.792c0-0.433-0.403-0.792-0.92-0.792H16.397c-0.517,0-0.92,0.359-0.92,0.792l0.001,0.479 c0,0.437,0.403,0.794,0.921,0.794l0.547-0.003c0.497,0,0.813,0.346,0.677,0.767l-6.672,21.153 c-0.118,0.427-0.645,0.771-1.143,0.771H9.241c-0.497,0-0.9,0.351-0.9,0.788v2.541c0,0.438,0.403,0.797,0.9,0.797h10.772 c0.497,0,0.979,0.348,1.065,0.782l3.776,20.021c0.087,0.428,0.206,0.428,0.295,0l3.793-20.021c0.067-0.435,0.551-0.782,1.047-0.782 h10.771c0.497,0,0.899-0.359,0.899-0.797l0.001-2.541c0-0.437-0.402-0.788-0.898-0.788L40.194,24.752L40.194,24.752z"></path> </g> </g></svg>
                            </div>
                        <div class="blog-main-title">
                            <a href="https://github.com/wandou-cc/blog-ui" target="_blank"> BlogFocusPro 设置界面</a>
                            <center class='blog-ui-urltitle'>${urlObject.title}</center>
                        </div>
                        <div class="blog-ui-setting"></div>
                    </div>
                </div>
            `
    let app = document.createElement('div')
    app.setAttribute('id', 'blogUiApp')
    document.querySelectorAll('body')[0].appendChild(app)
    app.innerHTML = DomHtml
  }

  // 获取元素
  function getElement(className) {
    let domList = document.querySelectorAll(className)
    if (!domList || domList.length === 0) {
      return ''
    } else {
      return domList
    }
  }

  // 初始化一个弹用于消息提示
  function initDialog(parentDom, title) {
    let oldDialog = getElement('.dialog-dom')[0]
    if (oldDialog) {
      oldDialog.remove()
    }
    let dialogVDom = document.createElement('div')
    dialogVDom.setAttribute('class', 'dialog-dom')
    dialogVDom.innerText = title
    setTimeout(() => {
      dialogVDom.setAttribute('style', 'opacity: 1; transition: all 1s;')
    }, 0)
    let parentVDom = getElement(parentDom)[0]
    parentVDom.appendChild(dialogVDom)

    setTimeout(() => {
      dialogVDom.setAttribute('style', 'opacity: 0; transition: all 1s;')
    }, 2000)
  }

  // 设置隐藏显示
  function displayDom(domNode, type) {
    if (!domNode) {
      return
    }
    // 对于一些动态加载的节点 如果没有查到就加入 一个错误队列中 每1000毫秒查找一次
    let dom = getElement(domNode)
    let errorList = []
    if (dom && dom.length > 0) {
      dom.forEach(item => {
        item.style['display'] = type ? 'block' : 'none'
      })
    } else {
      errorList.push({
        domNode,
        type
      })
    }

    if (errorList.length !== 0) {
      let i = 0
      let interval = setInterval(() => {
        if (i <= 5) {
          errorList.forEach(item => {
            let errorDom = getElement(domNode)
            if (errorDom && errorDom.length > 0) {
              errorDom.forEach(item => {
                item.style['display'] = type ? 'block' : 'none'
              })
            }
          })
          i++
        } else {
          clearInterval(interval)
        }
      }, 3000)
    }
  }

  // 输出
  function log(message, type = 'log') {
    console[type](message)
  }

  // 创建dom 元素
  function render(Vnode) {
    let {tag, prop, children} = Vnode
    let el = document.createElement(tag)
    Object.keys(prop).forEach(item => {
      el.setAttribute(item, prop[item]);
      if (item === 'on') {
        let eventObject = prop[item]
        Object.keys(eventObject).forEach(eventItem => {
          el.addEventListener(eventItem, (e) => eventObject[eventItem](e))
        })
      }
    })

    if (children instanceof Array) {
      children.forEach((item) => {
        el.appendChild(render(item));
      });
    } else {
      el.textContent = children
    }
    return el
  }

  // 设置点击事件 在这里需要进行分发
  function setDomEvent(e, type) {
    let checkedFlag = e.checked
    let domId = e.attributes.domid.value
    switch (type) {
      case 'CSDN':
        CSDNEvent(domId, checkedFlag)
      case 'JUEJIN':
        JUEJINEvent(domId, checkedFlag)
      case 'SiFou':
        SiFouEvent(domId, checkedFlag)
      case 'ZhiHu':
        ZhiHuEvent(domId, checkedFlag)
    }
  }

  // 添加外部样式
  function addCss(className, query) {
    let dom = getElement(className)[0]
    Object.keys(query).forEach(item => {
      dom.style[item] = query[item]
    })
  }

  function appendDom() {
    let html =
      `
            <div class='bottom-tip'>
                <p class='gotogithub'>
                    <a  target="_blank" href="https://github.com/wandou-cc/blog-ui">
                        <svg t="1663318093270"  viewBox="0 0 3786 1024" version="1.1" xmlns="http://www.w3.org/2000/svg" p-id="4682" width="100" height="50"><path d="M729.176289 438.294072H410.703618c-7.882987 0-14.977675 6.30639-14.977675 14.977675v155.294843c0 7.882987 6.30639 14.977675 14.977675 14.977675h123.762895v193.133179s-27.590454 9.459584-104.843726 9.459584c-90.654349 0-217.570439-33.108545-217.570439-312.166281s132.43418-316.107775 256.197075-316.107775c107.208622 0 153.718245 18.919169 182.885296 28.378752 9.459584 3.153195 18.13087-6.30639 18.13087-14.977675l35.473441-150.56505c0-3.941493-1.576597-8.671286-5.518091-11.82448C687.396459 40.991532 614.872979 0 430.411085 0 217.570439 0 0 90.654349 0 525.006928c0 434.352579 249.102386 498.993072 459.578137 498.993072 174.214011 0 279.846035-74.100077 279.846035-74.100077 4.729792-2.364896 4.729792-8.671286 4.729793-11.036182V453.271747c0-8.671286-7.094688-14.977675-14.977676-14.977675zM2368.837567 52.027714c0-7.882987-6.30639-14.977675-14.977675-14.977676h-178.943803c-7.882987 0-14.977675 6.30639-14.977675 14.977676v346.063125h-279.057737V52.027714c0-7.882987-6.30639-14.977675-14.977675-14.977676H1686.959199c-7.882987 0-14.977675 6.30639-14.977675 14.977676v937.287144c0 7.882987 6.30639 14.977675 14.977675 14.977675h178.943803c7.882987 0 14.977675-7.094688 14.977675-14.977675V588.070824H2159.938414l-0.788299 401.244034c0 7.882987 6.30639 14.977675 14.977676 14.977675h179.732101c7.882987 0 14.977675-7.094688 14.977675-14.977675V52.027714z" fill="#d4237a" p-id="4683"></path><path d="M1067.356428 175.002309c0-64.640493-52.027714-116.668206-115.879908-116.668206s-115.091609 52.027714-115.091609 116.668206c0 64.640493 52.027714 116.668206 115.091609 116.668207 63.852194 0 115.879908-52.027714 115.879908-116.668207zM1054.743649 791.451886V358.675905c0-7.882987-6.30639-14.977675-14.977675-14.977676h-178.943803c-7.882987 0-15.765974 8.671286-15.765974 16.554273v619.602771c0 18.13087 11.036182 23.648961 26.013857 23.648961h160.812933c17.342571 0 22.072363-8.671286 22.072363-23.648961 0.788299-33.108545 0.788299-163.177829 0.788299-188.403387z" fill="#d4237a" p-id="4684"></path><path d="M3049.139338 345.274827h-177.367206c-7.882987 0-14.977675 7.094688-14.977675 14.977675V819.830639s-44.933025 33.108545-109.573518 33.108545c-63.852194 0-81.194765-29.167052-81.194765-92.230947V360.252502c0-7.882987-6.30639-14.977675-14.977675-14.977675h-180.5204c-7.882987 0-14.977675 7.094688-14.977676 14.977675v431.199384c0 186.038491 104.055427 231.759815 246.737491 231.759815 117.456505 0 212.052348-64.640493 212.052348-64.640492s4.729792 33.896844 6.306389 37.838337c2.364896 3.941493 7.094688 7.882987 13.401078 7.882987l115.091609-0.788299c7.882987 0 14.977675-7.094688 14.977675-14.977675V359.464203c0-7.094688-6.30639-14.189376-14.977675-14.189376zM3535.51963 324.779061c-100.902232 0-169.484219 44.933025-169.484218 44.933025V52.027714c0-7.882987-6.30639-14.977675-14.977675-14.977676h-179.732102c-7.882987 0-14.977675 6.30639-14.977675 14.977676v937.287144c0 7.882987 6.30639 14.977675 14.977675 14.977675h124.551193c5.518091 0 10.247883-3.153195 12.612779-7.882987 3.153195-4.729792 7.882987-43.356428 7.882987-43.356428s73.311778 69.370285 212.840647 69.370285c163.177829 0 256.985373-82.771363 256.985373-372.076983-0.788299-288.517321-149.776751-325.56736-250.678984-325.567359z m-70.158583 527.371824c-61.487298-1.576597-103.267129-29.95535-103.267129-29.95535V525.795227s40.991532-25.225558 92.230947-29.95535c63.852194-5.518091 125.339492 13.401078 125.339492 166.331024-0.788299 160.812933-28.378753 193.133179-114.30331 189.979984zM1569.502694 343.698229h-134.010777V166.331024c0-7.094688-3.153195-10.247883-11.036182-10.247883h-182.885296c-7.094688 0-11.036182 3.153195-11.036182 10.247883v183.673595s-91.442648 22.072363-97.749038 23.648961c-6.30639 1.576597-11.036182 7.882987-11.036181 14.189376v115.091609c0 8.671286 6.30639 14.977675 14.977675 14.977675h93.807544v277.48114c0 205.745958 144.258661 226.241724 242.007698 226.241724 44.933025 0 97.749038-14.189376 106.420324-17.342571 5.518091-1.576597 8.671286-7.094688 8.671285-13.401078v-126.916089c0-7.882987-7.094688-14.977675-14.977675-14.977675-7.882987 0-27.590454 3.153195-48.874519 3.153194-66.21709 0-88.289453-30.743649-88.289453-70.158583V518.700539h134.010777c7.882987 0 14.977675-6.30639 14.977676-14.977675V358.675905c-0.788299-7.882987-7.094688-14.977675-14.977676-14.977676z" fill="teal" p-id="4685"></path></svg>
                    </a>
                </p>
                <p class='blog-ui-version'> 当前版本号: ${VERSION}</p>
                <div style="text-align:center">
                    <p> 作者本人也是做前端开发的 </p> 
                    <p> 有兴趣的小伙伴可以加百人大群 一起探讨交流 </p>
                </div>
                <a target="_blank" href="https://qm.qq.com/cgi-bin/qm/qr?k=KBoDLbs7o7cLxBwKbBij0RNdNPslJ-HS&jump_from=webapi&authKey=zBON7pCcMJkpGoufA4QHOBHFNVYrJ6exGexad89wzgTpSLozInSnoGgQSEGhgMEp">
                    <p class='blog-ui-addQQ'> 
                       
                        <br>
                        <img src="" width='250px'/>
                    </p>
                </a>

                <p class='blog-ui-issues'>
                    <a target="_blank" href="https://github.com/wandou-cc/blog-ui/issues?q=??提交个建议">
                        <svg t="1663321961162" viewBox="0 0 1024 1024" version="1.1" xmlns="http://www.w3.org/2000/svg" p-id="7079" width="30" height="30"><path d="M409.556305 832.886311c-3.039219 0.001023-6.04774-1.347694-8.065699-3.927449-43.106774-55.093782-78.364789-109.137653-104.792695-160.631444-21.252023-41.409109-36.894282-81.309864-46.490847-118.594025-16.241916-63.098083-9.721409-97.682763-9.122775-100.570533 12.328793-62.99166 39.591717-104.664781 81.030501-123.856889 72.586179-33.615609 160.732751 14.868639 164.449399 16.949021 4.931313 2.76088 6.691399 8.995885 3.931542 13.927197-2.759857 4.929266-8.990768 6.689353-13.920034 3.935636l0 0c-0.822738-0.458441-82.886779-45.469588-145.933697-16.207124-35.121915 16.302291-58.500369 53.057403-69.484537 109.244077-0.014326 0.072655-0.028653 0.144286-0.044002 0.215918-0.056282 0.273223-6.478552 32.732495 9.444093 93.297896 14.762215 56.154951 52.257178 148.524708 147.051147 269.676999 3.482311 4.451382 2.697435 10.882861-1.752924 14.365172C413.983127 832.17716 411.76153 832.886311 409.556305 832.886311z" p-id="7080" fill="#1396cd"></path><path d="M207.895399 632.868835c-1.817392 0.001023-3.657296-0.484024-5.322216-1.500167-50.776454-30.993898-72.890101-66.422805-82.499969-90.686419-10.69662-27.00812-8.852622-46.824445-8.769734-47.65537 0.566912-5.623068 5.600555-9.714246 11.208273-9.155521 5.605671 0.564865 9.69685 5.553483 9.160637 11.155061-0.033769 0.412392-1.277086 16.805758 7.902994 39.294958 12.30935 30.15888 37.781488 57.675584 73.661673 79.57843 4.823865 2.944052 6.347568 9.241478 3.403516 14.065344C214.710618 631.126144 211.343941 632.868835 207.895399 632.868835z" p-id="7081" fill="#1396cd"></path><path d="M380.752282 675.731038c-3.63683 0-7.157004-1.942235-9.009188-5.365194-2.689249-4.970198-0.840134-11.180644 4.131087-13.869892 14.629185-7.942903 36.0828-24.222681 37.987173-35.55682 0.937348-5.572926 6.219655-9.335622 11.787464-8.395204 5.573949 0.936325 9.332553 6.212492 8.396227 11.787464-4.304026 25.618471-43.927465 47.729048-48.431036 50.164516C384.064724 675.332972 382.396735 675.731038 380.752282 675.731038z" p-id="7082" fill="#1396cd"></path><path d="M701.772646 599.410815c-22.321378 54.713113-53.872978 103.923908-94.227058 93.166913-52.372811-13.950733-62.85249-80.855516-50.41011-145.056724-66.695005-1.539053-136.792503-32.289404-140.636041-86.457094-3.824095-54.041824 30.737048-95.990215 89.455381-109.313661-16.511046-59.700707 5.770424-121.118522 55.450916-144.189983 47.982828-22.288632 100.192933 18.546402 132.837424 72.27714C743.255433 196.395996 843.566046 266.516006 843.566046 266.516006s117.051903 79.908958 3.183506 167.383218c58.414411 41.73145 71.975265 113.865327 36.265972 163.690106" p-id="7083" fill="#1396cd"></path><path d="M618.92987 704.354959c-4.622274 0-9.29162-0.62831-14.019295-1.890047-27.812439-7.407714-47.423079-28.414143-56.710606-60.745503-6.770194-23.567765-7.824199-53.222155-3.110851-84.528162-67.760267-4.853541-134.718261-37.925774-138.796136-95.402837-2.061962-29.143761 6.087649-55.81726 23.568788-77.138868 15.322987-18.688641 37.232996-32.489972 63.780629-40.272215-13.000082-62.190411 12.694113-122.525568 63.454194-146.098449 25.437345-11.815093 53.729715-8.987698 81.817424 8.181333 19.770276 12.085246 39.140439 31.30703 55.555294 54.952566 12.870122-16.153912 29.014824-26.425859 48.15986-30.602995 50.725288-11.069103 103.932094 25.323758 106.756419 27.288506 2.911306 1.997494 55.861262 39.078017 57.361429 92.592838 0.821715 29.323862-13.829983 57.207933-43.586704 83.025948 25.921369 21.974477 42.827411 50.779523 48.053436 82.300424 5.192256 31.315216-1.867534 62.401212-19.87977 87.533612-3.290953 4.592598-9.683547 5.649674-14.278191 2.356674-4.593622-3.291976-5.649674-9.68457-2.356674-14.278191 14.823614-20.684088 20.620643-46.348608 16.32378-72.263837-5.004991-30.18344-22.840194-57.57837-50.221822-77.139891-2.63706-1.883907-4.226255-4.906753-4.282536-8.148587-0.057305-3.240811 1.426489-6.317892 3.997034-8.292873 31.089066-23.882943 46.488801-48.954969 45.771463-74.519204-1.219781-43.532469-48.019667-75.975369-48.492434-76.29771-0.030699-0.021489-0.062422-0.042979-0.093121-0.064468-0.471744-0.327458-48.571229-33.341363-90.783633-24.082488-18.10024 3.970428-32.854269 15.476483-43.852764 34.198893-1.823532 3.105734-5.145184 5.02341-8.747221 5.050016-0.024559 0-0.051165 0-0.075725 0-3.572362 0-6.887874-1.863441-8.745175-4.920056-16.347317-26.90579-36.681434-48.651047-57.258075-61.228503-22.282492-13.622252-43.318598-16.003486-62.522985-7.081279-44.394093 20.61655-65.379033 76.206636-49.898457 132.181485 0.74599 2.695389 0.355087 5.579065-1.080611 7.979742-1.435699 2.400676-3.791349 4.108574-6.51846 4.727675-53.720505 12.190647-84.953857 49.976228-81.512479 98.611925 3.412726 48.100508 69.868277 75.546603 130.663922 76.949556 3.012613 0.068562 5.842055 1.463328 7.733125 3.810792 1.89107 2.346441 2.651386 5.408173 2.077312 8.366551-10.351766 53.414537-5.302773 120.355135 42.998303 133.222187 34.704406 9.251711 63.814398-42.281989 82.118276-87.143733 2.133593-5.233188 8.107655-7.745405 13.33982-5.608741 5.233188 2.134617 7.744381 8.107655 5.608741 13.33982C683.843298 670.447708 652.841214 704.354959 618.92987 704.354959z" p-id="7084" fill="#1396cd"></path></svg>
                        &nbsp;&nbsp;<span> '差评' 去提交个建议 </span>
                    </a>
                    <a target="_blank" href="https://github.com/wandou-cc/blog-ui">
                        <svg t="1663322550847" viewBox="0 0 1051 1024" version="1.1" xmlns="http://www.w3.org/2000/svg" p-id="21206" width="20" height="20"><path d="M766.083422 783.058824m-206.990374 0a206.990374 206.990374 0 1 0 413.980749 0 206.990374 206.990374 0 1 0-413.980749 0Z" fill="#1396cd" p-id="21207"></path><path d="M892.029947 997.167914H386.053476c-98.019251 0-193.300535-136.350802-240.941177-217.394652-6.571123-10.951872-2.737968-25.189305 8.213904-31.760428 10.951872-6.571123 25.189305-2.737968 31.760428 8.213904 70.639572 119.922995 147.850267 194.395722 200.966845 194.395722h505.976471c21.35615 0 38.331551-16.975401 38.33155-38.331551V481.882353c0-21.35615-16.975401-38.331551-38.33155-38.331551h-94.73369c-74.472727 0-153.873797-49.283422-153.873797-123.208556v-3.285562l20.260962-148.945454c-0.547594-39.426738-19.165775-66.806417-58.044919-83.234225-20.260963-8.761497-80.496257 1.095187-91.448129 10.404278C436.979679 162.635294 357.57861 381.125134 356.483422 383.315508l-5.475935 14.785027-15.880214 0.547593c-1.095187 0-90.900535 3.833155-130.327273 9.309091-31.212834 4.380749-62.425668 24.641711-83.234225 54.211765-21.35615 30.665241-29.02246 67.354011-21.356149 102.947594 4.928342 21.903743 14.785027 50.37861 28.474866 83.234224 4.928342 12.047059-0.547594 25.736898-12.047059 30.665241-12.047059 4.928342-25.736898-0.547594-30.66524-12.047059-15.33262-35.045989-25.736898-66.806417-31.212835-91.448128-9.309091-49.831016 0.547594-99.114439 29.570054-140.183958 27.927273-39.974332 70.639572-67.354011 114.994652-73.37754 31.760428-4.380749 90.900535-7.66631 119.375401-8.761497 20.260963-52.568984 90.900535-227.79893 165.373262-292.414973 26.284492-22.451337 106.233155-32.855615 140.731551-17.522995 55.854545 24.641711 85.972193 68.449198 85.972193 127.589305v3.285561l-20.808557 147.850268c1.095187 44.35508 56.949733 75.020321 107.328343 75.020321h94.73369c46.545455 0 84.877005 37.783957 84.877005 84.877005v430.408556c0 47.093048-38.331551 84.877005-84.877005 84.877005z" fill="#1396cd" p-id="21208"></path></svg>
                        &nbsp;&nbsp;&nbsp;<span>&nbsp;&nbsp;'好评' 给作者点个赞 </span>
                    </a>
                </p>

                <div class='blog-ui-advertis'>
                    <p class='advertis-warn'> 广告警告?? </p>

                    <p> 也不算广告啦 也是之前作者写的VScode插件 </p>
                    <a target="_blank" href="https://github.com/wandou-cc/exclusive-translation">
                            <img src='' />
                            ?? 叫做 'exclusive-translation' 专属翻译
                            <br />
                            ??可以直接vscode搜索 '百度翻译'安装 可以直接中英翻译??
                    </a>
                </div>

                <div class='blog-ui-prompt'>
                    如果有问题或者建议可以及时联系群主或者github提issues, 我也很希望大家能提提意见, 我看到后会及时内回复各位, 祝各位使用愉快
                </div>

                <div class='statement'>
                     未来版本将要更新的功能:<br>
                        1.对CSDN下载资源对优化<br>
                        2.添加博客园 掘金 知乎 简书 思否 等技术论坛等优化<br>
                        3.可以对文章主要部分进行打印 PDF 获取<br>
                        4.目前只想到这些吧 其他的 想起来在写
                </div>
                <br>
            </div>
        `
    let parentDom = getElement('.blog-ui-csdn')[0]
    let createDom = document.createElement('div')
    createDom.innerHTML = html
    parentDom.appendChild(createDom)
  }


  function fixMainThumbtack() {
    let thumtacks = document.getElementsByClassName('fix-main');
    mainFixed = GM_getValue('MainFixed')
    if (thumtacks.length) {
      Array.from(thumtacks).forEach((svg, index, svgs) => {//fill, empty
        if (index === 0) {//
          svg.addEventListener('click', () => {
            mainFixed = false;
            GM_setValue('MainFixed', mainFixed);
            svgs[1].style.display = 'block';
            svgs[0].style.display = 'none';
          })
          if (mainFixed) {
            svgs[0].style.display = 'block';
            svgs[1].style.display = 'none';
          }
        } else {
          svg.addEventListener('click', () => {
            mainFixed = true;
            GM_setValue('MainFixed', mainFixed);
            svgs[1].style.display = 'none';
            svgs[0].style.display = 'block';
          })
        }
      })
    }
  }

  function initMainEvent() {


    addEvent('#blog-ui-main', 'click', (e) => {
      console.log(123)
      addCss('#blog-main', {display: 'inherit'})
      if (getElement('.bscroll-vertical-scrollbar').length !== 0) {
        getElement('.bscroll-vertical-scrollbar')[0].remove()
      }
      getElement('.blog-ui-csdn')[0].style.transform = 'translateX(0px) translateY(0px) translateZ(1px)'
    })


    // 设置鼠标移入svg 显示主菜单
    addEvent('#blog-ui-main', 'mouseenter', (e) => {

      (!ISH5 && CURRENTPAGES == 2) ? setAside() : '' // 点击之后进行判断是不是没有右侧的侧边栏了
      console.log(0)
      addCss('#blog-main', {display: 'inherit'})
      if (getElement('.bscroll-vertical-scrollbar').length !== 0) {
        getElement('.bscroll-vertical-scrollbar')[0].remove()
      }
      getElement('.blog-ui-csdn')[0].style.transform = 'translateX(0px) translateY(0px) translateZ(1px)'
    })

    addEvent('#blog-main', 'mouseleave', () => {
      if (mainFixed) {
        return;
      }
      addCss('#blog-main', {display: 'none'})
    })

    var screen_width = document.body.offsetWidth;
    var screen_height = window.innerHeight;

    let father = getElement('#blogUiApp')[0]

    if (GM_getValue('x')) {
      father.style.top = GM_getValue('y')
      father.style.left = GM_getValue('x')
    }

    addEvent('#blog-ui-main', 'mousedown', (e) => {
      var x = e.pageX - father.offsetLeft
      var y = e.pageY - father.offsetTop

      function move(e) {
        e.preventDefault();
        let Py = e.pageY - y
        let Px = e.pageX - x
        father.style.top = Py + 'px'
        father.style.left = Px + 'px'

        if (Py < 20) {
          father.style.top = 20 + 'px'
        } else if (Py > (screen_height - 50)) {
          father.style.top = screen_height - 50 + 'px'
        }

        if (Px < 5) {
          father.style.left = 5 + 'px'
        } else if (Px > (screen_width - 50)) {
          father.style.left = screen_width - 50 + 'px'
          getElement('#blog-ui-main')[0].style.reight = '5px'
        }

        GM_setValue('x', father.style.left)
        GM_setValue('y', father.style.top)
      }

      document.addEventListener('mousemove', move)
      document.addEventListener('mouseup', function () {
        document.removeEventListener('mousemove', move)
      })
    })

    addEvent('#blog-ui-main', 'touchstart', (e) => {
      var x = e.changedTouches[0].pageX - father.offsetLeft
      var y = e.changedTouches[0].pageY - father.offsetTop

      function move(e) {
        let Py = e.changedTouches[0].pageY - y
        let Px = e.changedTouches[0].pageX - x
        father.style.top = Py + 'px'
        father.style.left = Px + 'px'

        if (Py < 20) {
          father.style.top = 20 + 'px'
        } else if (Py > (screen_height - 50)) {
          father.style.top = screen_height - 50 + 'px'
        }

        if (Px < 5) {
          father.style.left = 5 + 'px'
        } else if (Px > (screen_width - 50)) {
          father.style.left = screen_width - 50 + 'px'
          getElement('#blog-ui-main')[0].style.reight = '5px'
        }

        GM_setValue('x', father.style.left)
        GM_setValue('y', father.style.top)
      }

      document.addEventListener('touchmove', move)
      document.addEventListener('touchend', function () {
        document.removeEventListener('touchmove', move)
      })
    })
  }

  function CSDNIsH5OrPC(id) {
    // h5 移动端端时候的主元素ID
    let dom = getElement(id)
    if (dom && dom.length > 0) {
      return true
    } else {
      return false
    }
  }

  function deepCloneElement(element) {
    const clone = element.cloneNode(true);
    element.parentNode.replaceChild(clone, element);
    return clone;
  }
// ----------- CSDN 专区 ----------
  function csdnDirectory(checkedFlag, domId) {
    CSDNEvent(domId, checkedFlag)
    if (checkedFlag && domId) {
      csdnSetMenuHeight(true)
    }
  }

  function csdnSetMenuHeight(flag = false) {
    setTimeout(() => {
      let asidedirectory = getElement('#asidedirectory')[0]
      if (asidedirectory) {
        let blog_container_aside = Array.from(getElement('.blog_container_aside')[0].children)
        let height = 0
        blog_container_aside.forEach((item) => {
          height += item.offsetHeight
        })
        height = height - asidedirectory.offsetHeight
        GM_setValue('CSDNMenuHeight', height)
        let CSDNMenuHeight = GM_getValue("CSDNMenuHeight")
        // csdnScrollMenu(asidedirectory, CSDNMenuHeight)
        // window.onscroll = (e) => {
        //   csdnScrollMenu(asidedirectory, CSDNMenuHeight)
        // }

      }
    }, 1000)
  }

  // function csdnScrollMenu(asidedirectory, CSDNMenuHeight) {
  //   let scrollTop = document.documentElement.scrollTop || window.pageYOffset || document.body.scrollTop
  //   if (scrollTop > CSDNMenuHeight) {
  //     asidedirectory.classList.add('default-menu')
  //   } else {
  //     asidedirectory.classList.remove('default-menu')
  //   }
  // }

  function csdnRadioP() {
    GM_setValue('CsdnRadioC', false)
    GM_setValue('CsdnRadioP', true)
    GM_setValue('CsdnRadioImmerse', false)

    getElement('.main_father')[0].style = `height: 100%; width: 97vw; justify-content: unset;`
    getElement('.container')[0].style = `display: flex;width: 97vw;`
  }

  function csdnRadioC() {
    GM_setValue('CsdnRadioP', false)
    GM_setValue('CsdnRadioC', true)
    GM_setValue('CsdnRadioImmerse', false)

    getElement('.main_father')[0].style = `height: 100%; width: 97vw; justify-content: center;`
    getElement('.container')[0].style = `display: flex;`
  }

  function maximizeAndHide(element) {
    let currentNode = element;
    while (currentNode !== document.body) {
      //currentNode.style.width = '100%';
      currentNode.classList.add(['maximize'])
      let parent = currentNode.parentNode;
      Array.from(parent.childNodes).forEach(child => {
        if (!child || !child.style || (child.id && child.id === 'blogUiApp')) {
          return;
        }
        if (child !== currentNode && !['STYLE', 'LINK'].includes(child.tagName)) {
          //parent.removeChild(child);
          child.classList.add('hide100')
          //child.style.display = 'none';
        }
      });
      currentNode = parent;
    }
  }

  function demaximizeAndHide(element) {
    let currentNode = element;
    while (currentNode !== document.body) {
      //currentNode.style.width = '100%';
      //currentNode.classList.add(['maximize'])
      let parent = currentNode.parentNode;
      Array.from(parent.childNodes).forEach(child => {
        if (!child || !child.style || (child.id && child.id === 'blogUiApp')) {
          return;
        }
        if (child !== currentNode && !['STYLE', 'LINK'].includes(child.tagName)) {
          //parent.removeChild(child);
          child.classList.add('hide100')
          child.style.display = 'block';
        }
      });
      currentNode = parent;
    }
  }

  function csdnRadioImmerse() {
    //GM_setValue('CsdnRadioNormal', false)
    GM_setValue('CsdnRadioImmerse', true)

    // getElement('.main_father')[0].style = `height: 100%; width: 97vw; justify-content: center;`
    // getElement('.container')[0].style = `display: flex;`
    maximizeAndHide(getElement('.blog-content-box')[0]);
    getElement('main')[0].style.width = '100%';
    getElement('.main_father')[0].style.padding = '0px 0px 0px 0px';
    getElement('.container')[0].classList.remove('container');
  }

  function csdnRadioNormal() {
    //GM_setValue('CsdnRadioNormal', true)
    GM_setValue('CsdnRadioImmerse', false)
    // demaximizeAndHide( getElement('.blog-content-box')[0]);
  }

  function CSDNIsH5OrPC(id) {
    // h5 移动端端时候的主元素ID
    let dom = getElement(id)
    if (dom && dom.length > 0) {
      return true
    } else {
      return false
    }
  }

  // csdn 点击操作区部分触发的事件
  function CSDNEvent(domId, checked) {
    displayDom(domId, checked);
    (!ISH5 && CURRENTPAGES == 2) ? setAside() : '' // 点击之后进行判断是不是没有右侧的侧边栏了
    window.onscroll = null
    csdnSetMenuHeight()
  }

  // -------- csdn 通用 ---------
  // 处理顶部
  function removeTopbar(checked) {
    // setTimeout(() => {
    //   // 处理左侧
    //   getElement('.toolbar-menus li').forEach(item => {
    //     let dataType = item.getAttribute('title')
    //     if (['高价值源码课程分享', '简单高效优惠的云服务', '程序员的如意兵器', '找到志同道合的伙伴', '系统学习·问答·比赛', '开源代码托管', '让你的灵感立即落地'].includes(dataType)) {
    //       item.style.display = checked ? 'inline-block' : 'none'
    //     }
    //   })
    //
    //   // 判断是否登录
    //   let loginDom = getElement('.toolbar-btn-loginfun')
    //   // 已经登录
    //   if (!loginDom) {
    //     return
    //   }
    //
    //   // 删除顶部右侧
    //   ['.toolbar-btn-vip', '.toolbar-btn-collect', '.toolbar-dynamic-box', '.toolbar-mp-menubox', '.toolbar-btn-write', '.toolbar-advert', '.toolbar-btn-mp', '.toolbar-btn-msg'].forEach(item => {
    //     displayDom(item, checked)
    //   })
    // }, 500)
    let toolBar = getElement('#toolbarBox')[0];
    if (toolBar && toolBar.style) {
      toolBar.style.display = checked ? 'block' : 'none';
    }
  }

  function whiteBack(checked) {
    if (checked) {
      getElement('body')[0].classList.add('bodyWhite')
    } else {
      getElement('body')[0].classList.remove('bodyWhite')
    }
  }

  // 优化开始
  function CSDNOoptimiz(key) {
    if (!ISH5) {
      let removeDom = ['#recommendNps', '.template-box', '.blog-footer-bottom', '#csdn-copyright-footer']
      // 删除可以直接通类名进行获取的元素
      removeDom.forEach(item => {
        displayDom(item, false)
      })
    }
// 创建一个 <style> 元素
    const style = document.createElement('style');

// 添加 CSS 规则
    style.innerHTML = `
  .blog_container_aside::-webkit-scrollbar {
    width: 6px;
    height: 6px;
  }
  
  .blog_container_aside::-webkit-scrollbar-button {
    display: none;
  }
  
  .blog_container_aside::-webkit-scrollbar-thumb {
    background: rgba(144, 147, 153, 0.3);
    cursor: pointer;
    border-radius: 4px;
  }
  
  .blog_container_aside::-webkit-scrollbar-corner {
    display: none;
  }
`;

// 将 <style> 元素添加到 <head> 中
    document.head.appendChild(style);
    document.getElementById('recommend-right')?.remove();
    // getElement('.passport-login-container')[0].style.display = 'none'
    let a = document.querySelector('.blog_container_aside')
    if(a){
      a=deepCloneElement(a)
      a.style.position='absolute';
      a.style.left='403px';
      a.style.background = 'white';
      a.style.height = '60vh';
      a.style.overflow='scroll';
      a.style.boxShadow ='0px 0px 10px rgb(204, 204, 204)';
      a.style.top = '-2px';

      a.classList.remove(['hide100'])
      let blogmain = document.getElementById('blog-main')
      blogmain.insertBefore(a, blogmain.firstChild);
      setAside();
    }

    // 点击登录注册按钮进行展示登录页面
    let loginShow = ['.toolbar-btn-login', '.unlogin-comment-bt']
    loginShow.forEach(item => {
      let loginDom = getElement(item)
      loginDom && loginDom.length != 0 && loginDom[0].addEventListener('click', () => {
        setTimeout(() => {
          getElement('.passport-login-container')[0].style.display = 'block'
        }, 500)
      })
    })

    if (key === 2) {
      // 解除点击全选
      let hljdButton = getElement(".hljs-button")
      if (hljdButton && hljdButton.length !== 0) {
        hljdButton.forEach(item => {
          item.setAttribute('data-title', '免登录复制')
          item.addEventListener('click', (event) => {
            const parentPreBlock = event.target.closest("pre");
            let code = parentPreBlock.querySelectorAll('code')[0]
            navigator.clipboard.writeText(code.innerText)
            item.setAttribute('data-title', '复制成功')
            setTimeout(() => {
              item.setAttribute('data-title', '免登录复制')
            }, 3000)
          })
        })
      }

      // 复制
      getElement('#content_views')[0].oncopy = function (event) {
        const selection = document.getSelection()
        event.clipboardData.setData("text/plain", selection.toString())
        event.preventDefault()
      }

      // 展开code 折叠
      document.querySelectorAll('.hide-preCode-bt').forEach(item => {
        item.click()
      })
      ISH5 ? csdnDeatilH5() : csdnDeatilPc()
    }
  }

  // -----------详情页面处理方法------
  // 判断右侧 的 侧边栏是不是全都有display:none 如果有就进行全屏显示
  function setAside() {
    let blog_container_aside = getElement('.blog_container_aside')[0]
    setTimeout(() => {
      let domList = []
      getElement('.blog_container_aside .aside-box').forEach(item => {
        domList.push(item.style.display)
      })

      if (domList.filter(item => {
        return item === 'block'
      }).length == 0) {
        asideWidth = '0px'
        //getElement('main')[0].style.width = '100%'
      } else {
        asideWidth = '310px'
        //getElement('main')[0].style.width = '75%'
      }
      blog_container_aside.style.width = asideWidth
    })
  }

  // 处理左侧悬浮
  function removeSideToolbar(checked) {
    setTimeout(() => {
      // 删除侧边悬浮
      getElement('.csdn-side-toolbar')[0].style = ''
      getElement('.csdn-side-toolbar .option-box').forEach(item => {
        let dataType = item.getAttribute('data-type')
        if (['search', 'guide', 'cs'].includes(dataType)) {
          item.style.display = checked ? 'flex' : 'none'
        }
        if (['show', 'hide'].includes(dataType)) {
          item.remove()
        }
      })

      displayDom('.sidetool-writeguide-box', false)
      displayDom('.btn-sidetool-writeguide', false)
      displayDom('.btn-side-chatdoc-contentbox', false)
      getElement('.tip-box')?.[0]?.remove()
    }, 1000)
  }

  // operate 底部操作是否固定
  function operate(checked) {
    let operateDom = getElement('#operate')
    if (operateDom && operateDom.length !== 0) {
      setTimeout(() => {
        operateDom[0].style.bottom = '0px'
        operateDom[0].style.position = checked ? 'fixed' : 'inherit'
      })
    }
  }

  // 详情页面处理H5
  function csdnDeatilH5() {
    // let loginDom = getElement('.passport-login-container')
    let recommendList = getElement('.container-fluid')
    recommendList.forEach(item => {
      item.addEventListener('click', (e) => {
        e.stopPropagation()
        window.open(e.currentTarget.attributes['data-url'].nodeValue)
      })
    })

    let readall_box = getElement('.readall_box')
    if (readall_box) {
      readall_box[0].remove()
      getElement('.article_content')[0].style.height = 'inherit'
    }
  }

  // 详情页面处理PC
  function csdnDeatilPc() {
  }

  // {
  //   // (!ISH5 && CURRENTPAGES == 2) ? setAside() : '' // 点击之后进行判断是不是没有右侧的侧边栏了
  //
  //   let mainDom = getElement('.main_father')[0]
  //   mainDom.classList.remove('justify-content-center')
  //   addCss('main', {
  //     "flex": "1",
  //     "margin-right": "10px"
  //   })
  //
  //   // 设置右侧边栏
  //   // let blog_container_aside = getElement('.blog_container_aside')[0]
  //   // var observe = new MutationObserver((list) => {
  //   //   blog_container_aside.style['position'] = 'relative'
  //   //   blog_container_aside.style['left'] = '0'
  //   //   blog_container_aside.style['width'] = asideWidth
  //   // })
  //   // observe.observe(blog_container_aside, { attributes: true });
  //
  //   // 设置底部关注一栏
  //   let toolbar = getElement('.left-toolbox')[0]
  //   toolbar.classList.add('observeToolbar')
  //
  //   let observeToolbar = new MutationObserver((list) => {
  //     list.forEach(item => {
  //       item.target.classList.add('observeToolbar')
  //       observeToolbar.disconnect();
  //     })
  //   })
  //   observeToolbar.observe(toolbar, { attributes: true })
  //
  //   // 去除剪贴板劫持
  //   csdn.copyright.init("", "", "");
  //
  //   // 删除原始的右侧
  //   let rightDom = getElement('.recommend-right')
  //   rightDom && rightDom[0].remove()
  //
  //   // 关注博主才能查看
  //   let focusUP = getElement('.hide-article-box')
  //   if (focusUP && focusUP.length !== 0) {
  //     focusUP[0].remove()
  //     getElement('#article_content')[0].style.height = 'inherit'
  //   }
  //   setTimeout(() => {
  //     setAside() // 判断右侧是否有悬浮
  //   }, 1000)
  // }

  function CSDNRightNav() {
    document.getElementById()
  }

  // ------处理搜索列表---------
  // 列表页是否平铺展示
  function blogNav(checked) {

    if (checked) {
      getElement('.home_wrap')[0].style.width = '95vw'
      getElement('.blog-content')[0].style.width = '75vw'
    } else {
      getElement('.home_wrap')[0].style.width = '70vw'
      getElement('.blog-content')[0].style.width = '50vw'
    }
  }

  function soPc(checked) {
    setTimeout(() => {
      let mainDom = getElement('.clearfix')[0]
      checked ? mainDom.classList.remove('main') : mainDom.setAttribute('class', 'main clearfix')
    }, 100)
  }

  // -------- 主函数 -------------
  function mainInit() {
    // 获取url地址 判断是那个网站
    let urlObject = initUrl()
    jumpLink()

    if (!urlObject) {
      return
    }

    // 不同平台是不是H5
    switch (urlObject.platform) {
      case 'CSDN':
        ISH5 = CSDNIsH5OrPC('.csdn-toolbar');
        break;
      // case 'ZhiHu': ISH5 = ZhihuIsH5OrPC('')
      default:
        ISH5 = false
    }
    log(CURRENTPAGES)
    if (CURRENTPAGES && !BLOGUICONFIG[CURRENTPAGES][ISH5 ? 'h5' : 'pc']) {
      log(`当前页面无优化,如果需要请联系作者`)
      return
    }
    // 生成主窗口
    domHtml(urlObject)
    generalCetch()
    fixMainThumbtack();

    // 进行刷新这之后的设置
    BLOGUICONFIG[CURRENTPAGES][ISH5 ? 'h5' : 'pc'].forEach(configItem => {
      configItem.children.forEach(item => {

        // 如果有事件那就去单独执行 否则就是 默认隐藏
        if (item.getEvent && !['button'].includes(item.type)) {
          if (item.type === 'radio' && !item.checked) {
            return
          } else {
            eval(`${item.getEvent}(${item.checked}, '${item.domId}')`)
          }
        } else {
          setTimeout(() => {
            displayDom(item.domId, item.checked)
          }, 500)
        }
      })
    })

    switch (urlObject.platform) {
      case 'CSDN':
        CSDNOoptimiz(urlObject.key);
        break;
      case 'Juejin':
        JuejinOptimiz(urlObject.key);
        break;
      case 'ZhiHu':
        ZhihuOptimiz(urlObject.key);
        break;
    }
    // 生成附加信息
    //appendDom()
    initMainEvent()
    // getOnileUser()

    log(`当前正在优化 ${urlObject.title}  使用愉快!有问题请联系作者`)

  }

  log(`脚本启动成功, 欢迎使用${TITLE} 版本:${VERSION}`)

  // window.onload = () => {
  mainInit()
})();