jQuery DOM操作 基于命令改变页面

呃,貌似是广告哈?呵呵,不过的确是这样,jQuery为我们提供了丰富的DOM操作方法,使这些复杂的DOM操作变得简单。
继上一回写jQuery的笔记貌似已经过去很长时间了,这一节也确实有必要写一下了,呵呵,Let's Go~
操作属性:
之前,我们说过.addClass()及.removeClass()方法,更改的其实也是DOM的属性:className。
说到这就得再提一下,为啥元素的类名叫做className而不是直接叫class,因为class是js的保留字。嗯。
那么除了class,DOM元素的其它属性,如:id、rel及href之类的,对于这些属性我们咋操作?
别急,jQuery提供了.attr()和.removeAttr()方法。
甚至,你也可以用这两个方法来替代.class()方法——如果你想给自己找点麻烦的话,呵呵。。
下面,让我们把红色的字,变成绿色的,而且,我喜欢GOOGLE,但是有一些人喜欢百度,那么好,让我们选择自己喜欢的。


代码如下:

这里有个超链接,超链接的地址为<a href='http:/www.baidu.com' target='_blank' class='link'>百度</a>
<br/>
点击这个按钮,让百度变GOOGLE,再点一下就让它再变回百度<input type='button' value='变GOOGLE吧' id='but_link'/>
<br/><br/>
这里有几个字,字的颜色呢,是红色的,<font color='red' class='font'>我是红色,我是红色</font>
<br/>
点击这个按钮,让红色变绿色<input type='button' value='变绿色吧' id='but_color'/>

代码如下:

$(document).ready(function(){
$('#but_link').toggle(function(){
$('.link').attr('href','http://www.google.com');
$('.link').text('GOOGLE');
$(this).attr('value','变BAIDU吧');
},function(){
$('.link').attr('href','http://www.baidu.com');
$('.link').text('百度');
$(this).attr('value','变GOOGLE吧');
});
$('#but_color').toggle(function(){
$('.font').attr('color','green');
$('.font').text('我是绿色,我是绿色');
$(this).attr('value','变红色吧');
},function(){
$('.font').attr('color','red');
$('.font').text('我是红色,我是红色');
$(this).attr('value','变绿色吧');
});
});

如果想要循环对一些DOM对象做处理,比如书中的例子,想要对一个DIV下的每个A标签都给其一个唯一的ID
那么就可以用到jQuery的.each()方法,其类似于一个迭代器,有点像PHP的foreach


代码如下:

$(document).ready(function() {
$('div.chapter a').each(function(index) {
$(this).attr({
'id': 'wikilink-' + index,
});
});
});

这个index参数类似于一个计数器,对第一个链接它的值为0,然后对每个后续的链接它的值会递增1。依此类推。
呃,稍候这些例子,我一起给出演示地址。不过很无奈的是,我国外空间的那个地址被墙了。嗯。
深入理解$()工厂函数:
其实,从刚开始记这个笔记我们就在用这个工厂函数。
在某种意义上来说,这个函数在jQuery库中牌最核心的位置,因为无论在添加效果、事件
还是为匹配的元素集合添加属性时,都离不开它。
然而,除了选择元素之外,$()函数的圆括号内还有另一个玄机——这个强大的特性使得$()函数不仅能够改变页面的视觉外观,
更能改变页面中实际的内容。只要在这对圆括号中放入一组HTML元素,就能轻而易举地改变整个DOM结构。
例如,书中的例子是很恰当的,因为我确实写过FAQ。。。
而FAQ总是一问一答型的(自问自答型的)。那么,因为有的答案太长,所以要在其后面加一个Back to top
可以这样写


代码如下:

$(document).ready(function){
$('<a href="#top">back to top</a>');
$('<a id="top"></a>');
});

这样就为每个段落后面加了一个超链接“Back to top”,并且也添加了一个”top”锚。
啥?你说你没看见?呃,好吧。。我承认因为我还没有插入这个新元素至DOM中,只是创建了出来。
插入新元素:
jQuery提供了两种将元素插入到其他元素前面的方法:.insertBefore()和.before()。
这两个方法作用相同,它们的区别取决于如何将它们与其他方法进行连缀。
那么,很自然的,聪明的你一定会想到,插入到其他元素后面的方法就是.insertAfter()和.after()。
对于刚才的”back to top”我们使用.insertAfter()方法,原因就是我们要在每个答案后面加上这个链接。。嗯。


