原生JavaScript第四篇

原生js学习笔记4——BOM操作

  什么是DOM

  DOM:Do

  1. js的组成部分

  2. 一套标准,目前有DOM1和DOM2这两种标准

  我们可以使用DOM操作来操作页面中的元素。

  DOM节点

  子节点

  childNode:返回值一个数组,放的是父节点中所有的子节点

  nodeType:返回值是一个数组,1表示元素节点,3表示文本节点

  在某些浏览器中,如火狐,使用childNode获取所有元素节点时会把空格等一起或取出来,此时就需要使用nodeType来判断。

  示例:

<!DOCTYPE html><html lang="en"><head>

<meta charset="UTF-8">

<title>Document</title>

<script type="text/javascript">

// 使用childNode获取到所有的li标签,并将背景颜色改为红色

window.onload = function  () {

var oUl = document.getElementById(‘ul‘);

for (var i = 0; i < oUl.childNodes.length; i++) {

// 判断nodeType的值是否为1

if (oUl.childNodes[i].nodeType == 1) {

oUl.childNodes[i].style.backgroundColor = ‘red‘;

};

};

}

</script></head><body>

<ul id = ‘ul‘>

<li></li>

<li></li>

<li></li>

</ul></body></html>

  childern: 取子节点,与childNode相比,chlidren不会把非标签元素解析出来,不用担心兼容性问题

  父节点

  parentNode

  首尾子节点

  兄弟节点

  添加元素

  createElement(元素名):创建一个元素

  父元素.appendChild(子元素)将子元素添加进父元素中(添加在最后边)

  示例:点击一次按钮,添加一个li标签

<!DOCTYPE html><html lang="en"><head>

<meta charset="UTF-8">

<title>Document</title>

<script type="text/javascript">

window.onload = function() {

var oBtn = document.getElementById(‘btn‘);

var oUl = document.getElementById(‘ul‘);

var oText = document.getElementById(‘text‘);

oBtn.onclick = function () {

// 创建一个新标签

var oLi = document.createElement(‘li‘);

// 将输入框中的文字写在新li标签中

oLi.innerHTML = oText.value;

// 将新标签添加在父标签里

oUl.appendChild(oLi);

}

}

</script></head><body>

<input type="text" id = "text">

<input type="button" value="点击添加" id = "btn">

<ul id = "ul">

<li>hello</li>

</ul></body></html>

  父元素.insertBefore(子元素,在谁之前插入),在谁之前插入子元素

<!DOCTYPE html><html lang="en"><head>

<meta charset="UTF-8">

<title>Document</title>

<script type="text/javascript">

window.onload = function() {

var oBtn = document.getElementById(‘btn‘);

var oUl = document.getElementById(‘ul‘);

var oText = document.getElementById(‘text‘);

oBtn.onclick = function () {

// 创建一个新标签

var oLi = document.createElement(‘li‘);

// 将输入框中的文字写在新li标签中

oLi.innerHTML = oText.value;

// 将新标签添加在父标签里

// oUl.appendChild(oLi);

var aLi = document.getElementsByTagName(‘li‘);

// 在第0个元素之前插入新元素

oUl.insertBefore(oLi, aLi[0]);

}

}

</script></head><body>

<input type="text" id = "text">

<input type="button" value="点击添加" id = "btn">

<ul id = "ul">

<li>hello</li>

</ul></body></html>

  删除元素

  父元素.removeChild(要删除的元素):删除父元素中的某个子元素

  示例:点击删除,删除某个元素

<!DOCTYPE html><html lang="en"><head>

<meta charset="UTF-8">

<title>Document</title>

<script type="text/javascript">

window.onload = function() {

var oBtn = document.getElementsByTagName(‘a‘);

var oUl = document.getElementById(‘ul‘);

for (var i = 0; i < oBtn.length; i++) {

oBtn[i].onclick = function() {

oUl.removeChild(this.parentNode);

}

};

}

</script>

</head><body>

<input type="text" id = "text">

<input type="button" value="点击添加" id = "btn">

<ul id = "ul">

<li>hello<a href="javascript:;">删除</a></li>

<li>123<a href="javascript:;">删除</a></li>

<li>234<a href="javascript:;">删除</a></li>

<li>hel234lo<a href="javascript:;">删除</a></li>

</ul></body></html>

时间: 2024-11-01 01:49:27

原生JavaScript第四篇的相关文章

原生JavaScript第五篇

