JavaScript笔记(5)
1.DOM操作
常用的DOM操作
document.getElementById(id);
//返回指定id的元素,通用
document.getElementsByTagName(tagName);
//返回带有指定标签名的对象的集合,通用
/* 不常用 */
getElementsByClassName(className);
//返回指定类名的元素集合,不兼容IE7、8,其他浏览器支持
getElementsByName();
//返回指定name属性元素的集合
DOM树中元素与元素之间的关系:父子、兄弟
假如现在有一个DOM元素为obj
找DOM节点
1.找父节点
/* 通用 */
obj.parentNode;
2.找兄弟节点
/* 不常用,应为不兼容 */
obj.nextSibling;//找obj“下一个”兄弟节点,这个属性只有IE7、8认识
obj.nextElementSibling;//找obj“下一个”兄弟节点,其他浏览器认识
obj.previousSibling;//找obj“上一个”兄弟节点,这个属性只有IE7、8认识
obj.previousElementSibling;//找obj“上一个”兄弟节点,其他浏览器认识
/* 兼容性写法:先通用 || 后IE7、8 */
var next = obj.nextElementSibling || obj.nextSibling;
var last = obj.previousElementSibling || obj.previousSibling;
3.找子节点
/* 找第一个子节点 */
obj.firstElementChild;通用
obj.firstChild;//只有IE7、8认识,不通用
/* 找最后一个子节点 */
obj.lastElementChild;//通用
obj.lastChild;//只有IE7、8认识,不通用
/* 兼容性写法:先通用 || 后IE7、8 */
var firstLi = obj.firstElementChild || obj.firstChild;
var lastLi = obj.lastElementChild || obj.lastChild;
/* 找所有子节点 */
obj.childNodes;//w3c标准,但会找到空文本的节点,不常用
obj.children;//非标准,只会计算“真正”的子元素,常用
DOM节点操作
在DOM操作里,所有的创建、插入、删除操作,都必须通过父节点来插入子节点和删除子节点
- 节点文本操作: 控制节点文本
(1) innerText: 会原封不动的显示字符串(不常用)
(2) innerHTML: 会解析这个字符串,如果该字符串中有HTML标记成分,就会被按照HTML的规范,将标记解析出来后显示(常用)
4.动态创建DOM节点
/* 尾部添加节点 */
var obj = document.createElement("tagName");
//此时只在内存里创建了节点,还没有写入HTML文档中
var fatherNode = document.getElementById("fatherId");
//拿到父节点
fatherNode.appendChild(obj);
//在父节点内部所有子节点尾部追加新建的节点
//此时节点才创建完成
/* 任意位置插入节点 */
var newChild = document.createElement("tagName");
var fatherNode = document.getElementById("fatherId");
var refChild = document.getElementById("refChild_Id");
fatherNode.insertBefore(newChild, refChild);//newChild: 新建节点 refChild: 参照节点
//在参照节点之前插入新节点,参照节点可以为null,此时新建节点会被插入尾部
/* 删除节点 */
var fatherNode = document.getElementById("fatherId");
var oldChidNode = document.getElementById("oldChild_Id");
fatherNode.removeChild(oldChildNode);
动态设置DOM元素的属性
写属性: obj.setAttribute("valueName","value");
读属性: obj.getAttribute("valueName");
2.控制样式
3.动画效果
JavaScript笔记(5)的更多相关文章
- [Effective JavaScript 笔记] 第4条:原始类型优于封闭对象
js有5种原始值类型:布尔值.数字.字符串.null和undefined. 用typeof检测一下: typeof true; //"boolean" typeof 2; //&q ...
- [Effective JavaScript 笔记] 第5条:避免对混合类型使用==运算符
“1.0e0”=={valueOf:function(){return true;}} 是值是多少? 这两个完全不同的值使用==运算符是相等的.为什么呢?请看<[Effective JavaSc ...
- [Effective JavaScript 笔记]第3章:使用函数--个人总结
前言 这一章把平时会用到,但不会深究的知识点,分开细化地讲解了.里面很多内容在高3等基础内容里,也有很多讲到.但由于本身书籍的篇幅较大,很容易忽视对应的小知识点.这章里的许多小提示都很有帮助,特别是在 ...
- [Effective JavaScript 笔记]第27条:使用闭包而不是字符串来封装代码
函数是一种将代码作为数据结构存储的便利方式,代码之后可以被执行.这使得富有表现力的高阶函数抽象如map和forEach成为可能.它也是js异步I/O方法的核心.与此同时,也可以将代码表示为字符串的形式 ...
- [Effective JavaScript 笔记]第28条:不要信赖函数对象的toString方法
js函数有一个非凡的特性,即将其源代码重现为字符串的能力. (function(x){ return x+1 }).toString();//"function (x){ return x+ ...
- 从头开始学JavaScript 笔记(一)——基础中的基础
原文:从头开始学JavaScript 笔记(一)--基础中的基础 概要:javascript的组成. 各个组成部分的作用 . 一.javascript的组成 javascript ECMASc ...
- 【原】javascript笔记之Array方法forEach&map&filter&some&every&reduce&reduceRight
做前端有多年了,看过不少技术文章,学了新的技术,但更新迭代快的大前端,庞大的知识库,很多学过就忘记了,特别在项目紧急的条件下,哪怕心中隐隐约约有学过一个方法,但会下意识的使用旧的方法去解决,多年前ES ...
- JavaScript笔记目录
JavaScript笔记目录 一.JavaScript简介 二.在HTML中使用JavaScript ...持续更新中,敬请期待
- 蛋糕仙人的javascript笔记
蛋糕仙人的javascript笔记:https://www.w3cschool.cn/kesyi/kesyi-nqej24rv.html
- JavaScript笔记(第一章,第二章)
JavaScript笔记(第一章,第二章) 第一章: <meta http-equiv="Content-Type" content="text/html; cha ...
随机推荐
- [go]ini配置文件解析
// config.ini [app] server.port = 8080 name = resk enabled = false time = 10s ;我是一个注释 #mysql数据库配置 [m ...
- js生成带log的二维码(qrcodejs)
github: qrcodejs cdn: http://static.runoob.com/assets/qrcode/qrcode.min.js #qrcode #qrcode margin: 2 ...
- OpenStack v.s. Kubernetes
目录 文章目录 目录 What are the differences with OpenStack and Kubernetes? Why OpenStack & Kubernetes? W ...
- mac下不允许安装除了app store之外的软件设置:
1.dock栏的系统偏好设置. 2.找到安全性与隐私 3.点击面板中的通用,在点击左小角的锁按钮, 4.选择任何来源,确定就可以了.[如果只有两个选项,而没有任何来源的话,打开终端,执行:sudo s ...
- pycharm建立第一个django工程-----windows中
pycharm建立第一个django工程 系统:win764 ip: 192.168.0.100 安装django pip install django 左上角建立一个名为Firstdjango工程 ...
- windows10环境下pip安装Scrapy报错
问题描述 当前环境win10,python_3.6.1,64位. 在windows下,在dos中运行pip install Scrapy报错: building 'twisted.test.raise ...
- 【VS开发】四大图像库:OpenCV/FreeImage/CImg/CxImage
本文转载自:http://hi.baidu.com/xiaocuiman/blog/item/6e267c2bc4b1883f5243c108.html 1.对OpenCV 的印象:功能十分的强大,而 ...
- ffmpeg学习笔记-音频播放
前文讲到音频解码,将音频解码,并且输入到PCM文件,这里将音频通过AudioTrack直接输出 音频播放说明 在Android中自带的MediaPlayer也可以对音频播放,但其支持格式太少 使用ff ...
- 最新 网龙网络java校招面经 (含整理过的面试题大全)
从6月到10月,经过4个月努力和坚持,自己有幸拿到了网易雷火.京东.去哪儿.网龙网络等10家互联网公司的校招Offer,因为某些自身原因最终选择了网龙网络公司.6.7月主要是做系统复习.项目复盘.Le ...
- axios二次封装的几种方法
一.用Class方法 import axios from "axios"; declare var Promise: any; export class Request { sta ...