//DOM 的 CRUD

// c 创建create

// 1.直接往body中动态的添加标签(可以是任意类型)
document.write('helloWorld');
document.write('<p>"helloworld"</p>');

// 2. 创建一个新的标签,然后插入到body中任意的一个标签中 appendChild
var div = document.createElement('div');
div.style.background = 'red';
div.style.width = '500px';
div.style.height = '300px';
// 添加到父标签
document.body.appendChild(div);

// 往div中插入一张图片
var img = document.createElement('img');
img.src = 'image/img_02.jpg';
div.appendChild(img);

// 拿到p标签
var img1 = document.createElement('img');
img1.src = 'image/img_03.jpg';

var p = document.getElementById('word');
p.appendChild(img1);

// 删除有3种方式: 1. 直接用body进行删除,但是只能作用于直接子标签
// 2. 拿到当前标签的父标签,再来删除
// 3. 直接拿当前的标签,调用 remove()方法.

document.body.removeChild(p);
// 拿到当前标签的父标签,再来删除
p.parentNode.removeChild(p);
p.remove();

// 改 拿到对应的标签,做出改变...

// 查
// 第一种方式:
document.getElementsByClassName();
document.getElementsByName();
document.getElementsByTagName();
document.getElementById();
// (注意:id返回一个值,其他的都是返回数组)

// 第二种方式:遍历标签内部的内容

find(document.body);

function find(object){
for(var i in object){
console.log(object[i]);
}
}

console.log(document.body.childNodes);

-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------

上一篇讲述了DOM的基本知识,从其得知,在DOM眼中,HTML的每个成分都可以看作是节点(文档节点、元素节点、文本节点、属性节点、注释节点,其中,属性节点是属于元素节点),本篇的内容就是通过DOM对这些节点进行增删改查的操作。

获取(R)

1. getElementById(id)、getElementsByName(name)、getElementsByTagName(tagName),这三种方法都会忽略文档的结构。

  • getElementById(id):通过id获取元素节点,如果页面上含有多个相同id的节点,那么只获取第一个节点,理论上,id在页面中应该是唯一的。jquery中通过$("#id")来获得节点,这种方式类似于css中的id选择器。
  • getElementsByName(name):通过name获取一组元素节点,返回的是具有相同name的节点数组。注意,这个方法在IE和W3C(FireFox、Chrome)下表现是不一样的,这个方法应该不是DOM LEVEL 1里的规范,IE支持LEVEL 1,和后来的标准就有很多差异了。主要有如下几点区别:
    • IE下通过getElementsByName(name)只能取得表单元素的节点;
    • IE下不区分id和name,也就是说通过getElementsByName(name)取得的节点数组也包含id和name相同的了,通过getElementById(id),也可以将name作为参数,看MSDN的官方说明。
    • When you use the getElementsByName method, all elements in the document that have the specified NAME or ID attribute value are returned. Elements that support both the NAME and the ID attribute are included in the collection returned by the getElementsByName method, but not elements with a NAME expando.
      1. <html>
      2. <head>
      3. <title>节点的增删改查</title>
      4. <script type="text/javascript">
      5. function init() {
      6. alert(document.getElementById("div1").nodeName);
      7. alert(document.getElementsByName("container").length);// IE结果是2,Chrome、FF结果是3
      8. alert(document.getElementById("container").value);// IE结果是1,Chrome、FF结果是2
      9. }
      10. </script>
      11. </head>
      12. <body onload="init()">
      13. <div id="div1" name="container">1</div>
      14. <!--<div id="div1"></div>-->
      15. <span id="div1" name="container">2</span>
      16. <input name="container" type="text" value="1" />
      17. <input id="container" type="text" value="2" />
      18. </body>
      19. </html>
  • getElementsByTagName(tagName):通过tagName获取一组元素节点,返回的是具有相同tagName的节点数组。这个方法的特殊之处在于不仅仅可以通过顶层document来使用,所有元素节点都可以使用。如:document.getElementById("container").getElementByTagName("div");,这跟css样式有些相像,比如定义id为container元素节点下的所有div样式:.container div{display:none;}。

