document.getElementById('id')。innerHTML =“some value”更改不反映

时间:2014-09-13 07:01:37

标签: javascript html forms submit innerhtml

我有下面提到的代码,innerHTML所做的更改不会反映在浏览器中

<body>

<script TYPE="text/javascript">
    function change(){
        document.getElementById("op").innerHTML="this works!";
        prompt(document.getElementById("op").innerHTML);
    }
</script>

<form onSubmit="change()">
    <table>
        <tr>
            <td id="a1">This</td>
           <td id="a2"><input type="text" id="t1"></td>
        </tr>
    </table>
    <input type="submit" value="submit">
</form>

//输出

    <table>
        <tr><td id="op"></td></tr>
    </table>

    </body>
</html>

更改确实发生,如提示所示,但不会反映在页面上。

1 个答案:

答案 0 :(得分:4)

JavaScript是单线程的。在将值innerHTML分配的函数完成之前,浏览器不会运行重绘事件。

在清除提示(阻塞功能)之前,该功能不会完成。

此时,由于它是由提交按钮触发的,表单将立即提交并加载一个新页面(这将使表格单元格的内容恢复原状状态。)

取消表单的默认事件。

90年代风格:

function change()
{
  document.getElementById("op").innerHTML="this works!";
  prompt(document.getElementById("op").innerHTML);
  return false;
}

onSubmit="return change()">

现代风格:

function change(event)
{
  event.preventDefault();
  document.getElementById("op").innerHTML="this works!";
  prompt(document.getElementById("op").innerHTML);
}
document.querySelector('form').addEventListener("submit", change);