미디어위키:Common.js: 두 판 사이의 차이

편집 요약 없음
잔글편집 요약 없음
10번째 줄: 10번째 줄:
     }
     }


     var elements = document.querySelectorAll('i[data-random-string]');
     var rsgelements = document.querySelectorAll('i[data-random-string]');
     elements.forEach(function(element) {
     rsgelements.forEach(function(element) {
         var length = parseInt(element.getAttribute('data-random-string'));
         var length = parseInt(rsgelement.getAttribute('data-random-string'));
         var interval = element.getAttribute('data-interval') === 'true';
         var interval = rsgelement.getAttribute('data-interval') === 'true';
         var intervalTime = parseInt(element.getAttribute('data-intervaltime'));
         var intervalTime = parseInt(rsgelement.getAttribute('data-intervaltime'));


         if (interval) {
         if (interval) {
             setInterval(function() {
             setInterval(function() {
                 element.textContent = generateRandomString(length);
                 rsgelement.textContent = generateRandomString(length);
             }, intervalTime);
             }, intervalTime);
         } else {
         } else {
             element.textContent = generateRandomString(length);
             rsgelement.textContent = generateRandomString(length);
         }
         }
     });
     });
});
});

2025년 11월 16일 (일) 10:52 판

/* 이 자바스크립트 설정은 모든 문서, 모든 사용자에게 적용됩니다. */
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(element) {
        var length = parseInt(rsgelement.getAttribute('data-random-string'));
        var interval = rsgelement.getAttribute('data-interval') === 'true';
        var intervalTime = parseInt(rsgelement.getAttribute('data-intervaltime'));

        if (interval) {
            setInterval(function() {
                rsgelement.textContent = generateRandomString(length);
            }, intervalTime);
        } else {
            rsgelement.textContent = generateRandomString(length);
        }
    });
});