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标签的内容

事件基础

执行事件的步骤:

  1. 获取事件源
  2. 注册事件(绑定事件)
  3. 添加事件处理程序

常见的鼠标事件

  • 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>

修改元素样式属性

  1. 使用element.style获得修改元素形式
this.style.backgroundColor='purple';
  • JS里的样式采取驼峰命名法
  • JS修改style样式操作,产生的是行内样式,css权重比较高
  • 一般样式少,功能简单时使用
  1. 使用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'; }
}

自定义属性操作

获取属性值

  1. element.属性 只能获取内置属性值(元素自带)
  2. element.getAttribute('属性') 可以获取自定义属性(程序员自己添加)
  3. H5新增

element.dataset.index或者element.dataset['index'] ie11才开始支持

dataset是一个集合,存放了所有以data开头的自定义属性

更改属性值

element.属性='值'

element.setAttribute=('属性','值');

移除属性值

element.removeAttribute('属性');

H5自定义属性

自定义属性目的:为了保存并使用数据,有些数据可以保存到页面中而不用保存到数据库中

自定义属性容易引起歧义,不容易判断是元素的内置属性还是自定义属性

一般规定data-开头作为属性名如:data-index

如果自定义属性里面有多个-连接的单词,获取的时候采取驼峰命名法

节点操作

概述

获取元素通常有两种方法

  1. 利用DOM提供的方法获取元素 逻辑性不强
  2. 利用节点层级关系获取元素 利用父子兄节点关系获取元素,逻辑性强但是兼容性较差

网页中所有内容都是节点,在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

  1. 修改元素属性:src、href、title
  2. 修改普通元素内容:innerHTML、innerText
  3. 修改表单元素: value、type、disabled
  4. 修改元素样式:style、className

  1. DOM提供的API:getElementById、getElementByTagName
  2. H5提供的新方法 querySelector querySelectAll
  3. 利用节点操作:parentNode、children、previousElementSibling、nextElementSibling

属性操作

  1. setAttribute:
  2. getAttribute:
  3. removeAttribute:

事件操作

鼠标事件--

