Js放到HTML文件中的哪个位置有什么区别


Posted in Javascript onAugust 21, 2013

这个问题一直是初学者的困惑。先明白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放到HTML文件中的哪个位置有什么区别 
结果如图,页面载入就是是这个样子,点击按钮没有反应。将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放到HTML文件中的哪个位置有什么区别 
•说明是可以运行的。这说明,不止可以放函数名了。

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

Javascript 相关文章推荐
input按钮的事件处理大全
Dec 10 Javascript
JavaScript中的View-Model使用介绍
Aug 11 Javascript
用jquery实现输入框获取焦点消失文字
Apr 27 Javascript
js实现通用的微信分享组件示例
Mar 10 Javascript
JavaScript实现在页面间传值的方法
Apr 07 Javascript
Bootstrap Metronic完全响应式管理模板学习笔记
Jul 08 Javascript
JavaScript和jQuery获取input框的绝对位置实现方法
Oct 13 Javascript
原生js实现新闻列表展开/收起全文功能
Jan 20 Javascript
jquery easyui如何实现格式化列
Jul 30 jQuery
vue实现跳转接口push 转场动画示例
Nov 01 Javascript
VueCli4项目配置反向代理proxy的方法步骤
May 17 Javascript
在vue中使用eslint,配合vscode的操作
Nov 09 Javascript
使用jQuery避免鼠标双击的解决方案
Aug 21 #Javascript
jquery ready(fn)事件使用介绍
Aug 21 #Javascript
javaScript面向对象继承方法经典实现
Aug 20 #Javascript
Table冻结表头示例代码
Aug 20 #Javascript
JQuery判断子iframe何时加载完成解决方案
Aug 20 #Javascript
jQuery回车实现登录简单实现
Aug 20 #Javascript
jquery 延迟执行实例介绍
Aug 20 #Javascript
You might like
xajax写的留言本
2006/11/25 PHP
php实现首页链接查询 友情链接检查的代码
2010/01/05 PHP
php简单的会话类代码
2011/08/08 PHP
php操作JSON格式数据的实现代码
2011/12/24 PHP
thinkPHP实现瀑布流的方法
2014/11/29 PHP
PHP6新特性分析
2016/03/03 PHP
两种方法实现文本框输入内容提示消失
2013/03/17 Javascript
Node.js 制作实时多人游戏框架
2015/01/08 Javascript
简单学习JavaScript中的for语句循环结构
2015/11/10 Javascript
Js与Jq获取浏览器和对象值的方法
2016/03/18 Javascript
简单实现的JQuery文本框水印插件
2016/06/14 Javascript
js中string和number类型互转换技巧(分享)
2016/11/28 Javascript
浅析Vue自定义组件的v-model
2017/11/26 Javascript
JS实现旋转木马轮播图
2020/01/01 Javascript
实例探究Python以并发方式编写高性能端口扫描器的方法
2016/06/14 Python
基于Python中capitalize()与title()的区别详解
2017/12/09 Python
python爬虫之urllib3的使用示例
2018/07/09 Python
Python爬虫之正则表达式的使用教程详解
2018/10/25 Python
Python装饰器限制函数运行时间超时则退出执行
2019/04/09 Python
详解PyTorch中Tensor的高阶操作
2019/08/18 Python
python命令 -u参数用法解析
2019/10/24 Python
Python面向对象封装操作案例详解
2019/12/31 Python
python GUI库图形界面开发之PyQt5打开保存对话框QFileDialog详细使用方法与实例
2020/02/27 Python
opencv之颜色过滤只留下图片中的红色区域操作
2020/06/05 Python
pandas创建DataFrame的7种方法小结
2020/06/14 Python
Speedo美国:澳大利亚顶尖泳衣制造商
2016/08/03 全球购物
Perricone MD裴礼康美国官网:抗衰老护肤品
2016/09/26 全球购物
国旗下的讲话演讲稿
2014/05/08 职场文书
室内趣味活动方案
2014/08/24 职场文书
2014年乡镇工作总结
2014/11/21 职场文书
2014年后备干部工作总结
2014/12/08 职场文书
党性分析材料格式
2014/12/19 职场文书
2016继续教育研修日志
2015/11/13 职场文书
乡镇团代会开幕词
2016/03/04 职场文书
协议书格式模板
2016/03/24 职场文书
zabbix 代理服务器的部署与 zabbix-snmp 监控问题
2022/07/15 Servers