卡厄思
梦
境
菜单
首页
回到首页
WIKI工具
全站样式
全站JS
修改导航栏
测试
沙盒
可视化管理器
战斗员管理器
卡牌管理器
伙伴管理器
装备管理器
词典管理器
图鉴
战斗员
伙伴
装备
怪物卡牌
中立卡牌
词典
小工具
配队模拟器
节奏榜生成器
搜索
链入页面
相关更改
特殊页面
页面信息
最近更改
登录
MediaWiki
查看“︁Common.js”︁的源代码
←
MediaWiki:Common.js
因为以下原因,您没有权限编辑该页面:
您请求的操作仅限属于该用户组的用户执行:
用户
此页面为本wiki上的软件提供界面文本,并受到保护以防止滥用。 如欲修改所有wiki的翻译,请访问
translatewiki.net
上的MediaWiki本地化项目。
您无权编辑此JavaScript页面,因为编辑此页面可能会影响所有访问者。
您可以查看和复制此页面的源代码。
/* 这里的任何JavaScript将为所有用户在每次页面加载时加载。 */ /* 卡牌 */ (function () { 'use strict'; var initialized = false; function show(el) { if (el) el.style.display = 'flex'; } function hide(el) { if (el) el.style.display = 'none'; } function resetModalView(modal) { var originalView = modal.querySelector('.original-card-view'); var inspirationView = modal.querySelector('.inspiration-view'); var godView = modal.querySelector('.god-inspiration-view'); var subcardsView = modal.querySelector('.subcards-view'); var nestedSubcardsViews = modal.querySelectorAll('.nested-subcards-view'); var inspirationNestedViews = modal.querySelectorAll('.inspiration-subcards-view'); var inspirationDeeperNestedViews = modal.querySelectorAll('.inspiration-nested-subcards-view'); if (originalView) show(originalView); if (inspirationView) hide(inspirationView); if (godView) hide(godView); if (subcardsView) hide(subcardsView); nestedSubcardsViews.forEach(hide); inspirationNestedViews.forEach(hide); inspirationDeeperNestedViews.forEach(hide); } function closeModal(modal) { modal.style.display = 'none'; document.body.style.overflow = 'auto'; resetModalView(modal); } function openModalFromCard(cardWrapper) { var cardId = cardWrapper.getAttribute('data-card-id'); if (!cardId) return; var modal = document.getElementById(cardId + '-modal'); if (!modal) return; resetModalView(modal); modal.style.display = 'block'; document.body.style.overflow = 'hidden'; } function handleBackToCard(button) { var modal = button.closest('.card-modal'); if (modal) { resetModalView(modal); } } function handleBackToSubcards(button) { var modal = button.closest('.card-modal'); if (!modal) return; var nestedView = button.closest('.nested-subcards-view'); var subcardsView = modal.querySelector('.subcards-view'); if (nestedView && subcardsView) { hide(nestedView); show(subcardsView); } } function handleInspirationClick(button) { var modal = button.closest('.card-modal'); if (!modal) return; var originalView = modal.querySelector('.original-card-view'); var inspirationView = modal.querySelector('.inspiration-view'); if (!originalView || !inspirationView) return; hide(originalView); show(inspirationView); } function handleGodInspirationClick(button) { var modal = button.closest('.card-modal'); if (!modal) return; var originalView = modal.querySelector('.original-card-view'); var godView = modal.querySelector('.god-inspiration-view'); if (!originalView || !godView) return; hide(originalView); show(godView); } function handleSubcardsClick(button) { var modal = button.closest('.card-modal'); if (!modal) return; var originalView = modal.querySelector('.original-card-view'); var subcardsView = modal.querySelector('.subcards-view'); if (!originalView || !subcardsView) return; hide(originalView); show(subcardsView); } function handleViewNestedSubcardsClick(button) { var modal = button.closest('.card-modal'); if (!modal) return; var subcardIndex = button.getAttribute('data-subcard-index'); if (!subcardIndex) return; var subcardsView = modal.querySelector('.subcards-view'); var nestedView = modal.querySelector('.nested-subcards-view[data-subcard-index="' + subcardIndex + '"]'); if (!subcardsView || !nestedView) return; hide(subcardsView); show(nestedView); } function handleInspirationSubcardsClick(button) { var modal = button.closest('.card-modal'); if (!modal) return; var idx = button.getAttribute('data-variant-index'); if (!idx) return; var inspirationView = modal.querySelector('.inspiration-view'); var nestedView = modal.querySelector('.inspiration-subcards-view[data-variant-index="' + idx + '"]'); if (!inspirationView || !nestedView) return; hide(inspirationView); show(nestedView); } function handleBackToInspiration(button) { var modal = button.closest('.card-modal'); if (!modal) return; var nestedView = button.closest('.inspiration-subcards-view'); var inspirationView = modal.querySelector('.inspiration-view'); if (nestedView && inspirationView) { hide(nestedView); show(inspirationView); } } function handleViewInspirationNestedSubcardsClick(button) { var modal = button.closest('.card-modal'); if (!modal) return; var vIdx = button.getAttribute('data-variant-index'); var sIdx = button.getAttribute('data-subcard-index'); if (!vIdx || !sIdx) return; var subcardsView = modal.querySelector('.inspiration-subcards-view[data-variant-index="' + vIdx + '"]'); var deeperView = modal.querySelector('.inspiration-nested-subcards-view[data-variant-index="' + vIdx + '"][data-subcard-index="' + sIdx + '"]'); if (!subcardsView || !deeperView) return; hide(subcardsView); show(deeperView); } function handleBackToInspirationSubcards(button) { var modal = button.closest('.card-modal'); if (!modal) return; var deeperView = button.closest('.inspiration-nested-subcards-view'); var vIdx = button.getAttribute('data-variant-index'); var subcardsView = modal.querySelector('.inspiration-subcards-view[data-variant-index="' + vIdx + '"]'); if (deeperView && subcardsView) { hide(deeperView); show(subcardsView); } } function onKeydown(event) { if (event.key === 'Escape' || event.keyCode === 27) { var modals = document.querySelectorAll('.card-modal'); modals.forEach(function (modal) { if (modal.style.display === 'block') { var inspirationView = modal.querySelector('.inspiration-view'); var godView = modal.querySelector('.god-inspiration-view'); var subcardsView = modal.querySelector('.subcards-view'); var nestedSubcardsViews = modal.querySelectorAll('.nested-subcards-view'); var inspirationNestedViews = modal.querySelectorAll('.inspiration-subcards-view'); var inspirationDeeperNestedViews = modal.querySelectorAll('.inspiration-nested-subcards-view'); var inNestedView = false; nestedSubcardsViews.forEach(function (view) { if (view.style.display !== 'none') { inNestedView = true; hide(view); if (subcardsView) show(subcardsView); } }); var inInspirationNested = false; inspirationNestedViews.forEach(function (view) { if (view.style.display !== 'none') { inInspirationNested = true; hide(view); if (inspirationView) show(inspirationView); } }); var inInspirationDeeperNested = false; inspirationDeeperNestedViews.forEach(function (view) { if (view.style.display !== 'none') { inInspirationDeeperNested = true; var vIdx = view.getAttribute('data-variant-index'); hide(view); var parentSubcardsView = modal.querySelector('.inspiration-subcards-view[data-variant-index="' + vIdx + '"]'); if (parentSubcardsView) show(parentSubcardsView); } }); if (!inNestedView && !inInspirationNested && !inInspirationDeeperNested) { if ((inspirationView && inspirationView.style.display !== 'none') || (subcardsView && subcardsView.style.display !== 'none') || (godView && godView.style.display !== 'none')) { resetModalView(modal); } else { closeModal(modal); } } } }); } } function onDocumentClick(e) { // 打开模态:点击卡片缩略图区域 var cardWrapper = e.target.closest('.card-small-wrapper'); if (cardWrapper) { e.preventDefault(); e.stopPropagation(); openModalFromCard(cardWrapper); return; } // 变体/衍生/返回/关闭 if (e.target.classList.contains('inspiration-button')) { e.stopPropagation(); handleInspirationClick(e.target); return; } if (e.target.classList.contains('god-inspiration-button')) { e.stopPropagation(); handleGodInspirationClick(e.target); return; } if (e.target.classList.contains('subcards-button')) { e.stopPropagation(); handleSubcardsClick(e.target); return; } if (e.target.classList.contains('view-nested-subcards-button')) { e.stopPropagation(); handleViewNestedSubcardsClick(e.target); return; } if (e.target.classList.contains('back-to-card-button')) { e.stopPropagation(); handleBackToCard(e.target); return; } if (e.target.classList.contains('back-to-subcards-button')) { e.stopPropagation(); handleBackToSubcards(e.target); return; } if (e.target.classList.contains('view-insp-subcards-button')) { e.stopPropagation(); handleInspirationSubcardsClick(e.target); return; } if (e.target.classList.contains('back-to-inspiration-button')) { e.stopPropagation(); handleBackToInspiration(e.target); return; } if (e.target.classList.contains('view-insp-nested-subcards-button')) { e.stopPropagation(); handleViewInspirationNestedSubcardsClick(e.target); return; } if (e.target.classList.contains('back-to-insp-subcards-button')) { e.stopPropagation(); handleBackToInspirationSubcards(e.target); return; } // 关闭按钮 var closeBtn = e.target.classList.contains('modal-close-button') ? e.target : (e.target.parentElement && e.target.parentElement.classList.contains('modal-close-button') ? e.target.parentElement : null); if (closeBtn) { var modal = closeBtn.closest('.card-modal'); if (modal) closeModal(modal); } } function init() { if (initialized) return; initialized = true; document.addEventListener('click', onDocumentClick); document.addEventListener('keydown', onKeydown); } if (document.readyState === 'loading') { document.addEventListener('DOMContentLoaded', init); } else { init(); } if (typeof mw !== 'undefined' && mw.hook) { // 页面增量渲染时确保已初始化(事件委托只需一次) mw.hook('wikipage.content').add(function () { init(); }); } })(); // 卡牌悬停显示功能 (function () { 'use strict'; var hoverTimeout; function showCardPopup(linkElement) { // 清除之前的超时 if (hoverTimeout) { clearTimeout(hoverTimeout); } // 检查是否已有弹出框 var existingPopup = linkElement.querySelector('.card-hover-popup'); if (existingPopup) { return; } // 查找紧邻的隐藏数据容器 var dataContainer = linkElement.nextElementSibling; if (!dataContainer || !dataContainer.classList.contains('card-link-data')) { return; } // 在隐藏容器中查找卡牌 var cardWrapper = dataContainer.querySelector('.card-small-wrapper'); if (!cardWrapper) { return; } // 克隆卡牌 var clonedCard = cardWrapper.cloneNode(true); clonedCard.style.cursor = 'default'; // 移除可能触发模态框的属性和类 clonedCard.removeAttribute('data-card-id'); var originalClass = clonedCard.className; clonedCard.className = originalClass.replace('card-small-wrapper', 'card-hover-preview'); // 创建弹出框 var popup = document.createElement('div'); popup.className = 'card-hover-popup'; popup.appendChild(clonedCard); // 添加到链接中 linkElement.appendChild(popup); } function hideCardPopup(linkElement) { hoverTimeout = setTimeout(function () { var popup = linkElement.querySelector('.card-hover-popup'); if (popup) { popup.remove(); } }, 100); } function initCardLinks() { var cardLinks = document.querySelectorAll('.card-link'); cardLinks.forEach(function (link) { // 避免重复绑定 if (link.hasAttribute('data-card-hover-init')) { return; } link.setAttribute('data-card-hover-init', 'true'); // 添加事件监听器 link.addEventListener('mouseenter', function () { showCardPopup(link); }); link.addEventListener('mouseleave', function () { hideCardPopup(link); }); }); } // 初始化 function init() { initCardLinks(); } if (document.readyState === 'loading') { document.addEventListener('DOMContentLoaded', init); } else { init(); } // MediaWiki 钩子支持 if (typeof mw !== 'undefined' && mw.hook) { mw.hook('wikipage.content').add(init); } })(); /* 切换标签 */ (function() { 'use strict'; function initTabSwitcher() { var tabContainers = document.querySelectorAll('.resp-tabs'); tabContainers.forEach(function(container) { var tabButtons = container.querySelectorAll('.czn-list-style'); if (tabButtons.length === 0) return; var tabContents = container.querySelectorAll('.resp-tab-content'); // 初始化 tabButtons.forEach(function(button, index) { button.classList.toggle('active', index === 0); }); if (tabContents.length > 0) { tabContents.forEach(function(content, index) { content.style.display = index === 0 ? 'block' : 'none'; }); } // 点击事件 tabButtons.forEach(function(button, index) { button.addEventListener('click', function(e) { e.preventDefault(); // 更新标签状态 tabButtons.forEach(function(btn, i) { btn.classList.toggle('active', i === index); }); // 切换内容 if (tabContents.length > 0) { tabContents.forEach(function(content, i) { content.style.display = i === index ? 'block' : 'none'; }); } }); }); }); } // 初始化 if (document.readyState === 'loading') { document.addEventListener('DOMContentLoaded', initTabSwitcher); } else { initTabSwitcher(); } })(); /* 角色立绘切换 */ $(document).ready(function() { // 使用事件委托来确保动态内容也能响应 $(document).on('click', '.character-switch-btn', function() { // 如果点击的是已经激活的按钮,不执行任何操作 if ($(this).hasClass('active')) { return; } var targetType = $(this).attr('data-target'); var container = $(this).closest('#character-container'); var imageWrapper = container.find('.character-image-wrapper'); var allImages = imageWrapper.find('.character-image'); // 先将所有图片淡出 allImages.each(function() { $(this).css('opacity', '0'); }); // 延迟后切换显示状态 setTimeout(function() { allImages.each(function() { $(this).css('display', 'none'); }); // 显示目标图片 imageWrapper.find('[data-image-type="' + targetType + '"]').each(function() { $(this).css('display', 'block'); // 强制重绘 $(this)[0].offsetHeight; $(this).css('opacity', '1'); }); }, 300); // 更新按钮样式 container.find('.character-switch-btn').each(function() { $(this).removeClass('active'); $(this).css({ 'background': 'rgba(0,0,0,0.5)', 'cursor': 'pointer' }); }); // 设置当前按钮为激活状态 $(this).addClass('active'); $(this).css({ 'background': 'rgba(70, 130, 255, 0.8)', 'cursor': 'default' }); }); // 鼠标悬停效果(仅对非激活按钮有效) $(document).on('mouseenter', '.character-switch-btn:not(.active)', function() { $(this).css('background', 'rgba(70, 130, 255, 0.5)'); }); $(document).on('mouseleave', '.character-switch-btn:not(.active)', function() { $(this).css('background', 'rgba(0,0,0,0.5)'); }); }); /* 悬浮目录 */ $(document).ready(function() { // 只在有目录的页面上执行 if ($('.toc').length > 0) { // 创建侧边目录 var $sidebar = $('<div id="toc-sidebar"><div id="toc-sidebar-trigger">展开目录</div><div id="toc-sidebar-content"></div></div>'); $('body').append($sidebar); // 提取并修复目录内容 var tocUl = $('<ul></ul>'); // 避免重复的目录项 var processedItems = new Set(); // 从原始目录构建新目录 $('.toc ul li').each(function() { var $link = $(this).find('a').first(); var href = $link.attr('href'); var $number = $link.find('.tocnumber').first(); var $text = $link.find('.toctext').first(); // 创建唯一标识符,避免重复添加 var itemId = $number.text() + '-' + $text.text(); if (!processedItems.has(itemId)) { processedItems.add(itemId); // 创建新的目录项 var $li = $('<li></li>'); var $newLink = $('
').attr('href', href); // 如果有编号,则添加编号 if ($number.length) { $newLink.append($('<span class="tocnumber"></span>').text($number.text())); $newLink.append(' '); } $newLink.append($('<span class="toctext"></span>').text($text.text())); $li.append($newLink); tocUl.append($li); } }); $('#toc-sidebar-content').append(tocUl); // 点击展开/折叠事件处理 $('#toc-sidebar-trigger').click(function() { $('#toc-sidebar').toggleClass('expanded'); // 根据展开/折叠状态更改按钮文字 if ($('#toc-sidebar').hasClass('expanded')) { $('#toc-sidebar-trigger').text('隐藏目录'); } else { $('#toc-sidebar-trigger').text('展开目录'); } }); } }); /* 词典Tooltip */ (function() { var tooltipContainer = null; var currentTerm = null; var hideTimeout = null; // 初始化 $(function() { // 创建全局 tooltip 容器 tooltipContainer = $('<div class="dictionary-tooltip-container"></div>'); $('body').append(tooltipContainer); // 鼠标进入词条 $(document).on('mouseenter', '.dictionary-term', function(e) { var $term = $(this); currentTerm = $term; // 清除隐藏定时器 if (hideTimeout) { clearTimeout(hideTimeout); hideTimeout = null; } // 获取 tooltip 内容 var content = $term.attr('data-tooltip-content'); if (!content) return; // 设置内容 tooltipContainer.html(content); // 计算位置 updateTooltipPosition($term); // 显示 tooltip tooltipContainer.addClass('active'); }); // 鼠标离开词条 $(document).on('mouseleave', '.dictionary-term', function() { hideTimeout = setTimeout(function() { tooltipContainer.removeClass('active'); currentTerm = null; }, 100); }); // 鼠标进入 tooltip(防止快速隐藏) tooltipContainer.on('mouseenter', function() { if (hideTimeout) { clearTimeout(hideTimeout); hideTimeout = null; } }); // 鼠标离开 tooltip tooltipContainer.on('mouseleave', function() { hideTimeout = setTimeout(function() { tooltipContainer.removeClass('active'); currentTerm = null; }, 100); }); // 窗口滚动时更新位置 $(window).on('scroll resize', function() { if (currentTerm && tooltipContainer.hasClass('active')) { updateTooltipPosition(currentTerm); } }); }); // 更新 tooltip 位置 function updateTooltipPosition($term) { var rect = $term[0].getBoundingClientRect(); var scrollTop = $(window).scrollTop(); var scrollLeft = $(window).scrollLeft(); // 基本位置:词条下方 var top = rect.bottom + scrollTop + 2; var left = rect.left + scrollLeft; // 获取 tooltip 尺寸 var tooltipWidth = 250; // 固定宽度 var tooltipHeight = tooltipContainer.outerHeight(); // 获取窗口尺寸 var windowWidth = $(window).width(); var windowHeight = $(window).height(); // 检查右边界 if (left + tooltipWidth > windowWidth + scrollLeft) { left = Math.max(scrollLeft, rect.right + scrollLeft - tooltipWidth); } // 检查下边界 if (rect.bottom + tooltipHeight > windowHeight) { // 如果下方空间不足,显示在上方 if (rect.top - tooltipHeight > 0) { top = rect.top + scrollTop - tooltipHeight - 2; } } // 设置位置 tooltipContainer.css({ top: top + 'px', left: left + 'px' }); } })(); /* 轮播图 */ (function () { 'use strict'; function initCarousel(root) { if (!root || root.__inited) return; root.__inited = true; const wrapper = root.querySelector('.carousel-wrapper'); const slides = Array.from(root.querySelectorAll('.carousel-slide')); const titles = Array.from(root.querySelectorAll('.carousel-title-item')); const btnPrev = root.querySelector('.carousel-prev'); const btnNext = root.querySelector('.carousel-next'); if (!wrapper || !slides.length) { root.style.display = 'none'; return; } // 单张图隐藏按钮 if (slides.length === 1) { root.classList.add('single'); } // 标题索引与幻灯索引对齐 titles.forEach((t, i) => { t.dataset.slide = String(i); }); let index = 0; let timer = null; const autoplay = (root.getAttribute('data-autoplay') || '1') !== '0'; const interval = Math.max(1500, parseInt(root.getAttribute('data-interval') || '4000', 10) || 4000); function update() { wrapper.style.transform = 'translateX(' + (-index * 100) + '%)'; titles.forEach((t, i) => { if (i === index) t.classList.add('active'); else t.classList.remove('active'); const text = t.querySelector('.title-text'); const ind = t.querySelector('.title-indicator'); if (text) text.style.opacity = i === index ? '1' : '0.75'; if (ind) ind.style.background = i === index ? '#ff6600' : 'transparent'; }); } function next() { index = (index + 1) % slides.length; update(); } function prev() { index = (index - 1 + slides.length) % slides.length; update(); } // 标题点击 titles.forEach((t) => { t.addEventListener('click', function () { const i = parseInt(t.dataset.slide || '0', 10) || 0; index = Math.min(Math.max(i, 0), slides.length - 1); update(); restartAutoplay(); }); }); // 按钮点击 if (btnPrev) { btnPrev.addEventListener('click', function () { prev(); restartAutoplay(); }); } if (btnNext) { btnNext.addEventListener('click', function () { next(); restartAutoplay(); }); } // 自动播放控制 function startAutoplay() { if (!autoplay || slides.length <= 1) return; stopAutoplay(); timer = setInterval(next, interval); } function stopAutoplay() { if (timer) { clearInterval(timer); timer = null; } } function restartAutoplay() { stopAutoplay(); startAutoplay(); } // 悬停/聚焦暂停 root.addEventListener('mouseenter', stopAutoplay); root.addEventListener('mouseleave', startAutoplay); root.addEventListener('focusin', stopAutoplay); root.addEventListener('focusout', startAutoplay); // 触摸滑动 let startX = 0; let curX = 0; let dragging = false; const threshold = 30; root.addEventListener( 'touchstart', function (e) { if (!e.touches || !e.touches.length) return; startX = e.touches[0].clientX; curX = startX; dragging = true; root.classList.add('grabbing'); stopAutoplay(); }, { passive: true } ); root.addEventListener( 'touchmove', function (e) { if (!dragging || !e.touches || !e.touches.length) return; curX = e.touches[0].clientX; const dx = curX - startX; wrapper.style.transform = 'translateX(calc(' + (-index * 100) + '% + ' + dx + 'px))'; }, { passive: true } ); root.addEventListener('touchend', function () { if (!dragging) return; const dx = curX - startX; root.classList.remove('grabbing'); dragging = false; if (Math.abs(dx) > threshold) { if (dx < 0) next(); else prev(); } else { update(); } startAutoplay(); }); // 鼠标拖动(可选) let mouseDown = false; let mStartX = 0; root.addEventListener('mousedown', function (e) { mouseDown = true; mStartX = e.clientX; root.classList.add('grab'); stopAutoplay(); }); window.addEventListener('mouseup', function (e) { if (!mouseDown) return; const dx = e.clientX - mStartX; mouseDown = false; root.classList.remove('grab'); if (Math.abs(dx) > threshold) { if (dx < 0) next(); else prev(); } else { update(); } startAutoplay(); }); // 初始化 update(); startAutoplay(); } // <- 确保此处仅关闭 initCarousel 函数 function initAll(context) { const scope = context && context.querySelectorAll ? context : document; scope.querySelectorAll('.carousel-container').forEach(initCarousel); } // 初次加载 if (document.readyState === 'loading') { document.addEventListener('DOMContentLoaded', function () { initAll(); }); } else { initAll(); } // 动态内容(如可视化编辑器或AJAX)再次初始化 if (window.mw && mw.hook) { mw.hook('wikipage.content').add(function (content) { // content 可能是 jQuery 对象,也可能是原生节点 if (content && content[0] && content.find) { // jQuery 对象 content.find('.carousel-container').each(function () { initCarousel(this); }); } else if (content && content.querySelectorAll) { // 原生节点 initAll(content); } else { initAll(); } }); } })(); /* 装备 */ $(function() { // 创建弹窗容器 var popupHTML = '<div class="equipment-popup-overlay" id="equipmentPopup">' + '<div class="equipment-popup-container">' + '<div class="equipment-popup-close">×</div>' + '<div class="equipment-popup-content"></div>' + '</div></div>'; // 添加到body if ($('#equipmentPopup').length === 0) { $('body').append(popupHTML); } // 点击装备卡片显示弹窗 $(document).on('click', '.equipment-card', function(e) { e.preventDefault(); e.stopPropagation(); var $card = $(this); var equipName = $card.data('name'); // 从data-name属性获取装备名称 var level = $card.data('level') || '1'; // 检查是否有装备名称 if (!equipName) { console.error('Equipment name not found'); return; } // 通过AJAX获取装备详情 $.ajax({ url: mw.util.wikiScript('api'), data: { action: 'parse', format: 'json', text: '{{#invoke:装备|popup|' + equipName + '|' + level + '}}', contentmodel: 'wikitext', prop: 'text' }, success: function(response) { if (response.parse && response.parse.text) { var content = response.parse.text['*']; $('.equipment-popup-content').html(content); $('#equipmentPopup').addClass('active'); } }, error: function() { console.error('Failed to load equipment details'); } }); }); // 关闭弹窗 $(document).on('click', '.equipment-popup-close', function(e) { e.stopPropagation(); $('#equipmentPopup').removeClass('active'); }); // 点击遮罩层关闭弹窗 $(document).on('click', '.equipment-popup-overlay', function(e) { if (e.target === this) { $(this).removeClass('active'); } }); // ESC键关闭弹窗 $(document).keydown(function(e) { if (e.keyCode === 27) { $('#equipmentPopup').removeClass('active'); } }); });
返回
MediaWiki:Common.js
。