Синтаксическая ошибка в Javascript </div> - PullRequest
0 голосов
/ 05 июля 2018

Я практикую todolist, который находится на w3school: https://www.w3schools.com/howto/tryit.asp?filename=tryhow_js_todo

И это можно показать так:

picture

После того, как я нажал кнопку Добавить, компьютер сказал, что есть:

Ошибка «Uncaught SyntaxError: Unexpected token}» в строке 124.

Но в строке 124 есть только тег </div>, поэтому я не понимаю, почему произошла синтаксическая ошибка.
Вот весь мой код:

<!DOCTYPE html>
<html>
    <head>
        <meta charset="UTF-8" name="viewport" content="width=device-width, initial-scale=1">
        <title></title>
        <style type="text/css">

            body {
              margin: 0;
              min-width: 250px;
            }
            * {
                box-sizing: border-box;
            }


            ul {
                margin: 0;
                padding: 0;
            }
            ul li{
                cursor: pointer;
                position: relative;
                padding: 12px 8px 12px 40px;
                background: #eee;
                font-size: 18px;
                transition: 0.2s;

                /* make the list items unselectable */
                -webkit-user-select: none;
                -moz-user-select: none;
                -ms-user-select: none;
                 user-select: none;
            }

            ul li:nth-child(odd){
                background: #f9f9f9;
            }

            ul li:hover{
                background: #ddd;
            }

            ul li.checked{
                background: #888;
                color: #fff;
                text-decoration: line-through;
                /*上面是畫斜線~*/
            }

            ul li.checked::before{
                content: '';
                position:absolute;
                border-color: #fff;
                border-style: solid;
                border-width: 0 2px 2px 0;
                top: 10px;
                left: 16px;
                transform: rotate(45deg);
                height: 15px;
                width: 7px;
            }

            .close{
                position: absolute;
                right: 0;
                top: 0;
                padding: 12px 16px 12px 16px;
            }
            .close:hover{
                background-color: #f44336;
                color: white;   
            }
            /* Style the header */
            .header {
                background-color: #f44336;
                padding: 30px 40px;
                color: white;
                text-align: center;
            }

            /* Clear floats after the header */
            .header:after {
                content: "";
                display: table;
                clear: both;
            }

            input{
                margin: 0;
                border: none;
                border-radius: 0;
                width: 75%;
                padding: 10px;
                float: left;
                font-size: 16px;
            }

            .bt{
                padding: 10px;
                width: 25%;
                background: #d9d9d9;
                color: #555;
                float: left;
                text-align: center;
                font-size: 16px;
                cursor: pointer;
                transition: 0.3s;
                border-radius: 0;
            }
            .bt:hover{
                background-color: #bbb;
            }
        </style>

    </head>
    <body>
        <div id="myDIV" class="header">
            <h2>My To do List</h2>
            <input type="text" id="myInput" placeholder="Todo..."/>
            <span onclick="javascript:function newElement()" class="bt">Add</span>
        </div>

        <ul id="myUL">
            <li>gym</li>
            <li class="checked">javascript</li>
            <li>sleep</li>
        </ul>

        <script type="text/javascript">

                var myList = document.getElementsByTagName('li');
                var i;

                for(i=0;i<myList.length;i++){
                    var span = document.createElement('span');
                    var txt = document.createTextNode("\u00D7"); 
                    span.className='close';
                    span.appendChild(txt);
                    myList[i].appendChild(span);
                }

                var close = document.getElementsByClassName('close');
                var i;
                for(i=0;i<close.length;i++){
                    close[i].onclick = function(){
                        var div = this.parentElement;
                        div.style.display = 'none';
                    }
                }

                var list = document.querySelector('ul');
                //addEventListener():
//              Attach a click event to a <button> element. When the user clicks on the button, output "Hello World" in a <p> element with id="demo":  
//              document.getElementById("myBtn").addEventListener("click", function(){
//                  document.getElementById("demo").innerHTML = "Hello World";
//              });
                list.addEventListener('click',function(ev){
                    if(ev.target.tagName === 'li'){
                        ev.target.classList.toggle('checked'); 
                    }
                },false);

                function newElement(){
                    var li = document.createElement('li');
                    var inputValue = document.getElementById('myInput').value;
                    var t = document.createTextNode(inputValue);
                    li.appendChild(t);//把輸入的東西變成li的子元素
                    if(inputValue === ''){
                        alert('你一定要寫東西!')
                    }else{
                        document.getElementById('myUL').appendChild(li);
                    }
                    document.getElementById('myInput').value='';

                    var span = document.createElement('span');
                    var txt = document.createTextNode('\u00D7');
                    span.className = 'close';
                    span.appendChild(txt);
                    li.appendChild(span);

                    for(i=0;i<close.length;i++){
                        close[i].onclick = function(){
                            var div = this.parentElement;
                            div.style.display = 'none';
                        }
                    }
                }

        </script>
    </body>
