论坛的能量在哪里查看呀? 好久没上来了,发现论坛完全改版了

论坛的能量在哪里查看呀? 好久没上来了,发现论坛完全改版了

2 个赞

我之前也找了好久
点开个人主页,右上角,展开
就能看到了

1 个赞

你可以在帖子里面点击自己的头像

也可以右上角点击自己头像==》右侧边栏最下面的个人资料==》总结的信息里查看

最后也可以添加个油猴脚本来显示在论坛右上角

image

油猴脚本
// ==UserScript==
// @name         NodeLoc 导航栏能量显示
// @namespace    http://tampermonkey.net/
// @icon         
// @version      0.5
// @description  在导航栏显示能量数值(图标前置+黑色透明样式)
// @author       You & Hiram
// @match        https://nodeloc.cc/*
// @match        https://nodeloc.com/*
// @run-at       document-end
// @grant        GM_addStyle
// @connect      nodeloc.cc
// @connect      nodeloc.com
// ==/UserScript==

(function () {
  "use strict";

  // 创建导航栏元素
  function createEnergyDisplayItem() {
    const li = document.createElement("li");
    li.className = "header-dropdown-toggle energy-display";

    li.innerHTML = `
      <div class="energy-display-container">
        <div class="left">
          <svg width="24" height="24" viewBox="0 0 48 48" fill="none" xmlns="http://www.w3.org/2000/svg" class="fa d-icon d-icon-calendar-check svg-icon svg-string">
            <path d="M31 4H16L10 27H18L14 44L40 16H28L31 4Z" fill="none" stroke="#9b9b9b" stroke-width="4" stroke-linecap="round" stroke-linejoin="round"/>
            <path d="M21 11L19 19" stroke="#9b9b9b" stroke-width="4" stroke-linecap="round"/>
          </svg>
        </div>
        <div class="right">
          <div class="title">能量值</div>
          <div class="value">加载中...</div>
        </div>
      </div>
    `;

    // 插入到导航栏第一个位置
    const navBar = document.querySelector("ul.d-header-icons");
    if (navBar) {
      navBar.insertBefore(li, navBar.firstChild);
      return li.querySelector(".value");
    }
    return null;
  }

  // 创建样式
  function createEnergyDisplayStyle() {
    GM_addStyle(`
      .energy-display {
      }
      .energy-display .energy-display-container {
        box-sizing: content-box;
        -webkit-appearance: none;
        appearance: none;
        position: relative;
        display: flex;
        align-items: center;
        justify-content: center;
        height: 2.2857em;
        padding: .2143em;
        text-decoration: none;
        cursor: pointer;
        border: 1px solid rgba(0, 0, 0, 0);
        outline: none;
        gap: 0.2143em;
        color: var(--header_primary-low-mid);
      }
      .energy-display .energy-display-container .left svg path {
        stroke: var(--header_primary-low-mid);
      }
      .energy-display .energy-display-container .right {
        font-size: 18px;
        line-height: 1.2;
        display: flex;
        flex-direction: column;
        align-items: flex-end;
      }
      .energy-display .energy-display-container .right .title {
        font-size: 12px;
      }
      .energy-display .energy-display-container .right .value {
        font-size: 16px;
        font-weight: bold;
        opacity: 1;
      }
    `);
  }

  function xhrRequest(options) {
    const {
      url,
      method = "GET",
      headers = {},
      body = null,
      withCredentials = false,
      responseType = "text",
    } = options;

    const xhr = new XMLHttpRequest();
    xhr.open(method, url);
    xhr.withCredentials = withCredentials;
    xhr.responseType = responseType;

    if (Object.keys(headers).length) {
      for (const [key, value] of Object.entries(headers)) {
        xhr.setRequestHeader(key, value);
      }
    }

    return new Promise((resolve, reject) => {
      xhr.onload = () => {
        const code = xhr.status;
        if (code >= 200 && code <= 299) {
          resolve(xhr.response);
        } else {
          reject(new Error(`Network Error: ${code}`));
        }
      };

      xhr.onerror = () => {
        reject(new Error("Network Error"));
      };

      xhr.ontimeout = () => {
        reject(new Error("Request timed out"));
      };

      if (!["get"].includes(method.toLowerCase())) {
        xhr.send(body);
      } else {
        xhr.send();
      }
    });
  }

  // 获取并更新能量值
  async function updateEnergyValue(displayElement) {
    xhrRequest({
      url: "https://nodeloc.cc/leaderboard/1.json",
      method: "GET",
      headers: {
        "Content-Type": "application/json",
      },
      withCredentials: true,
      responseType: "json",
    }).then((res) => {
      if (displayElement) {
        displayElement.textContent = res.personal.user.total_score.toString();
      }
    }).catch((err) => {
      console.error('TampermonKey-NodeLoc-xhrRequest', err.message);
      handleError(displayElement);
    });

    // GM_xmlhttpRequest({
    //   method: "GET",
    //   url: "https://nodeloc.cc/leaderboard/1.json",
    //   withCredentials: true,
    //   onload: function (response) {
    //     try {
    //       const data = JSON.parse(response.responseText);
    //       if (displayElement) {
    //         displayElement.textContent =
    //           data.personal.user.total_score.toLocaleString();
    //       }
    //     } catch (err) {
    //       console.error('TampermonKey-NodeLoc-RespParse',err.message);
    //       handleError(displayElement);
    //     }
    //   },
    //   onerror: function (err) {
    //     console.error('TampermonKey-NodeLoc-xhrRequest',err.message);
    //     handleError(displayElement);
    //   },
    // });
  }

  // 错误处理
  function handleError(displayElement) {
    if (displayElement) {
      displayElement.textContent = "--";
    }
  }

  // 等待导航栏加载
  const observer = new MutationObserver(() => {
    const navBar = document.querySelector("ul.d-header-icons");

    if (navBar) {
      observer.disconnect();
      createEnergyDisplayStyle();
      const displayElement = createEnergyDisplayItem();

      if (displayElement) {
        // 初始加载
        updateEnergyValue(displayElement);
        // 每30秒刷新
        setInterval(() => updateEnergyValue(displayElement), 30000);
      }
    }
  });

  observer.observe(document, {
    childList: true,
    subtree: true,
  });
})();
4 个赞

好的 感谢佬

好的 感谢佬

大佬,这个脚本问你下是你写的吗?如果是的话我能否拿去整合成一个NL增强脚本?
提供下开源协议谢谢 :smiley:

不是我写的,也是网上搜到的~

1 个赞