代码如下:

$(document).ready(function){
$('<a href="#top">back to top</a>').insertAfter('div.chapter p');
$('<a id="top"></a>');
});

通过.after()方法也能完成与.insertAfter()相同的任务,只不过必须把选择符表达式放在这个方法的前面,而不是后面。
在使用.after()方法时,$(document).ready()中的第一行代码可以改写成如下所示:
$('div.chapter p').after('<a href="#top">back to top</a>');
使用.insertAfter(),可以通过连缀更多方法连续地对所创建的<a>元素进行操作。
而使用.after(),连缀的其他方法的操作对象就变成了$('div.chapter p')中选择符匹配的元素。
那么,要在元素内插入新的元素咋办啊?刚才说的这些都是使其成为兄弟元素。而怎么插入子元素呢?
别急,有.prependTo()方法呢。


代码如下:

$('<a id="top" name="top"></a>').prependTo('body');

.prependTo()方法插入了作为目标的描,我们就为页面添加了一组功能完备的back to top链接。
同样,jQuery还提供了一个方法是.prepend(),看API其作用为:
向每个匹配的元素内部追加内容。
这个操作与对指定的元素执行appendChild方法,将它们添加到文档中的情况类似。
例如:


代码如下:

<p>I would like to say: </p>
<!-- 执行完效果 -->
<!--
<p>I would like to say: <b>Hello</b></p>
-->$("p").append("<b>Hello</b>");

包装元素:
jQuery中用于将元素包装在其他元素中的方法,被贴切地命名为:.wrap()。
如果,要将一个
<p>Test Paragraph.</p><div id="content"></div>
里面的<p>标签包在div里面,
<div id="content"><p>Test Paragraph.</p></div><div id="content"></div>
就可以这样来写
$("p").wrap(document.getElementById('content'));
复制元素:
重头戏终于出来了。。嗯。复制元素。。
现年头都实行克隆,不过最近好像很少喊了。喊的最多的就是要克隆人。想想都奇怪。 克隆完后抢你老婆咋办?
呃。闲话少说吧。。jQuery的克隆方法就是.clone()。嗯。相对于插入方法,相当于复制和粘贴。
默认情况下,.clone()方法不仅会复制匹配的元素,也会复制其所有的后代元素。
书上说这个方法也是接受参数的,如果参数值为false,那么就只会复制匹配的元素,而不复制其子元素。
不过我试验后不是这样的。。嗯。


代码如下:

<div id="xxx"><p>我可是有内容的DIV</p></div>
<input type='button' id='but_clone' value='复制嘿嘿' /> $('#but_clone').click(function(){
$('#xxx').clone(false).insertAfter($('#xxx'));
});

书上说clone(false)不会复制子标签里的内容,但是我的实验是仍然会复制子标签内容。。这是一处不同。
另外,书上说clone()不会复制元素的事件。这个我试验后也是可以的。。嗯。。还是奇怪。。唉。

当需要多次引用一个jQuery对象时,最佳方式就是把它们保存到变量中。
这样,通过减少对jQuery的$()工厂函数的调用,能够提高遍历DOM的速度。。
呃,这一章就简单的记录完了。有些遗憾,因为没办法按书中的例子来给大伙讲解。那样就是在抄这本书了。
断断续续的,因为中等要吃饭。所以这节写了很长时间,总体效果嘛,自己还算满意哈。呵呵。
下面,把书中的这一段抄下来吧。嗯。就是
DOM操作方法的简单归纳:
要在每个匹配的元素中插入新元素,使用:
.append()
.appendTo()
.prepend()
.prependTo()
要在每个匹配的元素相信的位置上插入新元素,使用:
.after()
.insertAfter()
.before()
.insertBefore()
要在每个匹配的元素外部插入新元素,使用:
.wrap()
要用新元素或文本替换每个匹配的元素,使用:
.html()
.text()
要移除每个匹配的元素中的元素,使用:
.empty()
要从文档中移除每个匹配的元素及其后代元素,但不实际删除它们,使用:
.remove()

jQuery 更改元素属性实例

这里有个超链接,超链接的地址为百度

点击这个按钮,让百度变GOOGLE,再点一下就让它再变回百度

这里有几个字,字的颜色呢,是红色的,我是红色,我是红色