JS2-DOM的更多相关文章

  1. DOM window的事件和方法; Rails查询语法query(查询结构继承); turbolinks的局限;

    window.innerHeight 是浏览器窗口可用的高度. window.outerHeight 是浏览器窗口最大的高度. 打开chrome-inspector,上下移动inspector,看到s ...

  2. 01慕课网《vue.js2.5入门》——基础知识

    前端框架 Vue.js2.5 2018-05-12 Vue官网:https://cn.vuejs.org/ 基础语法+案例实践+TodoList+Vue-cli构建工具+TodoList Vue基础语 ...

  3. 浅谈Vue.js2.0某些概念

    Vue.js2.0是一套构建用户界面的渐进式框架,目标是实现数据驱动和组件系统.   A 渐进式框架 Vue.js是一个提供MVVM数据双向绑定的库,只专注于UI层面,这是它的核心.它本身没有解决SP ...

  4. 耗时近一个月,终于录完了VUE.JS2.0前端视频教程!

    这次课录制的比较辛苦,圣诞节时原本已经快录制完成了,偶然的一次,播放了一下,感觉不满意,好几篇推倒重来,所以今天才结束. vue.js2.0是Vue.JS的最新版本,视频教程还不多,如果你看到了,学到 ...

  5. Vue学习笔记-Vue.js-2.X 学习(一)===>基本知识学习

    一  使用环境: windows 7 64位操作系统 二  IDE:VSCode/PyCharm 三  Vue.js官网: https://cn.vuejs.org/ 四  下载安装引用 方式1:直接 ...

  6. 关于DOM的操作以及性能优化问题-重绘重排

     写在前面: 大家都知道DOM的操作很昂贵. 然后贵在什么地方呢? 一.访问DOM元素 二.修改DOM引起的重绘重排 一.访问DOM 像书上的比喻:把DOM和JavaScript(这里指ECMScri ...

  7. 读书笔记:JavaScript DOM 编程艺术(第二版)

    读完还是能学到很多的基础知识,这里记录下,方便回顾与及时查阅. 内容也有自己的一些补充. JavaScript DOM 编程艺术(第二版) 1.JavaScript简史 JavaScript由Nets ...

  8. 页面嵌入dom与被嵌入iframe的攻防

    1.情景一:自己的页面被引入(嵌入)至别人的页面iframe中 if(window.self != window.top){ //url是自己页面的url window.top.location.hr ...

  9. 通俗易懂的来讲讲DOM

    DOM是所有前端开发每天打交道的东西,但是随着jQuery等库的出现,大大简化了DOM操作,导致大家慢慢的“遗忘”了它的本来面貌.不过,要想深入学习前端知识,对DOM的了解是不可或缺的,所以本文力图系 ...

  10. HTML DOM 介绍

    本篇主要介绍DOM内容.DOM 节点.节点属性以及获取HTML元素的方法. 目录 1. 介绍 DOM:介绍DOM,以及对DOM分类和功能的说明. 2. DOM 节点:介绍DOM节点分类和节点层次. 3 ...

随机推荐

  1. trick1---实现tensorflow和pytorch迁移环境教学

    相关文章: [一]tensorflow安装.常用python镜像源.tensorflow 深度学习强化学习教学 [二]tensorflow调试报错.tensorflow 深度学习强化学习教学 [三]t ...

  2. 4.3 Windows驱动开发:监控进程与线程对象操作

    在内核中,可以使用ObRegisterCallbacks这个内核回调函数来实现监控进程和线程对象操作.通过注册一个OB_CALLBACK_REGISTRATION回调结构体,可以指定所需的回调函数和回 ...

  3. Python Requests 实现简单网络请求

    Python 是一种跨平台的计算机程序设计语言,面向对象动态类型语言,Python是纯粹的自由软件,源代码和解释器CPython遵循 GPL(GNU General Public License)协议 ...

  4. CE修改器入门:代码替换功能

    某些游戏重新开始时,数据会存储在与上次不同的地方, 甚至游戏的过程中数据的存储位置也会变动.在这种情况下,你还是可以简单几步搞定它.这次我将尽量阐述如何运用"代码替换"功能,第五关 ...

  5. RabbitMQ高级知识(消息可靠性,死信交换机,惰性队列,MQ集群)

    服务异步通信-高级篇 消息队列在使用过程中,面临着很多实际问题需要思考: 1.消息可靠性 消息从发送,到消费者接收,会经历多个过程: 其中的每一步都可能导致消息丢失,常见的丢失原因包括: 发送时丢失: ...

  6. Intel Arrow Lake处理器还是8+16 24核心:接口换LGA1851

    Intel已经确认,将在今年内发布未来两代处理器Arrow Lake.Lunar Lake,其中前者将弥补Meteor Lake的不足,同时用于笔记本.桌面.服务器,现在它的核心规格流出了. 这份曝光 ...

  7. 为Win12做准备?微软Win11 23H2将集成AI助手:GPT4免费用

    微软日前确认今年4季度推出Win11 23H2,这是Win11第二个年度更新. Win11 23H2具体有哪些功能升级,现在还不好说,但它会集成微软的Copilot,它很容易让人想到多年前的" ...

  8. 京豆薅羊毛新姿势-docker方式

    背景 上周看脉脉的时候看到下面这个帖子,领导让搞项目容器化,但是楼主没搞过,对新东西有畏惧感,怂了,然后把机会白白送给其他同事了. 想来我也是差不多这样的,刚到阿里工作的时候,有个好的项目机会来了,领 ...

  9. spring-cloud 配置管理

    作用: 实现配置热更新 实现网关配置热部署 配置模板 spring: datasource: driver-class-name: com.mysql.cj.jdbc.Driver url: jdbc ...

  10. MySQL主主+Keepalived架构安装部署

    需求:根据当前客户的生产环境,模拟安装部署一套MySQL主主+Keepalived架构的测试环境,方便后续自己做一些功能性的测试. 1.准备工作 2.MySQL安装部署 3.MySQL主主配置 4.K ...