JavaScript放到HTML页面的那个位置合适

本文探讨了JavaScript在HTML文件中的合适位置,强调了JavaScript代码可以放置在HTML的事件触发器中,例如`onclick`。除了调用函数,`onclick`属性内还可以直接写JS代码执行。此外,文章提到了两种事件绑定方式:直接在HTML元素上添加事件处理函数,以及通过元素ID进行绑定。后者在修改和维护时更为灵活。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Js放到哪个位置,在HTML文件中?

这个问题一直是初学者的困惑。先明白js能放在HTML的那个位置,分别是head和body中。大部分人都是放到head里面的。我学的时候也是稀里糊涂的跟着放到head的里面,也不知道为什么?今天看说说,放到这两个地方的区别:
先看一段html代码:

<html>
 <head>
  <title> New Document </title>
   <meta http-equiv="content-type" content="text/html;charset=utf-8">

<script type="text/javascript" src="test.js"></script>

 </head>

 <body>
	<div id="target">
		
	</div>
	<button id="btn">按钮</button>
	
 </body>
</html>
	var test = function(){
		var span = document.createElement("span");
		span.innerHTML="添加";
		document.getElementById("target").appendChild(span);
	}

	document.getElementById("btn").onclick=test;
如果这段代码放到head里面就不能运行。为什么?
这就要说一下HTML的运行顺序了,应该确切点说不是HTML的运行顺序,是js的运行顺序。HTML从上运行到<script type="text/html" src="test.js"></script>的时候进入test.js文件。前面的不会运行,也就是被function包起来的不会被运行,这个时候就执行最后一句。去页面中取元素Id为btn的元素。但是这个时候,HTML页面并没有加载完。肯定取不到id为btn的元素。会报错。这个时候有人说可以改为下面的代码:
	document.body.onload = function(){
		document.getElementById("btn").onclick=test;
	};
但是这样写还不如,写到</body>的前面呢。
有没有注意到,上面的[document.getElementById("btn").onclick=test;]中test没有括号,那如果改成[test()].会怎么样呢
结果如图,页面载入就是是这个样子,点击按钮没有反应。将js代码改成如下:
	var test=function(){
			var span = document.createElement("span");
			span.innerHTML="添加";
			document.getElementById("target").appendChild(span);
			return function(){
				alert("aaaa");
			};
		}

		document.getElementById("btn").onclick=test();
页面载入的时候,还是和上面一个样子,当点击按钮的时候,有反应了弹出一个框内容是”aaaa“;说明点击的时候执行了函数中return的值。也就是加括号的时候,不触发事件也会执行函数。触发事件的时候执行函数的返回值。不加括号的时候,触发事件才执行函数。

html的事件触发器,内容能写什么?

  • 比如onclick="";双引号里面能写什么。一般看到的可以写函数,比如,onclick="test();"。除了这个还能写什么呢?好有这个分号能不写吗?
  • 看上面的js代码,每一行都有分号。分号的作用就是为了语句被混淆。那也就是说onclick里面可以写js代码。写一个试试,如下
    <html>
     <head>
      <title> New Document </title>
       <meta http-equiv="content-type" content="text/html;charset=utf-8">
    
    
     </head>
    
     <body>
    	<div id="target">
    		
    	</div>
    	<button id="btn" onclick="var espan = document.createElement('span');espan.innerHTML='添加';document.getElementById('target').appendChild(espan);">按钮</button>
    
     </body>
    </html>

  • 运行结果如下:




  • 说明是可以运行的。这说明,不止可以放函数名了。


事件绑定方式?

  • 事件绑定方式常用有两种一是前面介绍的在事件中加入js代码。如:onclick="test();"。这种绑定方式有缺点,就是你要修改,美工已经写好的代码。
  • 还有一种方式就是我开始代码写的那样,通过id,只需要美工将每个元素都加上id就行。并不需要修改HTML代码。















评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值