点击这个按钮,让红色变绿色

Clone Me!

我可是有内容的DIV

$(document).ready(function(){
$('#but_link').toggle(function(){
$('.link').attr('href','http://www.google.com');
$('.link').text('GOOGLE');
$(this).attr('value','变BAIDU吧');
},function(){
$('.link').attr('href','http://www.baidu.com');
$('.link').text('百度');
$(this).attr('value','变GOOGLE吧');
});
$('#but_color').toggle(function(){
$('.font').attr('color','green');
$('.font').text('我是绿色,我是绿色');
$(this).attr('value','变红色吧');
},function(){
$('.font').attr('color','red');
$('.font').text('我是红色,我是红色');
$(this).attr('value','变绿色吧');
});

$('button').click(function(){
$(this).clone().insertAfter(this);
});

$('#but_clone').click(function(){
$('#xxx').clone(false).insertAfter($('#xxx'));
});

$('#but_fun').click(function(){
$(this).clone().insertAfter(this);
});
});

[Ctrl+A 全选 注:如需引入外部Js需刷新才能执行]

代码打包下载

(0)

相关推荐

  • jQuery学习笔记之jQuery的DOM操作

    一.节点的操作 1.查找节点: var $var_1=$("htmltype");   //这句话就是获取所有htmltype节点 如:var $ul_1=$("ul"); 2.创建并追加节点: var $var_1=$("<htmltype>");//这句话是创建一个节点 $("htmltype2").append($var_1) ; //这句话是把节点插入所有htmltype2节点中 例子:var $li_1=

  • jQuery DOM删除节点操作指南

    下面示例可能用到如下HTML代码: 复制代码 代码如下: <ul>   <li title="t1">苹果</li>   <li>香蕉</li>   <li>橘子</li>   <li>葡萄</li>   <li>草莓</li> </ul> 1.remove()方法: 作用:从DOM中删除所有匹配的元素,传入的参数用于根据jQuery表达式来筛

  • jQuery移动和复制dom节点实用DOM操作案例

    本文章简单的介绍了关于jQuery移动和复制dom节点程序实现,有需要学习的朋友可参考参考. 在做一个项目时,需要dom节点移动,如以下代码: 复制代码 代码如下: <div></div> <p></p> 需要把p标签移动到div标签里,经过测试发现,在jQuery中移动dom节点非常方便: 复制代码 代码如下: $('div').append($('p')) 这样即可把p标签移动到div标签里,千万不要写成这样: 复制代码 代码如下: $('div').a

  • jQuery的DOM操作之删除节点示例

    如果文档中某一个元素多余,那么应将其删除.jQuery提供了两种删除节点的方法,remove()方法和empty()方法. 1. remove(): <%@ page contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%> <html> <head> <meta http-equiv="Content-Type" content=&quo

  • jQuery 选择器、DOM操作、事件、动画

    Jquery选择器 $(document).ready(function(){}) $(function(){}) 如果获取的对象是jQuery对象,那么在变量前面加上$,例如:var $variable=jQuery对象 选择器 1, 判断页面是否存在某元素:if($("#tt").length>0){} 或者if($("#tt")[0]){}; 2, 基本选择器 $("#test") 选择id为test的元素 $(".test

  • jQuery使用手册之二 DOM操作

    属性我们以<img id="a" scr="5.jpg"/>为例,在原始的javascript里面可以用var o=document.getElementById('a')取的id为a的节点对象,在用o.src来取得或修改该节点的scr属性,在jQuery里$("#a")将得到jQuery对象[ <img id="a" scr="5.jpg"/> ],然后可以用jQuery提供的很多

  • jQuery DOM操作 基于命令改变页面

    呃,貌似是广告哈?呵呵,不过的确是这样,jQuery为我们提供了丰富的DOM操作方法,使这些复杂的DOM操作变得简单. 继上一回写jQuery的笔记貌似已经过去很长时间了,这一节也确实有必要写一下了,呵呵,Let's Go~ 操作属性: 之前,我们说过.addClass()及.removeClass()方法,更改的其实也是DOM的属性:className. 说到这就得再提一下,为啥元素的类名叫做className而不是直接叫class,因为class是js的保留字.嗯. 那么除了class,DO

  • jQuery DOM操作小结与实例

    DOM操作的分类:DOM CORE(核心).HTML-DOM和CSS-DOM 1. DOM Core DOM Core并不专属于javascript,任何一种支持DOM的程序设计语言都可以使用它. 它的用途并非仅限于处理网页,也可以用来处理任何一种使用标记语言编写出来的文档,如XML. Javascript中的getElementById(),getElementByTagName(),getAttribute()和setAttribute()方法,都是dom core的组成部分. 2. HTM

  • jQuery DOM操作实例

    都来加深印象吧,大家都知道jQuery很好使用,因为它简化了javascript代码,更重要的是它还兼容基本上所有的浏览器,网页开发最头疼的就是这个了,所以jQuery也因此深受码农的喜爱,不过首先你得要记住它才能更好的使用它不是吗,过久了没用的属性方法也会淡忘的,下面是jQuery的DOM操作方法属性的详解,看看加深下印象. 例子虽丑功能还俱全呢! 复制代码 代码如下: <!DOCTYPE html><html xmlns="http://www.w3.org/1999/xh

  • JavaScript基于Dom操作实现查找、修改HTML元素的内容及属性的方法

    本文实例讲述了JavaScript基于Dom操作实现查找.修改HTML元素的内容及属性的方法.分享给大家供大家参考,具体如下: 当网页被加载时,浏览器会创建页面的文档对象模型(Document Object Model).HTML DOM 模型被构造为对象的树. 通过可编程的对象模型,JavaScript 获得了足够的能力来创建动态的 HTML.例如:改变HTML元素,改变HTML属性,改变CSS样式,事件响应. 效果图: 代码: <!DOCTYPE html PUBLIC "-//W3C

  • 浅谈jQuery 选择器和dom操作

    浅谈jQuery 选择器和dom操作 JQuery选择器 1.基本选择器 基本选择器是JQuery中最常用的选择器,也是最简单的选择器,它通过元素id.class 和标签名来查找DOM元素.这个非常重要,下面的内容都是以此为基础,逐级提高的. 1)."$("#id")",获取id指定的元素,id是全局唯一的,所以它只有一个成员. 2)."$(".class")",获取class指定的元素,不同的元素可以具有相同的class属性

  • jQuery基础知识点总结(DOM操作)

    使用jQuery的方式来操作DOM更加的简洁.方便,统一的调用方式方便学习并且可降低学习成本. 1.样式属性操作 1)设置样式属性操作 ①设置单个样式: // 第一个参数表示:样式属性名称 // 第二个参数表示:样式属性值 $(selector).css("color", "red"); ②设置多个样式(也可以设置单个) // 参数为 {}(对象) $(selector).css({"color": "red", "

  • Jquery基础教程之DOM操作

    对于dom的全称大家都知道吧,DOM是Document Object Model的缩写,其意思是文档对象模型.DOM是一种与浏览器.平台.语言无关的接口,使用dom接口很容易的访问页面中所有标准组件.dom操作一般可以分为三个方面即DOM Core(核心).HTM-Dom和CSS-DOM. 每一个网页都可以用DOM表示出来,每个DOM都可以看作是一棵DOM树.下面的html页面结构可以构建出一棵DOM树,代码: 代码如下: <!DOCTYPE html PUBLIC "-//W3C//DT

  • jQuery基于ajax实现页面加载后检查用户登录状态的方法

    本文实例讲述了jQuery基于ajax实现页面加载后检查用户登录状态的方法.分享给大家供大家参考,具体如下: 拥有会员功能的网站,如果会员已经登录,那么要显示相应的登录状态,而且这种显示的需求是在网站的每个页面都有的(目前国内网站貌似都是这么做的,还没有见过其他形式的状态显示方式),这样,在打开一个新的页面时就要知道这个会员是否已经登录,需要判断登录的状态. 1.解决方案. 为了能够实现在每一个页面判断会员登录状态的功能,我采用了页面时通过ajax传递参数通过后端返回的登录状态结果进行判断,当然

  • DOM操作原生js 的bug,使用jQuery 可以消除的解决方法

    js的 bug 类型:  Uncaught TypeError:Cannot set/read property 'xxx' of null 在进行DOM操作的时候比较容易发生这个错误,比如: 1.  document.getElementById('test1').style.display='none' 2.  document.getElementById('test1').onclick=function(){/*相关代码*/} 假如DOM中无此 test1对象,将会抛出上面的错误,发生

随机推荐