DOM操作二三事
我突然想起了append(),但是我记不太清它是原生JS的还是jQuery封装的,貌似是JS的,咦?那它在jQuery里叫什么来着?哎呀!记不清了!确定append()是JS里的?不是jQuery里的?哎呀!这个问题好low啊,要是被那些大牛知道得笑死我了!赶紧偷偷整理一下!
获取节点内容/修改节点内容
原生JS方法
<div id="test">test</div>
<script>
alert(document.getElementById("test").innerHTML);
document.getElementById("test").innerHTML += "test";
</script>
jQuery方法
text()
<div id="test"><h1>test</h1></div>
<script>
//返回test
alert($("#test").text());
$("#test").text(" new test");
</script>
html()
<div id="test"><h1>test</h1></div>
<script>
//返回<h1>test</h1>
alert($("#test").html());
$("#test").html("<h1>new test</h1>");
</script>
属性操作
原生JS方法
<div id="test" style="width:100px; height:100px; background:red;"></div>
<script>
document.getElementById("test").style.background="yellow";
alert(document.getElementById("test").style.background);
document.getElementById("test").setAttribute("width","200px");
alert(document.getElementById("test").getAttribute("width"));
</script>
注意:在使用setAttribute()后,元素的宽度并未发生改变,究其原因,在debug界面可以看到
<div id="test" style="width: 100px; height: 100px; background: yellow;" width="200px"></div>
width被写在style外面,而真正生效的是style里的width
再看CSS管理器里
element.style {
width: 100px;
height: 100px;
background: yellow;
}
width仍然没有变化...如果不在行间写style写在<style>标签里呢?仍然没有用!因为setAttribute()并不会对element.style发生作用,而element.style的优先级是最高的。
所以在使用setAttribute()时要谨慎,没事就别瞎用了。
jQuery方法
<div id="testDiv" style="width:100px; height:100px; background:red;"></div>
<a href="www.cnblogs.com" id="testLink">cnblogs</a>
<script>
alert($("#testDiv").attr("background-color"));
alert($("#testLink").attr("href"));
$("#testDiv").attr("background-color","yellow");
$("#testLink").attr("href","www.baidu.com");
alert($("#testDiv").attr("background-color"));
alert($("#testLink").attr("href"));
</script>
你会发现a的href是有用的,div的background-color是undefined,换成width还是undefined。我也不知道为什么,总之谨慎使用吧。
<div id="test" style="width:100px; height:100px; background:red;"></div>
<script>
alert($("#test").css("background-color"));
$("#test").css({"background-color":"yellow"});
</script>
用css()方法比较稳定,它是CSS类的一个方法,和addClass()/removeClass()/toggleClass()一样。
节点操作
原生JS方法
<div id="testDiv"></div>
<script>
var testSpan = document.createElement("span");
var testText = document.createTextNode("Test");
testSpan.appendChild(testText);
document.getElementById("testDiv").appendChild(testSpan);
</script>
重复插入是没用的,九浅一深什么的都是没有用的,你只能换着姿势插
<div id="testDiv">
<p id="testP">Test</p>
</div>
<script>
var testSpan = document.createElement("span");
var testText = document.createTextNode("Test");
testSpan.appendChild(testText); var testDiv = document.getElementById("testDiv");
var testP = document.getElementById("testP"); testDiv.insertBefore(testSpan,testP);
</script>
或者替换
<div id="testDiv">
<p id="testP">Test</p>
</div>
<script>
var testSpan = document.createElement("span");
var testText = document.createTextNode("TestReplace");
testSpan.appendChild(testText); var testDiv = document.getElementById("testDiv");
var testP = document.getElementById("testP"); testDiv.replaceChild(testSpan,testP);
</script>
或者干脆删掉
<div id="testDiv">
<p id="testP">Test</p>
</div>
<script>
var testDiv = document.getElementById("testDiv");
var testP = document.getElementById("testP"); testDiv.removeChild(testP);
</script>
jQuery方法
<div id="testDiv">
<p id="testP">Test Paragraph</p>
</div>
<script>
$("#testDiv").append("Append Test");
$("#testDiv").append("<p>Element Append Test</p>");
$("#testDiv").prepend("<p>Prepend Test</p>"); $("#testP").before("Before Test");
$("#testP").after("after Test");
</script>
用jQuery则要简单很多,不需要创建节点插来插去,只需要干着插,深深猛插。而且姿势也更多,原生JS只能正常插和从前面插,而jQuery不仅能正常插从前面插,还能在最前面插,在最后面插以及从某个部位的后面插,花样繁多,高下立判。
但是jQuery没有replace方法,但是人家提出了empty()清空子元素
<div id="testDiv">
<p id="testP">Test Paragraph</p>
</div>
<script>
$("#testDiv").empty();
</script>
还有remove(),可以自杀
<div id="testDiv">
<p id="testP">Test Paragraph</p>
</div>
<script>
$("#testP").remove();
</script>
换着姿势杀
<div id="testDiv">
<p id="testP">Test Paragraph</p>
</div>
<script>
$("p").remove("#testP");
</script>
比原生JS不知道高到哪里去了
遍历操作
原生JS方法
<script>
document.getElementById("test").firstChild;
document.getElementById("test").lastChild;
document.getElementById("test").parentNode;
document.getElementById("test").childNodes[0];
</script>
基本就这样了
jQuery方法
<script>
//祖先
//返回向上一级的父元素
$("test").parent();
//返回向上所有的祖先元素直到根节点
$("test").parents();
//返回介于两者之间的所有祖先元素
$("test").parentsUntil(test2); //子孙
$("test").children();
$("test").children("p.testP");
$("test").find("span");
$("test").find("*"); //兄弟
//前后找,过滤找
$("test").siblings();
$("test").siblings("p");
//往后找
$("test").next();
$("test").nextAll();
//往前找
$("test").pre();
$("test").preAll(); //过滤
//找第一个
$("test").first();
//找最后一个
$("test").last();
//按索引找
$("test").eq(0);
//按条件找
$("test").filter(".testFilter");
//筛选出来找
$("test").not(".testFilter");
</script>
简直无情,已经把原生JS秒出十条街了。
写在结尾
库再好也只是库,是别人的东西,怎样做出自己的库,做出自己的库的方法才是最重要的。jQuery也只是对原生JS的封装,却能绽放出比原生JS更耀眼的魅力,它的源码才是真正的关键所在。学习思维和方法,永远比学习流于表面的代码重要。这篇笔记仅仅是为了我能够不搞混原生JS和jQuery而记录的,仅此而已。
PS:好吧,原生JS里根本就没有append()方法,我终于搞清楚了。
DOM操作二三事的更多相关文章
- jQuery的dom操作(二)转
addClass() 向匹配的元素添加指定的类名. after() 在匹配的元素之后插入内容. append() 向匹配的元素内部追加内容. appendTo() 向匹配的元素内部追加内容. attr ...
- Jquery:Jquery中的DOM操作<二>
由于昨天晚上回来的晚,写的有点匆忙,所以昨天的学习笔记中出现了多处错误的地方,幸好有各位园友帮忙指出,在这里谢过各位了!今天继续学习关于Jquery中DOM的操作,其实是昨天随笔的延续,求围观!!! ...
- javascript的DOM操作(二)
<html> <title>学习DOM</title> <a id="wen">文本</a> <input nam ...
- DOM操作二
1.创建节点 createElement(): 创建新的Element节点 var s = document.createElement('script'); createTextNode(): ...
- jQuery学习笔记(二)jQuery中DOM操作
目录 DOM操作分类 jQuery中的各种DOM操作 查找节点 创建节点 删除节点 复制节点 替换节点 包裹节点 属性操作 样式操作 对HTML.文本和值的操作 遍历节点 CSS-DOM操作 小结 本 ...
- JavaScript的BOM、DOM操作、节点以及表格(二)
BOM操作 一.什么是BOM BOM(Browser Object Model)即浏览器对象模型. BOM提供了独立于内容 而与浏览器窗口进行交互的对象: BOM由一系列相关的对象构成 ...
- 前端学习(二十三)DOM操作,事件(笔记)
javascript 组成部分 1.ECMAScript javascript的核心解释器 2.DOM Document Object Modle 文 ...
- jQuery笔记(二)jQuery中DOM操作
前言 本篇主要介绍DOM操作,在说DOM操作之前,首先我们应该熟悉DOM树,以一个例子为例来说明DOM树.首先看这段HTML代码.(本文后面的代码如果没有特别指出,都是针对下述HTML代码进行操作) ...
- javascript学习(二) DOM操作HTML
一:DOM操作HTML JavaScript能够改变页面中所有的HTML元素 JavaScript能够改变页面中所有的HTML属性 JavaScript能够改变页面中所有的CSS样式 JavaScri ...
随机推荐
- 【数位dp】Enigma
http://codeforces.com/gym/101889 E 与一般数位dp不同,保存的是能否满足条件,而非记录方案数 代码: #include <iostream> #inclu ...
- 期中HTML代码及技术博客
<!DOCTYPE html> <html lang="en"> <head> <meta charset="U ...
- C++ Primer Plus学习:第七章
C++入门第七章:函数-C++的编程模块 函数的基本知识 要使用C++函数,必须完成如下工作: 提供函数定义 提供函数原型 调用函数 库函数是已经定义和编译好的函数,可使用标准库头文件提供原型. 定义 ...
- find . -name file -exec echo abc > {} \; fail
find . -name file -exec echo abc > {} \; fail 应该改用: find . -name file -exec bash -c 'echo abc > ...
- 数据挖掘聚类算法(DBSCAN、Kmeans)Java实现
学习聚类算法时,参考算法说明随手写的java实现,代码很简单,不多做说明啦,有需要的童鞋可以看看,自己也做个备录. http://files.cnblogs.com/files/yuananyun/% ...
- 1 RabbitMQ 安装,配置
1:安装 yum install -y rabbitmq-server 2:主要程序介绍 # 管理插件的程序 /usr/sbin/rabbitmq-plugins # 服务程序 /usr/sbin ...
- 【转载】mysql建表date类型不能设置默认值
如题,mysql建表date类型的不能设置一个默认值,比如我这样: CREATE TABLE `new_table` ( `biryhday` datetime NULL DEFAULT '1996- ...
- Java 面试前的基础准备 - 01
使用这个在线网页编辑真的是不习惯,还是 windows live writer 好. 下面列一个清单用于最近的面试:( 清单是网上down的 ) static,final,transient 等关键字 ...
- Delphi编程防止界面卡死的方法经验分享
Delphi编程防止界面卡死的方法经验分享! 1.循环里面防止界面卡死的方法可以使用Application.ProcessMessages: 例如下列方法: var n: Integ ...
- 【51Nod1773】A国的贸易 FWT+快速幂
题目描述 给出一个长度为 $2^n$ 的序列,编号从0开始.每次操作后,如果 $i$ 与 $j$ 的二进制表示只差一位则第 $i$ 个数会加上操作前的第 $j$ 个数.求 $t$ 次操作后序列中的每个 ...