MediaWiki:Gadget-SelectionCounter.js:修订间差异
MediaWiki界面页面
更多操作
删除的内容 添加的内容
Maintenance script(留言 | 贡献) 增加触发事件并增强选区检测 |
Maintenance script(留言 | 贡献) 确保 DOM 就绪后初始化 |
||
| 第7行: | 第7行: | ||
mw.loader.using(['mediawiki.util']).then(function () { |
mw.loader.using(['mediawiki.util']).then(function () { |
||
if (window.SelectionCounterLoaded) { |
|||
| ⚫ | |||
| ⚫ | |||
| ⚫ | |||
| ⚫ | |||
| ⚫ | |||
| ⚫ | |||
} |
} |
||
window.SelectionCounterLoaded = true; |
|||
$(function () { |
|||
| ⚫ | |||
| ⚫ | |||
| ⚫ | |||
| ⚫ | |||
| ⚫ | |||
.hide() |
|||
.appendTo('body'); |
|||
} |
} |
||
| ⚫ | |||
| ⚫ | |||
| ⚫ | |||
| ⚫ | |||
| ⚫ | |||
| ⚫ | |||
| ⚫ | |||
| ⚫ | |||
| ⚫ | |||
| ⚫ | |||
function getSelectionText() { |
|||
| ⚫ | |||
| ⚫ | |||
if (!selection || selection.isCollapsed) { |
|||
return; |
return ''; |
||
| ⚫ | |||
| ⚫ | |||
} |
} |
||
function updateCounter() { |
|||
rafId = null; |
|||
| ⚫ | |||
} |
|||
| ⚫ | |||
| ⚫ | |||
return; |
|||
| ⚫ | |||
| ⚫ | |||
function scheduleUpdate() { |
|||
if ( |
if (!text) { |
||
$counter.hide(); |
|||
return; |
|||
} |
|||
var count = Array.from(text).length; |
|||
$counter.text('已选 ' + count + ' 字').show(); |
|||
| ⚫ | |||
| ⚫ | |||
| ⚫ | |||
return; |
|||
} |
|||
| ⚫ | |||
} |
} |
||
| ⚫ | |||
} |
|||
document.addEventListener('selectionchange', scheduleUpdate); |
document.addEventListener('selectionchange', scheduleUpdate); |
||
document.addEventListener('mouseup', scheduleUpdate); |
document.addEventListener('mouseup', scheduleUpdate); |
||
document.addEventListener('keyup', scheduleUpdate); |
document.addEventListener('keyup', scheduleUpdate); |
||
document.addEventListener('touchend', scheduleUpdate, { passive: true }); |
document.addEventListener('touchend', scheduleUpdate, { passive: true }); |
||
| ⚫ | |||
}); |
}); |
||
2025年12月27日 (六) 12:37的版本
/* ================================================================
MediaWiki Gadget: SelectionCounter
功能:
- 选中文本时显示字数统计
- 与 RightToolbar 风格一致
================================================================= */
mw.loader.using(['mediawiki.util']).then(function () {
if (window.SelectionCounterLoaded) {
return;
}
window.SelectionCounterLoaded = true;
$(function () {
var $counter = $('#mw-selection-counter');
if (!$counter.length) {
$counter = $('<div id="mw-selection-counter" class="mw-selection-counter" role="status" aria-live="polite"></div>')
.hide()
.appendTo('body');
}
var rafId = null;
function getSelectionText() {
var selection = window.getSelection();
if (!selection || selection.isCollapsed) {
return '';
}
return String(selection).trim();
}
function updateCounter() {
rafId = null;
var active = document.activeElement;
if (active && (active.tagName === 'INPUT' || active.tagName === 'TEXTAREA' || active.isContentEditable)) {
$counter.hide();
return;
}
var text = getSelectionText();
if (!text) {
$counter.hide();
return;
}
var count = Array.from(text).length;
$counter.text('已选 ' + count + ' 字').show();
}
function scheduleUpdate() {
if (rafId) {
return;
}
rafId = window.requestAnimationFrame(updateCounter);
}
document.addEventListener('selectionchange', scheduleUpdate);
document.addEventListener('mouseup', scheduleUpdate);
document.addEventListener('keyup', scheduleUpdate);
document.addEventListener('touchend', scheduleUpdate, { passive: true });
});
});