原生js学习笔记5--BOM操作 什么是BOM BOM:Browser Object Model 是浏览器对象模型,浏览器对象模型提供了独立与内容的.可以与浏览器窗口进行互动的对象结构,BOM由多个对象构成,其中代表浏览器窗口的window对象是BOM的顶层对象,其他对象都是该对象的子对象. 目前主流浏览器介绍 ? IE--11: 国内用得最多的IE浏览器,历来对W3C标准支持差.从IE10开始支持ES6标准: ? Sarafi:Apple的Mac系统自带的基于Webkit内核的浏览器,从OS

原生JavaScript第七篇

原生js学习笔记7--本地存储之cookie操作 什么是cookie ? 用来保存页面信息的,如用户名.密码 ? cookie的特性:同一个网站中所有的页面共享一套cookie:数量.大小限制:过期时间 ? js中使用cookie:document.cookie 如何设置cookie? 在js中,使用document.cookie = "键=值"即可,但是这种方式设置的cookie由于没有添加过期时间,所以关闭浏览器,cookie就丢失,我们要在后边继续加上expires=时间设置上过

原生JavaScript第八篇

原生js学习笔记8--Ajax基础   什么是Ajax 不刷新页面的情况下从服务器获取.提交数据的一种数据交互方式. Ajax使用步骤 1.创建Ajax对象 var httpRequest = new XMLHttpRequset可以创建一个Ajax请求对象. 注意:浏览器的兼容问题 IE6以及之前的IE不支持上边的创建爱你方法,这些版本的浏览器并没有集成Ajax,而是当做一个插件来处理,所以在创建时需要做兼容性处理: if (window.XMLHttpRequest) { xmlHttp =

原生JavaScript第六篇

原生js学习笔记6--事件 事件对象 鼠标事件 event.clientX在可视区中,鼠标点击的x坐标 event.clientY在可视区中,鼠标点击的y坐标 示例: <!DOCTYPE html><html lang="en"><head> <meta charset="UTF-8"> <title>Document</title> <script type="text/jav

原生JavaScript第三篇

原生js学习笔记3--数组 定义数组 两种方式定义一个数组: 1. var array1 = new array(1, 2, 3, 4); 2. var array2 = [1, 2, 3, 4]; 数组元素的插入删除 ? push(元素):从尾部添加新元素 ? unshift(元素): 从头部添加新元素 ? pop(),从尾部弹出元素 ? shift(),从头部弹出元素 从某个位置连续删除若干个元素 splice(起始位置,长度)该方法从起始位置开始,删除长度个元素 数组元素的插入插入若干个元

深入理解javascript作用域系列第四篇——块作用域

× 目录 [1]let [2]const [3]try 前面的话 尽管函数作用域是最常见的作用域单元,也是现行大多数javascript最普遍的设计方法,但其他类型的作用域单元也是存在的,并且通过使用其他类型的作用域单元甚至可以实现维护起来更加优秀.简洁的代码,比如块作用域.随着ES6的推广,块作用域也将用得越来越广泛.本文是深入理解javascript作用域系列第四篇——块作用域 let for (var i= 0; i<10; i++) { console.log(i); } 上面这段是很熟

四种常见的提示弹出框(success,warning,error,loading)原生JavaScript和jQuery分别实现

虽然说现在官方的自带插件已经有很多了,但是有时候往往不能满足我们的需求,下面我简单介绍一些 常见的四种提示弹出框(success,loading,error,warning),我分别用原生JavaScript和jQuery来介绍分享给各位博友! 一.首先介绍原生JavaScript来实现四种提示弹出框: 第一步:先看看html的建立 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http:

原生JavaScript技巧大收集(11~20)-(终于又被我找到这篇文章了)

11.原生JavaScript加入收藏夹 function AddFavorite(sURL, sTitle) { try { window.external.addFavorite(sURL, sTitle) } catch(e) { try { window.sidebar.addPanel(sTitle, sURL, "") } catch(e) { alert("加入收藏失败,请使用Ctrl+D进行添加") } } }   12.原生JavaScript设为

HTML5实战与剖析之原生拖拽(四可拖动dragable属性和其他成员)

可拖动dragable属性 之前我们已经为大家介绍过几篇有关HTML5中原生拖拽的相关知识了.今天为大家介绍HTML5拖拽中的其他一些小东东,闲话不多说赶快一起看看吧. 在默认情况下,链接.文本和图像是可以拖动的,不用再写代码即可拖动.如果想让其他元素标签也可以拖动,那么只有HTML5能实现了.HTML5为所有HTML元素规定了dragable属性,表示元素是否可以拖动.链接和图像的标签中自动将dragable属性自动被设置成true,其他元素的dragable属性的默认值是false. 支持d