50 سؤال لجافا سكريبت





يوم جيد يا اصدقاء!



أوجه انتباهكم إلى اختبار JavaScript تفاعلي صغير يتكون حاليًا من 50 سؤالًا.



في رأيي ، حل مثل هذه المشاكل هو أفضل طريقة لتحديد مستوى مهارتك.



تابع هنا .



مقدمة



يعتمد هذا الجزء على هذا المستودع . تضع مؤلفتها ، ليديا هالي ، مشروعه كقائمة من الأسئلة المتقدمة ، وفي الواقع ، من بينها بعض الأسئلة التي أعتقد أنه حتى مطور جافا سكريبت ذو الخبرة سيجد صعوبة. ومع ذلك ، من بين هذه الأسئلة ، هناك أيضًا تلك الأسئلة التي يكفي الحصول على المعرفة الأساسية للإجابة عليها. هناك ترجمة روسية في المستودع ، ولكن ، بعبارة ملطفة ، يترك الكثير مما هو مرغوب فيه ، لذلك كان يجب ترجمة معظم الإجابات (التفسيرات) مرة أخرى.



وتجدر الإشارة إلى أن التفسيرات (الإجابات) المقدمة لا تكشف دائمًا جوهر المشكلة تمامًا. ويرجع ذلك إلى شكل المشروع - فهو قائمة مرجعية وليست برنامجًا تعليميًا. الأجوبة هي بالأحرى تلميح لمزيد من عمليات البحث على MDN أوJavascript.ru . ومع ذلك ، تحتوي العديد من التفسيرات على إجابات شاملة.



على الرغم من حقيقة أن الرمز قد تم اختباره عدة مرات ، لا أحد محصن ضد الأخطاء ، بالطبع ، باستثناء أولئك الذين لا يفعلون شيئًا. لذلك ، إذا وجدت أخطاء أو أخطاء مطبعية أو عدم دقة أو صياغة غير صحيحة ، وما إلى ذلك ، وكذلك إذا كنت ترغب في تحسين الترجمة ، يرجى الكتابة في صورة شخصية ، سأكون ممتنًا (يتم تشجيع النشاط على GitHub أيضًا).



في الواقع ، هذا كل ما أردت أن أقوله كمقدمة.



قواعد



القواعد بسيطة: 50 سؤالاً ، 3-4 إجابات محتملة ، التصنيف: عدد الإجابات الصحيحة وغير الصحيحة ، التقدم: عدد الأسئلة وعددها.



بناءً على النتائج ، يتم تحديد النسبة المئوية للإجابات الصحيحة ويتم التوصل إلى استنتاج حول مستوى إتقان جافا سكريبت: أكثر من 80٪ ممتاز ، أكثر من 50٪ ليس سيئًا ، أقل من 50٪ ... حسنًا ، كما تعلم.



يتم إرفاق تفسير لكل سؤال. إذا كانت الإجابة غير صحيحة ، يتم الكشف عن هذا التفسير.



نظرًا لحقيقة أن عدد الإجابات الصحيحة وغير الصحيحة ، بالإضافة إلى الرقم التسلسلي للسؤال ، يتم تسجيلها في التخزين المحلي ، لديك فرصة للتوقف ، وأخذ قسط من الراحة والاستمرار في أي وقت من المكان الذي تركته.



دعنا ننتقل من الاختبار نفسه.



اختبار





رمز المشروع هنا .



نشارك النتائج في التعليقات.



علم الميكانيكا



بضع كلمات حول كيفية تنفيذ الاختبار لأولئك المهتمين.



يبدو الترميز كالتالي:



<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>200+   JavaScript</title>
    <!--  -->
    <link href="https://fonts.googleapis.com/css2?family=Ubuntu&display=swap" rel="stylesheet">
    <!--  -->
    <link rel="stylesheet" href="style.css">
    <!--     "" -->
    <script type="module" src="script.js"></script>
</head>
<body></body>


أضف أنماطًا بسيطة:



