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

편집 요약 없음
편집 요약 없음
 
(같은 사용자의 중간 판 2개는 보이지 않습니다)
10번째 줄: 10번째 줄:
     }
     }


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


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

2024년 12월 24일 (화) 18:35 기준 최신판

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

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