卡厄思
梦
境
菜单
首页
回到首页
WIKI工具
全站样式
全站JS
修改导航栏
测试
沙盒
可视化管理器
战斗员管理器
卡牌管理器
伙伴管理器
装备管理器
词典管理器
图鉴
战斗员
伙伴
装备
怪物卡牌
中立卡牌
词典
小工具
配队模拟器
节奏榜生成器
搜索
链入页面
相关更改
特殊页面
页面信息
最近更改
登录
MediaWiki
查看“︁EventList.js”︁的源代码
←
MediaWiki:EventList.js
因为以下原因,您没有权限编辑该页面:
您请求的操作仅限属于该用户组的用户执行:
用户
此页面为本wiki上的软件提供界面文本,并受到保护以防止滥用。 如欲修改所有wiki的翻译,请访问
translatewiki.net
上的MediaWiki本地化项目。
您无权编辑此JavaScript页面,因为编辑此页面可能会影响所有访问者。
您可以查看和复制此页面的源代码。
$(function() { mw.loader.load( mw.util.getUrl( 'MediaWiki:EventList.css', { action: 'raw', ctype: 'text/css' } ), 'text/css' ); var heightCache = {}; // 为每个事件选项添加点击事件 $('.event-option').click(function() { var $this = $(this); var optionIndex = $this.data('option-index'); var $container = $this.closest('.event-container'); var containerId = $container.data('event-id') || $container.index(); var $effect = $container.find('.event-effect[data-effect-index="' + optionIndex + '"]'); var $allEffects = $container.find('.event-effect'); // 如果点击的是已经激活的选项 if ($this.hasClass('active')) { // 移除激活状态 $this.removeClass('active'); // 添加隐藏动画类 $effect.addClass('hiding'); // 等待动画完成后隐藏元素 setTimeout(function() { $effect.hide().removeClass('hiding'); smoothAdjustHeight($container, containerId); }, 300); } else { // 移除其他选项的激活状态 $container.find('.event-option').removeClass('active'); // 隐藏其他效果 $allEffects.not($effect).each(function() { var $this = $(this); if ($this.is(':visible')) { $this.addClass('hiding'); setTimeout(function() { $this.hide().removeClass('hiding'); }, 300); } }); // 激活当前选项 $this.addClass('active'); // 延迟显示新效果,确保旧效果先隐藏 setTimeout(function() { $effect.show(); smoothAdjustHeight($container, containerId); }, $allEffects.filter(':visible').not($effect).length > 0 ? 150 : 0); } }); // 平滑调整容器高度 function smoothAdjustHeight($container, containerId) { // 先测量需要的高度 var measuredHeight = measureHeight($container); // 如果高度没有变化,不执行动画 if (heightCache[containerId] === measuredHeight) { return; } // 更新缓存 heightCache[containerId] = measuredHeight; // 使用requestAnimationFrame确保动画流畅 requestAnimationFrame(function() { $container.css('min-height', measuredHeight + 'px'); $container.find('.event-background').css('height', (measuredHeight - 160) + 'px'); }); } // 测量所需高度 function measureHeight($container) { var totalHeight = 170; // 基础高度 $container.find('.event-option').each(function() { totalHeight += $(this).outerHeight(true); }); $container.find('.event-effect:visible').each(function() { totalHeight += $(this).outerHeight(true); }); return totalHeight + 15; // 添加底部边距 } // 初始化所有容器的高度 $('.event-container').each(function() { var $container = $(this); var containerId = $container.data('event-id') || $container.index(); var initialHeight = measureHeight($container); heightCache[containerId] = initialHeight; $container.css('min-height', initialHeight + 'px'); $container.find('.event-background').css('height', (initialHeight - 160) + 'px'); }); // 监听窗口大小变化,重新计算高度 var resizeTimer; $(window).resize(function() { clearTimeout(resizeTimer); resizeTimer = setTimeout(function() { $('.event-container').each(function() { var $container = $(this); var containerId = $container.data('event-id') || $container.index(); smoothAdjustHeight($container, containerId); }); }, 250); }); });
返回
MediaWiki:EventList.js
。