回顾

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的三步走
1、事件对象
2、事件、
3、事件驱动 值操作: <div></div> too liang
oDiv.innerText='too liang';仅仅设置文本
oDiv.innerHTML='<h2>too liang</h2>';文本和标签一起渲染
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的性能消耗很大,所以最好应用在少量的切换上面

最新文章

  1. web兼容行探究1:IE 6 select节点显示在绝对布局之上的解决方法
  2. C# 理解Thread.Sleep()方法 ----转帖
  3. Navicat连接oracle,出现Only compatible with oci version 8.1 and&amp;nb (转)
  4. 20145208 《Java程序设计》第8周学习总结
  5. hibernate的sqlQuery自动封装
  6. mongodb数据库设计原则
  7. DELPHI关于文件的操作
  8. 在MVC中利用uploadify插件实现上传文件的功能
  9. Opencv2系列学习笔记10(提取连通区域轮廓) 另一个
  10. Linux简介与厂商版本上
  11. 后端开发者的Vue学习之路(五)
  12. Qt setstylesheet指定窗口
  13. eclipse里没有j2ee
  14. Tiny6410 裸机开发--裸机点亮LED
  15. php如何和linux进行通讯
  16. git push以后GitHub上文件夹灰色 不可点击
  17. 通俗理解N-gram语言模型。(转)
  18. [转]kafka详解
  19. [Proposal]MyTools
  20. [保存]——pycharm5专业版激活方法

热门文章

  1. Visual Studio 2010 出现关于ActivityLog.xml错误的解决方案
  2. [转]Sublime Text 新建文件快速生成Html【头部信息】和【代码补全】、【汉化】
  3. C++进阶--自定义new handler
  4. Zuul Read Time out 错误
  5. uoj#274. 【清华集训2016】温暖会指引我们前行
  6. 杂项:TMT(数字媒体产业)
  7. 在docker宿主机上查找指定容器内运行的所有进程的PID
  8. win10 内置软件经常不用,还占空间?如何轻松卸载
  9. 几个简单常用的jQuery实例
  10. Rehash死锁的问题