CSS:
* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
    font-family: Ubuntu, sans-serif;
    font-size: 1em;
    text-align: center;
    letter-spacing: 1.05px;
    line-height: 1.5em;
    color: #111;
    user-select: none;
}

@media (max-width: 512px) {
    * {
        font-size: .95em;
    }
}

html {
    position: relative;
}

body {
    padding: 1em;
    min-height: 100vh;
    background: radial-gradient(circle, skyblue, steelblue);
    display: flex;
    flex-direction: column;
    justify-content: start;
    align-items: center;
}

h1 {
    margin: .5em;
    font-size: 1.05em;
}

output {
    margin: .5em;
    display: block;
}

.score {
    font-size: 1.25em;
}

form {
    text-align: left;
}

form p {
    text-align: left;
    white-space: pre;
}

form button {
    position: relative;
    left: 50%;
    transform: translateX(-50%);
}

button {
    margin: 2em 0;
    padding: .4em .8em;
    outline: none;
    border: none;
    background: linear-gradient(lightgreen, darkgreen);
    border-radius: 6px;
    box-shadow: 0 1px 2px rgba(0, 0, 0, .4);
    font-size: .95em;
    cursor: pointer;
    transition: .2s;
}

button:hover {
    color: #eee;
}

label {
    cursor: pointer;
}

input {
    margin: 0 10px 0 2em;
    cursor: pointer;
}

details {
    font-size: .95em;
    position: absolute;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
    width: 90%;
    background: #eee;
    border-radius: 4px;
    cursor: pointer;
}

details h3 {
    margin: .5em;
}

details p {
    margin: .5em 1.5em;
    text-align: justify;
    text-indent: 1.5em;
}

.right {
    color: green;
}

.wrong {
    color: red;
}




الأصول هي مجموعة من الكائنات ، حيث يحتوي كل كائن على سؤال خصائص (سؤال) ، وإجابات (إجابات) ، و rightAnswer (إجابة صحيحة) وتفسير (شرح):



[
{
    question: `
        function sayHi() {
            console.log(name);
            console.log(age);
            var name = "Lydia";
            let age = 21;
        }

        sayHi();
    `,
    answers: `
        A: Lydia  undefined
        B: Lydia  ReferenceError
        C: ReferenceError  21
        D: undefined  ReferenceError
    `,
    rightAnswer: `D`,
    explanation: `
              name     var.  ,  name    . Name    undefined   ,       ,     Lydia.     name,      ,    undefined. ,    let ( const),  ,     var,  .      .   "  ".         , JavaScript   ReferenceError.
    `
},
...
]


النص الأساسي:



جافا سكريبت
//    - 
import assets from './assets.js'

