##Jquery基础(三)

Jquery基础-DOM

##一、DOM 是 JavaScript 操作网页的接口,全称为“文档对象模型”(Document Object Model)。它的作用是将网页转为一个 JavaScript 对象,从而可以用脚本进行各种操作(比如增删内容)。

浏览器会根据 DOM 模型,将结构化文档(比如 HTML 和 XML)解析成一系列的节点,再由这些节点组成一个树状结构(DOM Tree)。所有的节点和最终的树状结构,都有规范的对外接口。

  ##1,节点类型

  ##1.1DOM 的最小组成单位叫做节点(node)。文档的树形结构(DOM 树),就是由各种不同类型的节点组成。每个节点可以看作是文档树的一片叶子。

  ##1.2节点的类型有七种:

  • Document:整个文档树的顶层节点
  • DocumentTypedoctype标签(比如<!DOCTYPE html>
  • Element:网页的各种HTML标签(比如<body><a>等)
  • Attribute:网页元素的属性(比如class="right"
  • Text:标签之间或标签包含的文本
  • Comment:注释
  • DocumentFragment:文档的片段

  注意:浏览器提供一个原生的节点对象Node,上面这七种节点都继承了Node,因此具有一些共同的属性和方法。

  ##1.3如何确定节点类型:

  Node有一个属性nodeType表示Node的类型,不同节点的nodeType属性值和对应的常量如下

      •     文档节点(document):9,对应常量Node.DOCUMENT_NODE
      •     元素节点(element):1,对应常量Node.ELEMENT_NODE
      •     属性节点(attr):2,对应常量Node.ATTRIBUTE_NODE
      •     文本节点(text):3,对应常量Node.TEXT_NODE
      •     文档片断节点(DocumentFragment):11,对应常量Node.DOCUMENT_FRAGMENT_NODE
      •     文档类型节点(DocumentType):10,对应常量Node.DOCUMENT_TYPE_NODE
      •     注释节点(Comment):8,对应常量Node.COMMENT_NODE

  ##1.4确定节点类型时,使用nodeType属性是常用方法。

      var node = document.documentElement.firstChild;
      if (node.nodeType === Node.ELEMENT_NODE) {
        console.log(‘该节点是元素节点‘);
      }

  这些Node类型中,我们最常用的就是 documentelementattribute这几种类型。

  参考: https://wangdoc.com/javascript/dom/node.html

##二、创建元素

  createElement

  语法:document.createElement`方法用来生成元素节点,并返回该节点。

    var div = document.createElement(‘div‘)

  ##2,1使用createElement要注意:通过createElement创建的元素并不属于html文档,它只是创建出来,并未添加到html文档中,要调用appendChild或insertBefore等方法将其添加到HTML文档树中。

  createTextNode

  createTextNode用来创建一个文本节点,用法如下

var newDiv = document.createElement(‘div‘);
var newContent = document.createTextNode(‘Hello‘);
newDiv.appendChild(newContent);
// <div>Hello</div>

  ##2,2上面代码新建一个div节点和一个文本节点,然后将文本节点插入div节点。

  这个方法可以确保返回的节点,被浏览器当作文本渲染,而不是当作 HTML 代码渲染。因此,可以用来展示用户的输入,避免 XSS 攻击。

var div = document.createElement(‘div‘);
div.appendChild(document.createTextNode(‘<span>Foo & bar</span>‘));
console.log(div.innerHTML)
// &lt;span&gt;Foo &amp; bar&lt;/span&gt;

  insertAdjacentElement

  Element.insertAdjacentElement方法在相对于当前元素的指定位置,插入一个新的节点。该方法返回被插入的节点,如果插入失败,返回null

 element.insertAdjacentElement(position, element);

  Element.insertAdjacentElement方法一共可以接受两个参数,第一个参数是一个字符串,表示插入的位置,第二个参数是将要插入的节点。第一个参数只可以取如下的值。

  • beforebegin:当前元素之前
  • afterbegin:当前元素内部的第一个子节点前面
  • beforeend:当前元素内部的最后一个子节点后面
  • afterend:当前元素之后
// HTML 代码:<body><div>some text</div></body>
var body = document.querySelector(‘body‘)
var p1 = document.createElement(‘p‘)
body.insertAdjacentElement(‘afterbegin‘, p1)
// 执行代码之后
// <body><p></p><div>some text</div></body>

  insertAdjacentHTML, insertAdjacentText

  Element.insertAdjacentHTML方法用于将一个 HTML 字符串,解析生成 DOM 结构,插入相对于当前节点的指定位置。

 element.insertAdjacentHTML(position, text);

  ##2,3该方法接受两个参数,第一个是一个表示指定位置的字符串,第二个是待解析的 HTML 字符串。position参数的值与 insertAdjacentElement的 position 取值相同

// HTML 代码:<div id="one">one</div>
var d1 = document.getElementById(‘one‘);
d1.insertAdjacentHTML(‘afterend‘, ‘<div id="two">two</div>‘);
// 执行后的 HTML 代码:
// <div id="one">one</div><div id="two">two</div>

  ##该方法只是在现有的 DOM 结构里面插入节点,这使得它的执行速度比innerHTML方法快得多。

  注意,该方法不会转义 HTML 字符串,这导致它不能用来插入用户输入的内容,否则会有安全风险。

  Element.insertAdjacentText方法在相对于当前节点的指定位置,插入一个文本节点,用法与Element.insertAdjacentHTML方法完全一致。

// HTML 代码:<div id="one">one</div>
var d1 = document.getElementById(‘one‘);
d1.insertAdjacentText(‘afterend‘, ‘two‘);
// 执行后的 HTML 代码:
// <div id="one">one</div>two

##三、修改元素

  appendChild

  appendChild()方法接受一个节点对象作为参数,将其作为最后一个子节点,插入当前节点。该方法的返回值就是插入文档的子节点。

var p = document.createElement(‘p‘);
document.body.appendChild(p);

  insertBefore

  insertBefore方法用于将某个节点插入父节点内部的指定位置。insertBefore方法接受两个参数,第一个参数是所要插入的节点newNode,第二个参数是父节点parentNode内部的一个子节点referenceNodenewNode将插在referenceNode这个子节点的前面。返回值是插入的新节点newNode



var p = document.createElement(‘p‘);
document.body.insertBefore(p, document.body.firstChild);
// 上面代码中,新建一个<p>节点,插在document.body.firstChild的前面,也就是成为document.body的第一个子节点。

  removeChild

  removeChild方法接受一个子节点作为参数,用于从当前节点移除该子节点。返回值是移除的子节点。

var divA = document.getElementById(‘A‘);
divA.parentNode.removeChild(divA);

  replaceChild

  replaceChild方法用于将一个新的节点,替换当前节点的某一个子节点。replaceChild方法接受两个参数,第一个参数newChild是用来替换的新节点,第二个参数oldChild是将要替换走的子节点。返回值是替换走的那个节点oldChild

var divA = document.getElementById(‘divA‘);
var newSpan = document.createElement(‘span‘);
newSpan.textContent = ‘Hello World!‘;
divA.parentNode.replaceChild(newSpan, divA);
// 将divA 替换成 newSpan

##四、查询节点

  ##4.1获取单个节点

  • document.getElementById

    根据元素id返回元素,返回值是Element类型,如果不存在该元素,则返回null。
    使用这个接口有几点要注意:
    (1)元素的Id是大小写敏感的,一定要写对元素的id
    (2)HTML文档中可能存在多个id相同的元素,则返回第一个元素
    (3)只从文档中进行搜索元素,如果创建了一个元素并指定id,但并没有添加到文档中,则这个元素是不会被查找到的

    // HTML代码为
    // <span id="myspan">Hello</span>
    var span = document.getElementById(‘myspan‘);
    span.id // "myspan"
    span.tagName // "SPAN"
  • document.querySelector

    Element.querySelector方法接受 CSS 选择器作为参数,返回父元素的第一个匹配的子元素。如果没有找到匹配的子元素,就返回null

    // 查找元素使用 document.querySelector() 函数
    // 这个函数的参数是一个选择器(和 CSS 选择器一样)
    // 选择器语法和 CSS 选择器一样, 现在只用 3 个基础选择器
    // 元素选择器
    var body = document.querySelector(‘body‘)
    // class 选择器, 用的是 .类名
    var form = document.querySelector(‘.login-form‘)
    // id 选择器, 用的是   #id
    var loginButton = document.querySelector(‘#id-button-login‘)
    // log 出来看看
    
    // 选择多个元素使用函数 querySelectorAll
    var buttons = document.querySelectorAll(‘.radio-button‘)
    // 还可以接受任何复杂的 CSS 选择器
    document.body.querySelector("style[type=‘text/css‘], style:not([type])");
    
    // 查找到的元素还可以继续用 querySelector
    var ul = document.querySelector(‘.ul‘)
    ul.querySelector(‘li‘)

  ##4.2获取多个节点

  • document.getElementsByTagName
  • document.getElementsByClassName
  • document.getElementsByName
  • document.querySelectorAll

  ##4.3获取父节

  parentElement 和 parentNode

  获取所有的后代节点

  children属性返回一个HTMLCollection实例,成员是当前节点的所有元素子节点。

  childNodes属性返回一个类似数组的对象(NodeList集合),成员包括当前节点的所有子节点,注意,除了元素节点,childNodes属性的返回值还包括文本节点和注释节点。

  children 和 childNodes 最大的区别就是:children 不会把空白节点算进去。

  ##4.4获取兄弟节点

  • previousSibling,nextSibling,previousElementSibling,nextElementSibling
  • 空白节点的坑,previousSibling,nextSibling会把空白节点算进去

  ##五、操作 CSS

    ##5.1style

// 在单个语句中设置多个样式
elt.style.cssText = "color: blue; border: 1px solid black";
// 或者
elt.setAttribute("style", "color:red; border: 1px solid blue;");

// 设置特定样式,同时保持其他内联样式值不变
elt.style.color = "blue";

    ##5.2classList

var element = document.querySelector(‘.active‘)
if (element != null) {
     // 使用 classList 可以访问一个元素的所有 class
     // remove 可以删除一个 class
     element.classList.remove("active")
}
element.classList.add(‘active‘) // 添加 active样式
element.classList.contains(‘active‘) //判断是否包含 active 样式
element.classList.toogle(‘active‘) // 如果存在 active 样式就删除,否则就添加

    ##5.3获取元素的位置

获取 DOM 元素相对于文档的位置,可以直接使用 offsetTop
获取 DOM 元素相对于视口的位置,可以使用 getBoundingClientRect()
获取 SVG 元素或行内元素的 CSS 盒子(比如用来做文本高亮时),可以使用 getClientRects();
获取绝对定位元素、伪元素的渲染后 CSS 属性,可以使用 getComputedStyle()

参考链接

获取网页的总宽高

document.body.clientWidth
document.body.clientHeight

获取视口(浏览器可见区域)的宽高

document.documentElement.clientWidth
document.documentElement.clientHeight

原文地址:https://www.cnblogs.com/liurui-bk517/p/11122808.html

时间: 2024-10-05 06:34:34

##Jquery基础(三)的相关文章

JQuery基础三

JQ选项卡实列<style> #div1 div{ width:200px; height:200px; border:1px red solid; display:none;} .active{ background:red;} </style> <script type="text/javascript" src="jquery-1.10.1.min.js"></script> <script> $(f

【jQuery基础学习】09 jQuery与前端(这章很水)

这章主要是将如何将jQuery应用到网站中,或者说其实就是一些前端知识,对于我这种后端程序来说其实还是蛮有用的. 关于网站结构 文件结构 前端文件分三个文件夹放 images文件夹用来存放将要用到的图片 styles文件夹用来存放css样式表 scripts文件夹用来存放js脚本 网页结构 头部:网站的品牌log,登录信息 内容:放置网站的主体内容 尾部:放置网站的其它友情链接和版权信息之类的 关于网站样式 首先写一个样式表,来包含全局的样式.定义整个网站的reset.css样式表,编写一些全局

Jquery基础之事件操作

事件是用户操作时页面或页面加载时引发的用来完成javascript和HTML之间的交互操作.常见的元素点击事件.鼠标事件.键盘输入事件等,较传Javascript 相比JQuery增加并扩展了基本的事件处理机制,极大的增强了事件处理的能力. 一.DOM加载事件 页面加载完毕后浏览器会通过javascript为Dom元素加载事件,使用Javascript时候使用的是window.onload方法,而Jquery使用的是$(document).ready()方法,下表 展示两个事件的异同.    w

Jquery基础之选择器

选择器是JQuery的根基,在JQuery中对事件处理.选择遍历Dom.ajax操作都依赖选择器.JQuery选择器分为基本选择器.层次选择器.过滤选择器.表单选择器. 一.基本选择器 1.ID选择器$("#ID") 页面中每个ID是唯一的,ID选择器选择每个ID元素,如下方法如下:$("#ID");例:$("#tbxName")这个方法选择id=tbxName的页面元素.选择结果为单个元素. 2.类选择器$(".class"

强大的JQuery(三)--操作html与遍历

前两篇博客讲到了JQuery的基础知识以及其动画效果,本篇将为大家介绍jquery操纵html以及jquery的遍历. 一.jquery操作html 1.获取内容和属性 text() - 设置或返回所选元素的文本内容 html() - 设置或返回所选元素的内容(包括 HTML 标记) val() - 设置或返回表单字段的值 attr()- 方法用于获取属性值. 实例: <span style="font-size:18px;">$("#btn1").cl

jQuery基础---Ajax进阶

原文:jQuery基础---Ajax进阶 内容提纲: 1.加载请求 2.错误处理 3.请求全局事件 4.JSON 和 JSONP 5.jqXHR 对象 发文不易,转载请注明出处! 在 Ajax 基础一篇中,我们了解了最基本的异步处理方式.本篇来了解一下 Ajax 的一些全局请求事件.跨域处理和其他一些问题. 一.加载请求 在 Ajax 异步发送请求时,遇到网速较慢的情况,就会出现请求时间较长的问题.而超过一定时间的请求, 用户就会变得不再耐烦而关闭页面. 而如果在请求期间能给用户一些提示,比如:

《jQuery基础教程》读书笔记

最近在看<jQuery基础教程>这本书,做了点读书笔记以备回顾,不定期更新. 第一章第二章比较基础,就此略过了... 第三章 事件 jQuery中$(document).ready()与javascript原生的window.onload()区别: $(document).ready():通过该方法注册的事件处理程序,会在DOM完全就绪并使用时调用.虽然这意味着所有元素对脚本而言都是可访问的,但是,却不意味着所有关联的文件都下载完毕.当HTML下载 完成并解析成DOM树之后,代码就可以开始运行

jQuery基础——事件篇

jQuery基础--事件篇 鼠标事件 click与dbclick事件 click方法监听用户单击操作,dbclick监听用户双击操作,这两个方法类似. dbclick与click事件不同的是: click事件触发需要以下几点: click事件其实是由mousedown与mouseup 2个动作构成,所以点击的动作只有在松手后才触发 dblclick事件触发需要以下几点: dblclick又是由2个click叠加而来的,所以dblclick事件只有在满足以下条件的情况下才能被触发 鼠标指针在元素里

Jquery基础教程第二版学习记录

本文仅为个人jquery基础的学习,简单的记录以备忘. 在线手册:http://www.php100.com/manual/jquery/第一章:jquery入门基础jquery知识:jquery能做什么:为什么需要jquery. 第二章:选择符工厂函数$()css选择符属性选择符自定义选择符DOM遍历方法 第三章:事件jQuery.noConflict([extreme]):运行这个函数将变量$的控制权让渡给第一个实现它的那个库.常用方法:(包括键盘,鼠标事件)blur([[data],fn]