无法将 classList 属性添加到数组的索引中

Unable to add classList property to an array's index

提问人:JaseyJS 提问时间:8/16/2018 最后编辑:CommunityJaseyJS 更新时间:8/16/2018 访问量:299

问:

需要一些帮助来制作内存游戏,因为我正在尝试单击元素以显示和打开,比较内部 html,如果相等,则添加类匹配以保持两个元素打开,但是当我单击(元素)卡时,它会抛出错误“未捕获的 TypeError:无法读取 HTMLLIElement .cardClick 中未定义的属性 classList”,我不知道如何纠正, 任何帮助将不胜感激。谢谢。 https://codepen.io/ma-halepoto/pen/OwEqNr 时完成代码

window.onload = function () {
        let openedCards  =  [];
            matchedCards =  [];
            //currentCard  =    [];
            //previouseCard= 0 ;
            moveCount = 0 ;
            restart = document.getElementsByClassName ('restart');
            modal = document.getElementById('myModal');
            span = document.getElementsByClassName('close')[0];
            displayCards = [];
            openedCardsLength=null;

            // console.log (restart); just to see if restart works
            restart[0].addEventListener ('click', function (){
                location.reload();

            })
        // console.log("It's loaded!") to check if this works
        const cards = ['fa-diamond','fa-diamond', 'fa-paper-plane-o','fa-paper-plane-o', 'fa-anchor', 'fa-anchor', 'fa-bolt', 'fa-bolt', 'fa-cube', 'fa-cube', 'fa-leaf', 'fa-leaf', 'fa-bicycle', 'fa-bicycle',
         'fa-bomb','fa-bomb' ]; 
        let shuffleCards = shuffle (cards);
        // console.log (shuffleCards); to check if this works
        let cardElements = document.getElementsByClassName('symbols');
        // console.log (cardElements); to check if this works
        for (i=0; i < cardElements.length; i++ ) {
            cardElements[i].className = shuffleCards[i]+ ' fa symbols';
        
        }

        // initialising popup 

        function popup() {
                        modal.style.display = "flex";
                        document.getElementById('p1').innerHTML = 'You did it in '+ moveCount+ ' moves'  + ' and ' + seconds+ ' seconds.';
        }

        // Closing popup by clicking x
        span.onclick = function closeX () {
                            modal.style.display = "none";
                        }

        // function close popup by clicking any where
        window.onclick = function(event) {
                            if (event.target == modal) {
                                modal.style.display = "none";
                            }
                        }

        // Stopwatch initialisation
        let stopWatch = document.getElementById ('timer');
            time = 0;
            seconds=0
        
        // start time
        function startTime () {
            time = setInterval ( function (){
                seconds++;
                stopWatch.innerHTML = seconds + ' s';
            }, 1000); 
        }

        // stop the time function
        function stopTime ()    {
            clearInterval (time);
        }
        
        displayCards = document.getElementsByClassName ('card');       
            console.log(displayCards);

        // Click Event
        function cardClick () {
            openedCards = this;
            openedCards.removeEventListener ('click', cardClick);
            console.log (openedCards);
            // openedCards[1].removeEventListener ('click', cardClick); 
            

            // updating move counts
            let countMoves = document.getElementById ('moves');

            moveCount++ ;
            countMoves.innerHTML= moveCount;
            console.log(countMoves);

            // star ranking;
            if ( moveCount === 20) {
                let removeStar = document.getElementById('star3');
                removeStar.style.display = 'none';
            } else if (moveCount ===30) {
                let removeStarTwo = document.getElementById ('star2');
                removeStarTwo.style.display = 'none';
                }   

            // start  stopwatch at the first click.
            if ( moveCount ===1) {
                startTime ();
            }

                //function clickedCards () {
                    //openedCards.push(this);   
                    openedCardsLength = openedCards.length;
                    

错误在这里

openedCards[0].classList.add('打开','显示');

openedCards[1].classList.add('打开', '显示');

                    console.log (openedCards[0]);
                    console.log (openedCards[1]);
                    console.log (openedCardsLength);

                    if (openedCardsLength ===2) {
        
                        
                        if (openedCards[0].type === openedCards[1].type){
                            openedCards[0].classList.add('match');
                            openedCards[1].classList.add('match');
                        } else {
                            openedCards[0].classList.remove('open','show');
                            openedCards[1].classList.remove('open','show');
                            openedCards[0].addEventListener ('click', cardClick);
                            openedCards[1].addEventListener ('click', cardClick);

                        }

                    }
                    
        } 
            
            // event listener function 
        for (i=0; i < displayCards.length; i++) {
            displayCards[i].addEventListener('click', cardClick);

        }
        
     }`
javascript 未定义 undefined-index

评论

1赞 Aus 8/16/2018
您假设“openedCards”是一个数组,但事实并非如此。一开始,你把它定义为一个数组,但在OnClick事件中,你用“this”覆盖它;一个元素。
0赞 Aus 8/16/2018
从替换第 88 行开始,请参阅修改后的 codepen codepen.io/anon/pen/RBmOda?editors=0010#0
0赞 JaseyJS 8/16/2018
凉。。。。。进展。所以 openedCards=this;更改数组!成什么?非常感谢
0赞 Aus 8/16/2018
'this' 是单击的对象/卡片(不是数组),您想将其“推送”到 openedCards 或其他任何东西中,但您不应该将其分配给 openedCards。这应该涵盖您原始问题的范围。

答: 暂无答案