2. parentNode、firstChild以及lastChild,这三种属性都可以递归来使用。

html实例:

    1. <html>
    2. <head>
    3. <title>节点的增删改查</title>
    4. </head>
    5. <body>
    6. <div id="level1">
    7. <div id="level21">
    8. <div id="level3"><div>
    9. </div>
    10. <div id="level22"></div>
    11. </div>
    12. </body>
    13. </html>
  • parentNode:取得当前节点的父节点,如document.getElementById("level21").parentNode,也可以obj.parentNode.parentNode.parentNode。
  • firstChild:取得当前节点的第一个子节点,如document.getElementById("level1").firstChild;,也可以document.getElementById("level1").firstChild.firstChild。
  • lastChild:取得当前节点的最后一个子节点,如document.getElementById("level1").lastChild。

3. 根节点,document.documentElement得到HTML以及XML文档中的根节点,document.body提供了对body节点的直接访问。

4. 所有子节点:childNodes和children,各种版本各种浏览器下表现都不一样。

5. 节点信息:nodeName(tagName)、nodeValue、nodeType.

  • nodeName

    • 元素节点的nodeName是标签名称
    • 属性节点的nodeName是属性名称
    • 文本节点的nodeName是#text
    • 文档节点的nodeName是#document
  • nodeValue
    • 文本节点的nodeValue包含文本
    • 属性节点的nodeValue包含属性值
    • 元素节点和文档节点没有nodeValue
  • nodeType
    • 元素类型 节点类型
      元素 1
      属性 2
      文本 3
      注释 8
      文档 9

创建(C)&修改(U)&删除(D)

       写一个点击单元格变为文本框的示例。

  1. <html>
  2. <head>
  3. <title>节点的增删改查</title>
  4. <script type="text/javascript">
  5. function appendInput(tdNode) {
  6. // 创建input元素节点,createElement创建元素节点,createTextNode(value)创建文本节点
  7. var inputNode = document.createElement("input");
  8. // 给input属性赋值
  9. inputNode.value = tdNode.innerText;
  10. inputNode.name = "value";
  11. // 删除单元格的文本节点,参数为要删除的子节点对象
  12. tdNode.removeChild(tdNode.firstChild);
  13. // 将input追加到单元格中,appendChild(node)将node追加到父节点末尾,insertBefore(node1, node2)是将node1加入到node2之前
  14. tdNode.appendChild(inputNode);
  15. // 聚焦input,在chrome下,光标直接定位到文本最右边,IE下确实最左边
  16. inputNode.focus();
  17. // 将光标移到文本最右边
  18. moveCursorToRight(inputNode);
  19. }
  20. /** 光标移到文本最右边 */
  21. function moveCursorToRight(obj) {
  22. var r = obj.createTextRange();
  23. r.moveStart('character', obj.value.length);
  24. r.collapse(true);
  25. r.select();
  26. }
  27. </script>
  28. </head>
  29. <body>
  30. <table>
  31. <tr>
  32. <td onclick="appendInput(this)">Hello!</td>
  33. </tr>
  34. </table>
  35. </body>
  36. </html>