// IIFE
;((D, B) => {
    //  - 
    const title = D.createElement('h1')
    B.append(title)

    // :     
    const score = D.createElement('output')
    score.className = 'score'
    B.append(score)

    // :   
    const progress = D.createElement('output')
    progress.className = 'progress'
    B.append(progress)

    //   ,       
    const div = D.createElement('div')
    B.append(div)

    //         
    //    0
    let rightAnswers = +localStorage.getItem('rightAnswers') || 0
    let wrongAnswers = +localStorage.getItem('wrongAnswers') || 0

    //      
    //    0
    let i = +localStorage.getItem('i') || 0

    //  
    showQuestion()

    //    
    updateScoreAndProgress()

    function showQuestion() {
        //      
        // ,  ,
        //  
        if (i === assets.length) {
            return showResult()
        }

        // -     -  
        const titleText = {
            4: `   ?`,
            9: ` ?`,
            12: `    `,
            13: `    ?`,
            14: `  ?`,
            20: `  sum?`,
            21: `    cool_secret?`,
            23: `  ?`,
            25: `     :    this`,
            27: `  ?`,
            29: `  ?`,
            30: `   event.target    ?`,
            33: `  ?`,
            34: `    ""?`,
            38: `  JavaScript `,
            39: `  ?`,
            40: `  ?`,
            41: `  setInterval?`,
            42: `  ?`,
            48: `  num?`,
            49: `  ?`
        }
        title.textContent = titleText[i] || `    ?`

        //     -  ,
        //    ,  ,    
        const {
            question,
            rightAnswer,
            explanation
        } = assets[i]

        //    -  input type="radio",
        //      (    - \n)
        //     -  ,
        //      slice(1, -1),
        //   
        const answers = assets[i].answers
            .split('\n')
            .slice(1, -1)
            .map(i => i.trim())

        // HTML-
        const template = `
        <form action="#">
            <p><em>:</em><br> ${question}</p>

            <p><em> :</em></p><br>
            ${answers.reduce((html, item) => html += `<label><input type="radio" name="answer" value="${item}">${item}</label><br>`, '')}

            <button type="submit"></button>
        </form>
        <details>
            <summary>  </summary>
            <section>
                <h3> : ${rightAnswer}</h3>
                <p>${explanation}</p>
            </section>
        </details>`

        //    
        div.innerHTML = template

        //  
        const form = div.querySelector('form')

        //   
        form.querySelector('input').setAttribute('checked', '')

        //   
        form.addEventListener('submit', ev => {
            //   
            ev.preventDefault()

            //    
            const chosenAnswer = form.querySelector('input:checked').value.substr(0, 1)

            //  
            checkAnswer(chosenAnswer, rightAnswer)
        })
    }

    function checkAnswer(chosenAnswer, rightAnswer) {
        //   
        let isRight = true

        //      ,
        //    ,
        //       ,
        //     ,
        //       
        //    false
        if (chosenAnswer === rightAnswer) {
            rightAnswers++
            localStorage.setItem('rightAnswers', rightAnswers)
        } else {
            wrongAnswers++
            localStorage.setItem('wrongAnswers', wrongAnswers)
            isRight = false
        }

        //  
        const button = div.querySelector('button')

        //    
        if (isRight) {
            //   
            title.innerHTML = `<h1 class="right">!</h1>`

            //  
            button.disabled = true

            //    
            //        
            //  
            const timer = setTimeout(() => {
                updateScoreAndProgress()
                showQuestion()
                clearTimeout(timer)
            }, 1000)

            //    
        } else {
            //   
            title.innerHTML = `<h1 class="wrong">!</h1>`

            //  
            div.querySelectorAll('input').forEach(input => input.disabled = true)

            //  
            div.querySelector('details').setAttribute('open', '')

            //   
            button.textContent = ''

            //      
            //        
            //  
            button.addEventListener('click', () => {
                updateScoreAndProgress()
                showQuestion()
            }, {
                once: true
            })
        }

        //   
        i++

        //      
        localStorage.setItem('i', i)
    }

    function updateScoreAndProgress() {
        //  
        score.innerHTML = `<span class="right">${rightAnswers}</span> - <span class="wrong">${wrongAnswers}</span>`

        //  
        progress.innerHTML = `${i + 1} / ${assets.length}`
    }

    function showResult() {
        //    
        const percent = (rightAnswers / assets.length * 100).toFixed()

        //    
        let result

        //      
        //  result  
        if (percent >= 80) {
            result = ` !    JavaScript.`
        } else if (percent > 50) {
            result = ` ,     .`
        } else {
            result = `,     JavaScript.`
        }

        //  
        B.innerHTML = `
        <h1> </h1>
        <div>
            <p> : <span class="right">${rightAnswers}</span></p>
            <p> : <span class="wrong">${wrongAnswers}</span></p>
            <p>  : ${percent}</p>
            <p>${result}</p>
            <button></button>
        </div>
        `

        //    
        //  
        //   ,
        //  
        B.querySelector('button').addEventListener('click', () => {
            localStorage.clear()
            location.reload()
        }, {
            once: true
        })
    }
})(document, document.body)




شكرا لك على الاهتمام.



All Articles