打开/关闭搜索
搜索
打开/关闭菜单
30
8
13
1.6K
陋室
导航
首页
最近更改
随机页面
特殊页面
社群首页
新闻动态
帮助
上传文件
内容
分类树
所有页面
导入页面
活跃用户列表
界面
侧边栏
站点公告
匿名用户通知
公共样式表
公共脚本
系统消息
打开/关闭外观设置菜单
通知
打开/关闭个人菜单
未登录
未登录用户的IP地址会在进行任意编辑后公开展示。
user-interface-preferences
中文(简体)
个人工具
登录
查看“︁MediaWiki:Gadget-RightToolbar.js”︁的源代码
MediaWiki界面页面
查看
阅读
查看源代码
查看历史
associated-pages
系统消息
讨论
更多操作
←
MediaWiki:Gadget-RightToolbar.js
因为以下原因,您没有权限编辑该页面:
您请求的操作仅限属于这些用户组的用户执行:
用户
、
自动确认用户
此页面为本wiki上的软件提供界面文本,并受到保护以防止滥用。 如欲修改所有wiki的翻译,请访问
translatewiki.net
上的MediaWiki本地化项目。
您无权编辑此JavaScript页面,因为编辑此页面可能会影响所有访问者。
您可以查看和复制此页面的源代码。
/* ================================================================ MediaWiki Gadget: Localized Clock Bar 功能: - 显示浏览器本地时间和 UTC 时间 - 使用 MediaWiki 用户语言格式 - 深色模式适配 + 滑入动画 ================================================================= */ mw.loader.using(['mediawiki.util']).then(function () { function initClockBar() { var isMobile = window.innerWidth <= 768; var $container = $('#mw-right-toolbar'); if (!$container.length) { $container = $('<div id="mw-right-toolbar" class="mw-right-toolbar"></div>').appendTo('body'); } function createButton(id, text, tooltip, clickHandler) { return $('<button></button>', { id: id, class: 'mw-rt-button', title: tooltip, text: text, type: 'button' }).on('click', clickHandler); } var $topButton = $('#mw-scroll-top'); if (!$topButton.length) { $topButton = createButton('mw-scroll-top', '▲', '回到顶部', function () { $('html, body').animate({ scrollTop: 0 }, { duration: 500, easing: 'swing' }); }); $container.append($topButton); } var $bottomButton = $('#mw-scroll-bottom'); if (!$bottomButton.length) { $bottomButton = createButton('mw-scroll-bottom', '▼', '回到底部', function () { $('html, body').animate({ scrollTop: $(document).height() }, { duration: 500, easing: 'swing' }); }); $container.append($bottomButton); } var $clockDiv = $('#mw-right-toolbar-clock'); if (!isMobile && !$clockDiv.length) { $clockDiv = $('<div id="mw-right-toolbar-clock" class="mw-rt-clock"></div>').append( $('<div id="mw-local-date">加载中...</div>'), $('<div id="mw-local-time"></div>'), $('<div id="mw-utc-time"></div>') ); $container.append($clockDiv); } $topButton.hide(); var ticking = false; $(window).on('scroll', function () { if (ticking) { return; } ticking = true; window.requestAnimationFrame(function () { var scrollTop = $(window).scrollTop(); if (scrollTop > 200) { $topButton.fadeIn(); } else { $topButton.fadeOut(); } ticking = false; }); }); window.requestAnimationFrame(function () { $container.addClass('is-visible'); }); function renderClock() { var now = new Date(); var userLang = mw.config.get('wgUserLanguage') || 'en'; var localFormatter = new Intl.DateTimeFormat(userLang, { year: 'numeric', month: 'long', day: 'numeric', hour: '2-digit', minute: '2-digit', second: '2-digit', hour12: false, timeZone: Intl.DateTimeFormat().resolvedOptions().timeZone }); var localParts = localFormatter.formatToParts(now); var localDateStr = localParts.filter(function (p) { return p.type === 'year' || p.type === 'month' || p.type === 'day'; }).map(function (p) { return p.value; }).join(' '); var localTimeStr = localParts.filter(function (p) { return p.type === 'hour' || p.type === 'minute' || p.type === 'second'; }).map(function (p) { return p.value; }).join(':'); $('#mw-local-date').text(localDateStr); $('#mw-local-time').text(localTimeStr); var utcFormatter = new Intl.DateTimeFormat(userLang, { year: 'numeric', month: 'long', day: 'numeric', hour: '2-digit', minute: '2-digit', second: '2-digit', hour12: false, timeZone: 'UTC' }); var utcParts = utcFormatter.formatToParts(now); var utcDateStr = utcParts.filter(function (p) { return p.type === 'year' || p.type === 'month' || p.type === 'day'; }).map(function (p) { return p.value; }).join(' '); var utcTimeStr = utcParts.filter(function (p) { return p.type === 'hour' || p.type === 'minute' || p.type === 'second'; }).map(function (p) { return p.value; }).join(':'); $('#mw-utc-time').text('UTC: ' + utcDateStr + ' ' + utcTimeStr); } var clockTimer = window.setInterval(renderClock, 1000); renderClock(); mw.hook('user.languageChange').add(renderClock); document.addEventListener('visibilitychange', function () { if (document.hidden) { window.clearInterval(clockTimer); clockTimer = null; return; } if (!clockTimer) { clockTimer = window.setInterval(renderClock, 1000); renderClock(); } }); } $(initClockBar); });
返回
MediaWiki:Gadget-RightToolbar.js
。
查看“︁MediaWiki:Gadget-RightToolbar.js”︁的源代码
MediaWiki界面页面