</html>

Было:

Ошибка Uncaught ReferenceError: newElement не определена в строке 123

и я исправил это.

1 Ответ

0 голосов
/ 05 июля 2018

Вы просто добавляете имя функции в событие onclick, как показано ниже

<span onclick="newElement()" class="bt">Add</span>

вместо

<span onclick="javascript:function newElement()" class="bt">Add</span>

<!DOCTYPE html>
<html>
    <head>
        <meta charset="UTF-8" name="viewport" content="width=device-width, initial-scale=1">
        <title></title>
        <style type="text/css">

            body {
              margin: 0;
              min-width: 250px;
            }
            * {
                box-sizing: border-box;
            }


            ul {
                margin: 0;
                padding: 0;
            }
            ul li{
                cursor: pointer;
                position: relative;
                padding: 12px 8px 12px 40px;
                background: #eee;
                font-size: 18px;
                transition: 0.2s;

                /* make the list items unselectable */
                -webkit-user-select: none;
                -moz-user-select: none;
                -ms-user-select: none;
                 user-select: none;
            }

            ul li:nth-child(odd){
                background: #f9f9f9;
            }

            ul li:hover{
                background: #ddd;
            }

            ul li.checked{
                background: #888;
                color: #fff;
                text-decoration: line-through;
                /*上面是畫斜線~*/
            }

            ul li.checked::before{
                content: '';
                position:absolute;
                border-color: #fff;
                border-style: solid;
                border-width: 0 2px 2px 0;
                top: 10px;
                left: 16px;
                transform: rotate(45deg);
                height: 15px;
                width: 7px;
            }

            .close{
                position: absolute;
                right: 0;
                top: 0;
                padding: 12px 16px 12px 16px;
            }
            .close:hover{
                background-color: #f44336;
                color: white;   
            }
            /* Style the header */
            .header {
                background-color: #f44336;
                padding: 30px 40px;
                color: white;
                text-align: center;
            }

            /* Clear floats after the header */
            .header:after {
                content: "";
                display: table;
                clear: both;
            }

            input{
                margin: 0;
                border: none;
                border-radius: 0;
                width: 75%;
                padding: 10px;
                float: left;
                font-size: 16px;
            }

            .bt{
                padding: 10px;
                width: 25%;
                background: #d9d9d9;
                color: #555;
                float: left;
                text-align: center;
                font-size: 16px;
                cursor: pointer;
                transition: 0.3s;
                border-radius: 0;
            }
            .bt:hover{
                background-color: #bbb;
            }
        </style>

    </head>
    <body>
        <div id="myDIV" class="header">
            <h2>My To do List</h2>
            <input type="text" id="myInput" placeholder="Todo..."/>
            <span onclick="newElement()" class="bt">Add</span>
        </div>

        <ul id="myUL">
            <li>gym</li>
            <li class="checked">javascript</li>
            <li>sleep</li>
        </ul>

        <script type="text/javascript">

                var myList = document.getElementsByTagName('li');
                var i;

                for(i=0;i<myList.length;i++){
                    var span = document.createElement('span');
                    var txt = document.createTextNode("\u00D7"); 
                    span.className='close';
                    span.appendChild(txt);
                    myList[i].appendChild(span);
                }

                var close = document.getElementsByClassName('close');
                var i;
                for(i=0;i<close.length;i++){
                    close[i].onclick = function(){
                        var div = this.parentElement;
                        div.style.display = 'none';
                    }
                }

                var list = document.querySelector('ul');
                //addEventListener():
//              Attach a click event to a <button> element. When the user clicks on the button, output "Hello World" in a <p> element with id="demo":  
//              document.getElementById("myBtn").addEventListener("click", function(){
//                  document.getElementById("demo").innerHTML = "Hello World";
//              });
                list.addEventListener('click',function(ev){
                    if(ev.target.tagName === 'li'){
                        ev.target.classList.toggle('checked'); 
                    }
                },false);

                function newElement(){
                    var li = document.createElement('li');
                    var inputValue = document.getElementById('myInput').value;
                    var t = document.createTextNode(inputValue);
                    li.appendChild(t);//把輸入的東西變成li的子元素
                    if(inputValue === ''){
                        alert('你一定要寫東西!')
                    }else{
                        document.getElementById('myUL').appendChild(li);
                    }
                    document.getElementById('myInput').value='';

                    var span = document.createElement('span');
                    var txt = document.createTextNode('\u00D7');
                    span.className = 'close';
                    span.appendChild(txt);
                    li.appendChild(span);

                    for(i=0;i<close.length;i++){
                        close[i].onclick = function(){
                            var div = this.parentElement;
                            div.style.display = 'none';
                        }
                    }
                }

        </script>
    </body>
</html>
...