js中script上下放置的区别是什么
这篇文章主要介绍了js中script上下放置的区别是什么,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。
具体如下:
回顾
javascript分为三部分:
1、ECMAScript5.0 es6(阮一峰) es7 es8 es6中有类的概念
声明变量 var let(es6中语法)
内置函数 Date Math.random
if else switch while do-while for
2、DOM Document Object Model
获取DOM事件的三种方式
getElementById()
getElementsByTagName()
getElementsByClassName()
DOM的三步走
①、事件对象
②、事件、
③、事件驱动
值操作: <div></div> too liangoDiv.innerText='too liang';
仅仅设置文本oDiv.innerHTML='<h3>too liang</h3>';
文本和标签一起渲染oInput.value='alex';
仅仅是对表单控件有效
标签属性操作;
设置类名:oDiv.className+=' active';
追加类名、
设置id:oDiv.id='box';
样式操作:
oDiv.style.(css中所有的样式属性)
注意驼峰体:如果margin-left 使用js的时候marginLeft
3、BOM
<script></script>在head和body中放置的区别
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
<script>
//加载顺序:1DOM元素加载 2图片加载
//1等待DOM和图片资源加载完成之后才调用window.onload后面的方法
//2事件覆盖事件,也即同时存在多个window.noload时,后面的覆盖前面的
window.onload=function () {
// var oBtn=document.getElementById('btn');
// console.log(oBtn);
function $(idName){
return document.getElementById(idName);
}
$('btn').onclick=function(){
。。。。。。
};
}
</script> <!--没有操作DOM时可以将script放在这里面,如果要使用DOM的相关操作,使用window.onload,建议最好写在body里面-->
</head>
DOM的增删改查
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<body>
<button id="btn">追加</button>
<button id="del">删除</button>
<div id="box">
<p>测试段落</p>
</div>
<script>
//加载顺序:1DOM元素加载 2图片加载
//1等待DOM和图片资源加载完成之后才调用window.onload后面的方法
//2事件覆盖现在,同时存在多个window.noload时,后面的覆盖前面的
window.onload=function () {
// var oBtn=document.getElementById('btn');
// console.log(oBtn);
function $(idName){
return document.getElementById(idName);
}
$('btn').onclick=function(){
//1DOM的创建
var oP=document.createElement('p');
//2 DOM的追加
$('box').appendChild(oP);
//3 DOM的修改
oP.innerText='alex';
oP.id='p1';//设置id
var oA=document.createElement('abc');//自定义创建
oA.innerText='321';
oA.id='abc';
$('box').insertBefore(oA,oP);//在oA之前插入
};
//4 DOM的删除操作
$('del').onclick=function(){
$('box').removeChild($('p1'));
$('box').removeChild($('abc'));
}
}
</script>
</body>
</html>
应用场景分析
如果是一开始页面有初始化渲染开销;应用:频繁的切换:display:none|block 或者 追加className 删除className
如果是DOM的创建和删除 如果你是频繁的切换,对DOM的性能消耗很大,所以最好应用在少量的切换上面
感兴趣的朋友可以使用在线HTML/CSS/JavaScript代码运行工具:http://tools.jb51.net/code/HtmlJsRun测试上述代码运行效果。
感谢你能够认真阅读完这篇文章,希望小编分享的“js中script上下放置的区别是什么”这篇文章对大家有帮助,同时也希望大家多多支持编程网,关注编程网行业资讯频道,更多相关知识等着你来学习!
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341