편집 요약 없음 |
잔글편집 요약 없음 |
||
| (같은 사용자의 중간 판 31개는 보이지 않습니다) | |||
| 6번째 줄: | 6번째 줄: | ||
for (var i = 0; i < length; i++) { | for (var i = 0; i < length; i++) { | ||
result += characters.charAt(Math.floor(Math.random() * characters.length)); | result += characters.charAt(Math.floor(Math.random() * characters.length)); | ||
} | }; | ||
return result; | return result; | ||
} | }; | ||
var | var rsgelements = document.querySelectorAll('i[data-random-string]'); | ||
rsgelements.forEach(function(rsgelements) { | |||
var length = parseInt( | var length = parseInt(rsgelements.getAttribute('data-random-string')); | ||
var interval = | var interval = rsgelements.getAttribute('data-interval') === 'true'; | ||
var intervalTime = parseInt( | var intervalTime = parseInt(rsgelements.getAttribute('data-intervaltime')); | ||
if (interval) { | if (interval) { | ||
setInterval(function() { | setInterval(function() { | ||
rsgelements.textContent = generateRandomString(length); | |||
}, intervalTime); | }, intervalTime); | ||
} else { | } else { | ||
rsgelements.textContent = generateRandomString(length); | |||
} | |||
}); | |||
$(function () { | |||
$("i.mw-typing").each(function () { | |||
var $el = $(this); | |||
var original = $el.text().trim(); | |||
var speed = parseInt($el.attr("data-speed"), 10) || 50; | |||
var goal = $el.attr("data-goal"); | |||
var delay = parseInt($el.attr("data-delay"), 10) || 0; | |||
if (goal && goal.trim().length > 0) { | |||
$el.text(original); | |||
function startDeleting() { | |||
var i = original.length; | |||
function deleteStep() { | |||
if (i > 0) { | |||
i--; | |||
$el.text(original.slice(0, i)); | |||
setTimeout(deleteStep, speed); | |||
} else { | |||
typeGoal(); | |||
} | |||
} | |||
var j = 0; | |||
function typeGoal() { | |||
if (j < goal.length) { | |||
$el.text($el.text() + goal.charAt(j)); | |||
j++; | |||
setTimeout(typeGoal, speed); | |||
} | |||
} | |||
deleteStep(); | |||
} | |||
setTimeout(startDeleting, delay); | |||
} else { | |||
$el.text(""); | |||
function startTyping() { | |||
var k = 0; | |||
function typeOriginal() { | |||
if (k < original.length) { | |||
$el.text($el.text() + original.charAt(k)); | |||
k++; | |||
setTimeout(typeOriginal, speed); | |||
} | |||
} | |||
typeOriginal(); | |||
} | |||
setTimeout(startTyping, delay); | |||
} | } | ||
}); | }); | ||
}); | |||
}); | }); | ||
2026년 1월 2일 (금) 21:51 기준 최신판
/* 이 자바스크립트 설정은 모든 문서, 모든 사용자에게 적용됩니다. */
mw.loader.using(['mediawiki.util'], function() {
function generateRandomString(length) {
var characters = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789!@#$%^&*()_+[]{}|;:,.<>?█▀▄▌▐';
var result = '';
for (var i = 0; i < length; i++) {
result += characters.charAt(Math.floor(Math.random() * characters.length));
};
return result;
};
var rsgelements = document.querySelectorAll('i[data-random-string]');
rsgelements.forEach(function(rsgelements) {
var length = parseInt(rsgelements.getAttribute('data-random-string'));
var interval = rsgelements.getAttribute('data-interval') === 'true';
var intervalTime = parseInt(rsgelements.getAttribute('data-intervaltime'));
if (interval) {
setInterval(function() {
rsgelements.textContent = generateRandomString(length);
}, intervalTime);
} else {
rsgelements.textContent = generateRandomString(length);
}
});
$(function () {
$("i.mw-typing").each(function () {
var $el = $(this);
var original = $el.text().trim();
var speed = parseInt($el.attr("data-speed"), 10) || 50;
var goal = $el.attr("data-goal");
var delay = parseInt($el.attr("data-delay"), 10) || 0;
if (goal && goal.trim().length > 0) {
$el.text(original);
function startDeleting() {
var i = original.length;
function deleteStep() {
if (i > 0) {
i--;
$el.text(original.slice(0, i));
setTimeout(deleteStep, speed);
} else {
typeGoal();
}
}
var j = 0;
function typeGoal() {
if (j < goal.length) {
$el.text($el.text() + goal.charAt(j));
j++;
setTimeout(typeGoal, speed);
}
}
deleteStep();
}
setTimeout(startDeleting, delay);
} else {
$el.text("");
function startTyping() {
var k = 0;
function typeOriginal() {
if (k < original.length) {
$el.text($el.text() + original.charAt(k));
k++;
setTimeout(typeOriginal, speed);
}
}
typeOriginal();
}
setTimeout(startTyping, delay);
}
});
});
});