1
0
Files
MCdoc_js/MCdoc.user.js
2025-07-15 20:19:12 +08:00

172 lines
8.7 KiB
JavaScript
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

// ==UserScript==
// @name 中国版我的世界开发者文档 美化
// @namespace https://git.xjyofc.top/xjy/MCdoc_js
// @updateURL https://git.xjyofc.top/xjy/MCdoc_js/raw/branch/main/MCdoc.js
// @downloadURL https://git.xjyofc.top/xjy/MCdoc_js/raw/branch/main/MCdoc.js
// @version 2.0
// @description 更好的中国版我的世界开发者文档界面
// @author 仙君御
// @match https://mc.163.com/dev/*
// @icon 
// @grant none
// ==/UserScript==
(function() {
'use strict';
// 新样式
function newUI(){
const navBar = document.querySelector('.nav-bar');
const header = document.querySelector('header.navbar.fixed-navbar');
const searchBtn = document.querySelector('.search-btn');
const searchBox = document.querySelector('.search-box');
const searchCont = document.querySelector('.search-cont');
const themeContent = document.querySelector('.theme-default-content');
const sidebar = document.querySelector('.sidebar');
const page = document.querySelector('.page');
if (navBar) {navBar.style.top = '0';}
if (header) {header.style.top = '0';}
if (searchBtn) { searchBtn.style.width = '60px';}
if (searchBox) {searchBox.style.width = 'auto';}
if (themeContent) { themeContent.style.borderRadius = '8px'; }
if (searchCont && header) {
searchCont.style.width = 'auto';
searchCont.style.position = 'fixed';
searchCont.style.top = '22px';
searchCont.style.left = '50%';
searchCont.style.transform = 'translateX(-90%)';
header.appendChild(searchCont);
}
if (sidebar) {
sidebar.style.top = '75px';
sidebar.style.height = '-webkit-fill-available';
sidebar.style.removeProperty('display');
}
if (page) {
page.style.boxShadow = '0 0 10px rgba(0, 0, 0, 0.1)';
page.style.borderRadius = '8px';
}
}
// 动态隐藏元素
function hide() {
const pageTop = document.querySelector('.page-top');
const pageTopFixed = document.querySelector('.page-top-fixed');
const pageTopboth = document.querySelector('.page-top-fixed.page-top');
const navBtn = document.querySelector('.nav-btn');
const btnCont = document.querySelector('.btn-cont');
const openRight = document.querySelector('.open-right');
const page = document.querySelector('.page');
const footer = document.querySelector('.footer');
const feedbackBtn = document.querySelector('.btn.feedback');
const hideSide = document.querySelector('.hide-side');
const nietopbar = document.getElementById('NIE-topBar');
if (pageTop) { pageTop.style.display = 'none'; }
if (pageTopFixed) {pageTopFixed.style.display = 'none';}
if (pageTopboth) {pageTopboth.style.display = 'none';}
if (page) {page.style.paddingTop = '0';}
if (navBtn) {navBtn.style.display = 'none';}
if (btnCont) {btnCont.style.display = 'none';}
if (openRight) {openRight.style.display = 'none';}
if (footer) {footer.style.display = 'none';}
if (feedbackBtn) {feedbackBtn.style.display = 'none';}
if (hideSide) { hideSide.style.display = 'none';}
if (nietopbar) {nietopbar.style.display = 'none';}
}
// 页面布局修复
function fix() {
const page = document.querySelector('.page');
if (page) {
page.style.paddingTop = '0';
page.style.flex = '0';
page.style.marginLeft = 'auto';
page.style.width = '67%';
page.style.overflow = 'visible';
}
const pageContent = document.querySelector('.page-container');
if (pageContent) {
pageContent.style.display = 'block';
}
// 设置html宽度为浏览器窗口实际大小
const htmlElement = document.documentElement;
if (htmlElement) {
htmlElement.style.width = window.innerWidth + 'px';
htmlElement.style.minWidth = window.innerWidth + 'px';
htmlElement.style.transform = 'none';
// 确保不出现横向滚动条
htmlElement.style.overflowX = 'hidden';
}
// 设置body元素宽度
if (document.body) {
document.body.style.width = window.innerWidth + 'px';
}
// 设置id为app的元素宽度
const appElement = document.getElementById('app');
if (appElement) {
appElement.style.width = window.innerWidth + 'px';
}
}
// 创建urlmenu菜单
function Menu() {
const header = document.querySelector('header.navbar.fixed-navbar');
const urlMenu = document.createElement('div');
urlMenu.className = 'urlmenu';
urlMenu.innerHTML = `
<a href="https://mc.163.com/dev/apidocs.html">API文档</a>
<a href="https://mc.163.com/dev/guide.html">开发指南</a>
<a href="https://mc.163.com/dev/course.html">教学课程</a>
<a href="https://mc.163.com/dev/newslist.html">新闻与活动</a>
<a href="https://mc.163.com/dev/help.html">帮助中心</a>
<a href="https://mcdev.webapp.163.com/#/feedbackModal?target=browser" target="_blank">问题反馈</a>
<a href="https://adl.netease.com/d/g/mc/c/dev">MCStudio</a>
`;
// 设置菜单样式
urlMenu.style.position = 'fixed';
urlMenu.style.right = '20px';
urlMenu.style.top = '15px';
urlMenu.style.padding = '10px';
urlMenu.style.borderRadius = '5px';
// urlMenu.style.backgroundColor = 'rgba(0, 0, 0, 0)';
// 添加到navbar fixed-navbar中
if (header) {header.appendChild(urlMenu);}
}
// 注册功能函数
function mian() {
hide();
Menu();
newUI();
fix();
}
// 监听在页面和脚本渲染完成后
document.addEventListener('DOMContentLoaded', function() {
mian();
});
// 监听窗口大小变化
window.addEventListener('resize', function() {
mian();
})
// 监听页面滚动事件
window.addEventListener('scroll', function() {
mian();
});
// 监听文档加载状态变化(开始渲染时)
document.addEventListener('readystatechange', function() {
// interactive表示DOM已加载但资源可能未完成complete表示所有资源加载完成
if (document.readyState === 'interactive' || document.readyState === 'complete') {
mian();
}
});
})();