【repost】DOM CRUD的更多相关文章

  1. 【转载】Dom篇

    一. 初探Dom     1. Dom介绍 二. Dom基础     1. window顶级对象     2. body.document对象事件     3. 通用的HTML元素的事件     4. ...

  2. 【前端】:Dom

    前言: 昨天写了篇关于JavaScript的,今天写篇Dom的(插入4个实例),写完之后感觉知识点还不少~ 内容当然会用到[前端]:JavaScript的知识.下篇博客会写关于jQuery~~ 一.D ...

  3. 【repost】H5总结

    1.新增的语义化标签: <nav>: 导航 <header>: 页眉 <footer>: 页脚 <section>:区块 <article> ...

  4. js【jquery】 - DOM操作

    1.修改元素样式 js方式: var div2 = document.getElementById("") div2.style.width = '200px'; div2.cla ...

  5. 【repost】Javascript操作DOM常用API总结

    Javascript操作DOM常用API总结 文本整理了javascript操作DOM的一些常用的api,根据其作用整理成为创建,修改,查询等多种类型的api,主要用于复习基础知识,加深对原生js的认 ...

  6. 【前端】DOM操作

    1 什么是DOM 全称 Document Object Model 文档对象模型. 一个web页面的展示,是由html标签组合成的一个页面,dom对象实际就是将html标签转换成了一个文档对象.可以通 ...

  7. 【repost】JavaScript 事件模型 事件处理机制

    什么是事件? 事件(Event)是JavaScript应用跳动的心脏 ,也是把所有东西粘在一起的胶水.当我们与浏览器中 Web 页面进行某些类型的交互时,事件就发生了.事件可能是用户在某些内容上的点击 ...

  8. 【repost】document.write的用处

    document.write的用处 document.write是JavaScript中对document.open所开启的文档流(document stream操作的API方法,它能够直接在文档流中 ...

  9. 【笔记】DOM探索基础篇(二)

    # 浏览器的渲染(HTML解析) ——参考: <前端必读:浏览器内部工作原理>http://kb.cnblogs.com/page/129756/ <谈谈DOMContentLoad ...

随机推荐

  1. BOM浏览器对象模型;

    1.window.open(url,ways) url是打开的网页地址 ways是打开方式(-blank:-self) 2.window.close()关闭窗口 3.浏览器的用户信息 window.n ...

  2. 引用类型中的push()、pop()、shift()方法

    /** * write by waitingbar1014 * time 2013.10.18 * 用途:常用于如一堆游戏激活码中获得抽取的值 * **/ //有以下一个数组: var arrayli ...

  3. javascript 高级程序设计 二

    这里我们直接进入主题: 在JS刚刚开始的时候,必须面临一个问题,那就是如何使的JS的加载和执行不会影响web核心语言HTML的展示效果,和HTML和谐共存. 在这个背景下<script>标 ...

  4. DNA甲基化测序方法介绍

    DNA甲基化测序方法介绍 甲基化 表观遗传学 DNA 甲基化是表观遗传学(Epigenetics)的重要组成部分,在维持正常细胞功能.遗传印记.胚胎发育以及人类肿瘤发生中起着重要作用,是目前新的研究热 ...

  5. CF Round #509 (Div. 2)

    前言:第一次打\(CF\),因为经验不足以及英语水平很烂,即便在机房大佬的带领下也是花了好久才读懂题目..\(A\)题直到\(11\)分钟才\(A\),题目一共才做了\(4\)题,太菜了.. A. H ...

  6. lazarus,synedit输入小键盘特殊符号的补丁

    unit synedittextdoublewidthchars2; // fix up chinese symbel width //by steven {$mode objfpc}{$H+} in ...

  7. 测试 Open Live Writer

    我要试试. 看看图片如何: 这是从电脑端上传的一个例子,如果编辑器里可以支持复制粘贴图片就好了. Open Live Writer 发布以后,还可在保存在本地,想起来的时候就修改一下. 再美化一下. ...

  8. XSS绕过速查表

    0x00 目录 0x01 常规插入及其绕过 1 Script 标签 绕过进行一次移除操作: <scr<script>ipt>alert("XSS")< ...

  9. 基于tomcat的solr环境搭建(Linux)

    ♥♥  solr是基于lucene的一个全文检索服务器,提供了一些类似webservice的API接口,用户可以通过http请求solr服务器,进行索引的建立和索引的搜索.索引建立的过程:用户提交的文 ...

  10. SVN基本操作 (zz)

    SVN基本操作 分类: LINUX 原文地址:SVN基本操作 作者:tuyer 文章摘要:SVN 基本操作:SVN是什么 Svn是一个离线的代码管理,可以多个人一起修改,然后再将修改的内容提交到Svn ...