javascript执行顺序导致页面加载效果失败的问题

练习用JS动态创建表格放入指定的div中时,表格始终出不来,最后发现是因为js 代码在页面还没有加载完成时函数代码块就已经运行了,所以创建的table元素找不到指定的div。
显示失败的代码如下:

<script type="text/javascript">
var arr=[['id','名称','血量','伤害'],['1','gareen','340','58'],['2','teemo','320','56'],['3','annie','380','38'],['4','deadbo','400','90']];
var table=document.createElement("table");
for(var i=0;i<arr.length;i++){
	var tr=document.createElement("tr");
	for(var j=0;j<arr[i].length;j++){
		var td=document.createElement("td");
		var text=document.createTextNode(arr[i][j]);
	    td.appendChild(text);
		tr.appendChild(td);
	}
	table.appendChild(tr);
}
var showtable=document.getElementById("showtable");
showtable.appendChild(table);
//document.getElementsByTagName("body")[0].appendChild(table);这种方法也可以将表格添加到body元素当前的位置
</script>
<div id="showtable">
</div>

解决办法:使用window.onload,在文档加载完成后能立即触发,window.onload =function (){写要在页面加载完成后执行的代码};
或者将JS代码放在HTML元素的后面。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值