JS2-DOM
API和Web API
API
应用程序编程接口,目的是提供应用程序与开发人员基于某软件或硬件得以访问一组例程的能力,且又无需访问源码,或理解内部工作机制的细节
API是给程序员提供的一种工具,以便能更轻松的实现想要的功能
Web API
是浏览器提供的一套操作浏览器功能和页面元素的API(BOM和DOM)
DOM
DOM是(Document Object Model)文档对象模型,是W3C组织推荐的处理可扩展标记语言的标准编程接口
可以通过DOM接口改变网页的结构、内容和样式
DOM树
- 文档:一个页面就是一个文档,DOM中使用document表示
- 元素:页面中所有标签就是元素,DOM中使用element表示
- 节点:网页中所有内容都是节点(标签、属性、文本、注释)等,DOM中使用node表示
DOM把以上内容都看作对象
获取元素
根据ID获取
getElementById
<div id="time">2010</div>
<script>
// 参数id是大小写敏感的字符串,返回的是一个元素对象
var timer = document.getElementById('time');
console.log(timer);
console.log(typeof timer);//返回object
//打印返回的元素对象,更好的查看里面的属性和方法
console.dir(timer);
</script>
根据标签名获取
//返回的是获取过来元素对象的集合 以伪数组的形式存储的
var lis = document.getElementsByTagName('li');
console.log(lis);
//如果页面中只有一个li,返回的还是伪数组,没有则是空的伪数组[]
可以指定父元素内部所有指定标签名的子元素
父元素必须是单个对象(必须指明是哪一个元素对象),获取的时候不包括父元素自己
var mm = document.getElementsByTagName('div');
console.log(mm[0].getElementsByTagName('li'));
通过类名获取
document.getElementsByClassName('box');//选择类名为box的对象
//指定选择器的第一个对象
document.querySelector('.box');
document.querySelector('#nav');//选择器必须加符号
//指定选择器的所有对象
document.querySelectorAll('.box');
获取body3元素
document.body;
获取html元素
document.documentElement;//得到整个html标签的内容
事件基础
执行事件的步骤:
- 获取事件源
- 注册事件(绑定事件)
- 添加事件处理程序
常见的鼠标事件
- onclick 鼠标左键按下
- onmouseover 鼠标经过
- onmouseout 鼠标离开
- onfouse 获得鼠标焦点触发
- onblur 失去鼠标焦点触发
- onmousemove 鼠标移动触发
- onmouseup 鼠标弹起触发
- onmousedown鼠标按下触发
操作元素
改变元素内容
element.innerText=
element.innerHTML=
- innerText不识别HTML标签,innerHTML识别,是W3C标准
- 这两个属性是可读写的
- 读的时候,innerText会去除标签空格和换行,innerHTML显示是完整的
修改常见元素属性
img.src换图
表单元素的属性操作
type、value、checked、selected、disabled
<script>
var btn = document.querySelector('button');
var input = document.querySelector('input');
btn.onclick = function () {
input.value = '被点击了';
// 禁用某个表单不能再点击用disabled
btn.disabled = true;
this.disabled=true;//this指向的是调用者
}
</script>
修改元素样式属性
- 使用element.style获得修改元素形式
this.style.backgroundColor='purple';
- JS里的样式采取驼峰命名法
- JS修改style样式操作,产生的是行内样式,css权重比较高
- 一般样式少,功能简单时使用
- 使用this.className='',然后在css里定义该类的样式属性
this.className='change';
- className是保留字,操作元素类名属性
- 会直接更改类名,覆盖原来的类名
- 如果想要保留原来的类名,可以使用多类名选择器
this.className='first change';
排他思想
给所有元素全部清除样式后,给当前元素设置样式,顺序不可以颠倒
var btns = document.getElementsByTagName('button');
for (var i = 0; i < btns.length; i++) {
btns[i].onclick = function () {
console.log('1');
for (var i = 0; i < btns.length; i++) {
btns[i].style.backgroundColor = '';
}
this.style.backgroundColor = 'pink';
}
}
自定义属性操作
获取属性值
- element.属性 只能获取内置属性值(元素自带)
- element.getAttribute('属性') 可以获取自定义属性(程序员自己添加)
- H5新增
element.dataset.index或者element.dataset['index'] ie11才开始支持
dataset是一个集合,存放了所有以data开头的自定义属性
更改属性值
element.属性='值'
element.setAttribute=('属性','值');
移除属性值
element.removeAttribute('属性');
H5自定义属性
自定义属性目的:为了保存并使用数据,有些数据可以保存到页面中而不用保存到数据库中
自定义属性容易引起歧义,不容易判断是元素的内置属性还是自定义属性
一般规定data-开头作为属性名如:data-index
如果自定义属性里面有多个-连接的单词,获取的时候采取驼峰命名法
节点操作
概述
获取元素通常有两种方法
- 利用DOM提供的方法获取元素 逻辑性不强
- 利用节点层级关系获取元素 利用父子兄节点关系获取元素,逻辑性强但是兼容性较差
网页中所有内容都是节点,在DOM中,节点使用node表示,节点至少拥有nodeType节点类型、nodeName节点名称、nodeValue节点值三个基本属性
- 元素节点nodetype为1
- 属性节点2
- 文本节点3(包括文字、空格、换行等)
实际开发中,节点操作主要操作的是元素节点
通过节点层级获取节点
利用DOM树把节点划分为不同的层级关系,最常见的是父子兄层级
父亲节点:
- node.parentNode
返回的是最近的父节点,如果找不到就返回空
子节点:
- parentNode.childNodes
得到的所有的子节点,包括文本节点(换行也会被计算进去)
如果想获取元素节点,需要专门处理(检测nodeType),一般不提倡使用
- parentNode.children(非标准),开发中常用
第一个子节点:
- parentNode.firstChild 返回第一个子节点,会返回文本
- parentNode.firstElementChild 返回第一个子元素节点
- parentNode.lastElementChild 返回最后一个子元素节点
有兼容性问题,IE9以上支持
实际开发的写法 既 没有兼容性问题又返回第一个元素
node.children[0]
node.children[node.children.length-1]
兄弟节点:
- node.nextSibling
得到的是下一个兄弟节点,包含元素节点和文本节点等等
- node.previousSibling
返回上一个兄弟节点,找不到返回null
- node.nextElementSibling 下一个元素节点
- node.previousElementSibling 上一个元素节点
有兼容性问题,只能自己封装一个兼容性的函数
创建节点
- document.createElement('tagment') 动态创建节点
- node.appendChild(child) 添加一个节点到指定父节点的子节点列表末尾,类似数组中的push
- node.insertBefore(child,指定元素) 将一个节点插入指定元素前面
- 想要页面添加新元素 ;创建;添加
删除节点
parentNode.removeChild(子节点);
复制节点
node.cloneNode()
把node节点复制一份,如果括号参数为空或者false,默认是浅拷贝,只复制标签,不复制内容
三种方式动态创建元素区别
- document.write()直接将内容写入页面的内容流,但是如果文档流已经执行完毕,则它会导致页面全部重绘
- innerHTML如果采取拼接字符串的方式,需要大量拼接字符串,效率较低,如果采用数组格式拼接,效率高,结构稍微复杂
- creatElement创建多个元素效率稍低一点点,但是结果更清晰
总结
创建
document.write
innerHTML
createElement
增
appendchild
insertBefore
删
removeChild
改
- 修改元素属性:src、href、title
- 修改普通元素内容:innerHTML、innerText
- 修改表单元素: value、type、disabled
- 修改元素样式:style、className
查
- DOM提供的API:getElementById、getElementByTagName
- H5提供的新方法 querySelector querySelectAll
- 利用节点操作:parentNode、children、previousElementSibling、nextElementSibling
属性操作
- setAttribute:
- getAttribute:
- removeAttribute:
事件操作
鼠标事件--
JS2-DOM的更多相关文章
- DOM window的事件和方法; Rails查询语法query(查询结构继承); turbolinks的局限;
window.innerHeight 是浏览器窗口可用的高度. window.outerHeight 是浏览器窗口最大的高度. 打开chrome-inspector,上下移动inspector,看到s ...
- 01慕课网《vue.js2.5入门》——基础知识
前端框架 Vue.js2.5 2018-05-12 Vue官网:https://cn.vuejs.org/ 基础语法+案例实践+TodoList+Vue-cli构建工具+TodoList Vue基础语 ...
- 浅谈Vue.js2.0某些概念
Vue.js2.0是一套构建用户界面的渐进式框架,目标是实现数据驱动和组件系统. A 渐进式框架 Vue.js是一个提供MVVM数据双向绑定的库,只专注于UI层面,这是它的核心.它本身没有解决SP ...
- 耗时近一个月,终于录完了VUE.JS2.0前端视频教程!
这次课录制的比较辛苦,圣诞节时原本已经快录制完成了,偶然的一次,播放了一下,感觉不满意,好几篇推倒重来,所以今天才结束. vue.js2.0是Vue.JS的最新版本,视频教程还不多,如果你看到了,学到 ...
- Vue学习笔记-Vue.js-2.X 学习(一)===>基本知识学习
一 使用环境: windows 7 64位操作系统 二 IDE:VSCode/PyCharm 三 Vue.js官网: https://cn.vuejs.org/ 四 下载安装引用 方式1:直接 ...
- 关于DOM的操作以及性能优化问题-重绘重排
写在前面: 大家都知道DOM的操作很昂贵. 然后贵在什么地方呢? 一.访问DOM元素 二.修改DOM引起的重绘重排 一.访问DOM 像书上的比喻:把DOM和JavaScript(这里指ECMScri ...
- 读书笔记:JavaScript DOM 编程艺术(第二版)
读完还是能学到很多的基础知识,这里记录下,方便回顾与及时查阅. 内容也有自己的一些补充. JavaScript DOM 编程艺术(第二版) 1.JavaScript简史 JavaScript由Nets ...
- 页面嵌入dom与被嵌入iframe的攻防
1.情景一:自己的页面被引入(嵌入)至别人的页面iframe中 if(window.self != window.top){ //url是自己页面的url window.top.location.hr ...
- 通俗易懂的来讲讲DOM
DOM是所有前端开发每天打交道的东西,但是随着jQuery等库的出现,大大简化了DOM操作,导致大家慢慢的“遗忘”了它的本来面貌.不过,要想深入学习前端知识,对DOM的了解是不可或缺的,所以本文力图系 ...
- HTML DOM 介绍
本篇主要介绍DOM内容.DOM 节点.节点属性以及获取HTML元素的方法. 目录 1. 介绍 DOM:介绍DOM,以及对DOM分类和功能的说明. 2. DOM 节点:介绍DOM节点分类和节点层次. 3 ...
随机推荐
- PaddleNLP基于ERNIR3.0文本分类:WOS数据集为例(层次分类)
相关项目链接: Paddlenlp之UIE模型实战实体抽取任务[打车数据.快递单] Paddlenlp之UIE分类模型[以情感倾向分析新闻分类为例]含智能标注方案) 应用实践:分类模型大集成者[Pad ...
- 在数据增强、蒸馏剪枝下ERNIE3.0分类模型性能提升
在数据增强.蒸馏剪枝下ERNIE3.0模型性能提升 项目链接: https://aistudio.baidu.com/aistudio/projectdetail/4436131?contributi ...
- HarmonyOS实战[二]—超级详细的原子化服务体验[可编辑的卡片交互]快来尝试吧
相关文章: HarmonyOS实战[一]--原理概念介绍安装:基础篇 [本文正在参与"有奖征文|HarmoneyOS征文大赛"活动] 1.创建HarmonyOS应用 选择Java程 ...
- 【分享】从Mybatis源码中,学习到的10种设计模式
作者:小傅哥 博客:https://bugstack.cn 沉淀.分享.成长,让自己和他人都能有所收获! 一.前言:小镇卷码家 总有不少研发伙伴问小傅哥:"为什么学设计模式.看框架源码.补技 ...
- 月薪40K+的测试老兵,测试开发学习实战心得分享
1. 前言 大家好,我是Arthur,拥有超过10年以上的银行测试经验,目前在一家互联网创业公司担任测试经理.在我们那个年代,基本上都是不会写代码的做测试工作,而且基本都是纯手工:最近几年,测试开发开 ...
- Vue核心概念与其指令
Vue简述 Vue是一套构建用户UI界面的前端框架. 构建用户界面的意思是:往html中填充数据,框架的意思是:一套开发规范. Vue的特点 1.数据驱动视图 当页面是一个普通的数据展示时,数据改 ...
- spring boot jar混淆加密
最近在做一个智能床垫的机构版项目,客户要求部署到客户那边要做代码混淆防止代码被反编译. 一:在需要加密的jar的pom.xml文件添加依赖 <!-- 设置 jitpack.io 仓库 --> ...
- CTAS建表时报错ORA-65114
环境: Oracle 19.16 多租户架构 1.问题现象: SQL> create table T1 as select * from v$active_session_history * E ...
- Oracle配置DCD避免会话被防火墙强制断开
今天有客户反馈应用测试连接Oracle数据库的会话半小时左右未做操作就会被中断,报错ORA-3113,询问数据库是否有这样的超时设置,能否取消掉这个限制? 登上环境查看监听日志发现连接的IP和数据库I ...
- Jackson objectMapper.readValue 方法 详解
直接说结论方便一目了然: 1. 简单的直接Bean.class 2. 复杂的用 TypeReference 这样就完事了. public class TestMain2 { public static ...