Test Paragraph.
呃,貌似是广告哈?呵呵,不过的确是这样,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,但是有一些人喜欢百度,那么好,让我们选择自己喜欢的。
$(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
可以这样写
这样就为每个段落后面加了一个超链接“Back to top”,并且也添加了一个”top”锚。
啥?你说你没看见?呃,好吧。。我承认因为我还没有插入这个新元素至DOM中,只是创建了出来。
插入新元素:
jQuery提供了两种将元素插入到其他元素前面的方法:.insertBefore()和.before()。
这两个方法作用相同,它们的区别取决于如何将它们与其他方法进行连缀。
那么,很自然的,聪明的你一定会想到,插入到其他元素后面的方法就是.insertAfter()和.after()。
对于刚才的”back to top”我们使用.insertAfter()方法,原因就是我们要在每个答案后面加上这个链接。。嗯。
通过.after()方法也能完成与.insertAfter()相同的任务,只不过必须把选择符表达式放在这个方法的前面,而不是后面。
在使用.after()方法时,$(document).ready()中的第一行代码可以改写成如下所示:
$('div.chapter p').after('back to top');
使用.insertAfter(),可以通过连缀更多方法连续地对所创建的元素进行操作。
而使用.after(),连缀的其他方法的操作对象就变成了$('div.chapter p')中选择符匹配的元素。
那么,要在元素内插入新的元素咋办啊?刚才说的这些都是使其成为兄弟元素。而怎么插入子元素呢?
别急,有.prependTo()方法呢。
.prependTo()方法插入了作为目标的描,我们就为页面添加了一组功能完备的back to top链接。
同样,jQuery还提供了一个方法是.prepend(),看API其作用为:
向每个匹配的元素内部追加内容。
这个操作与对指定的元素执行appendChild方法,将它们添加到文档中的情况类似。
例如:
I would like to say:
$("p").append("Hello");
包装元素:
jQuery中用于将元素包装在其他元素中的方法,被贴切地命名为:.wrap()。
如果,要将一个
Test Paragraph.
里面的
标签包在div里面,
就可以这样来写
$("p").wrap(document.getElementById('content'));
复制元素:
重头戏终于出来了。。嗯。复制元素。。
现年头都实行克隆,不过最近好像很少喊了。喊的最多的就是要克隆人。想想都奇怪。 克隆完后抢你老婆咋办?
呃。闲话少说吧。。jQuery的克隆方法就是.clone()。嗯。相对于插入方法,相当于复制和粘贴。
默认情况下,.clone()方法不仅会复制匹配的元素,也会复制其所有的后代元素。
书上说这个方法也是接受参数的,如果参数值为false,那么就只会复制匹配的元素,而不复制其子元素。
不过我试验后不是这样的。。嗯。
我可是有内容的DIV
$('#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()

Python和JavaScript各有优势,选择取决于项目需求和个人偏好。1.Python易学,语法简洁,适用于数据科学和后端开发,但执行速度较慢。2.JavaScript在前端开发中无处不在,异步编程能力强,Node.js使其适用于全栈开发,但语法可能复杂且易出错。

javascriptisnotbuiltoncorc; saninterpretedlanguagethatrunsonenginesoftenwritteninc.1)javascriptwasdesignedAsalightweight,解释edganguageforwebbrowsers.2)Enginesevolvedfromsimpleterterterpretpreterterterpretertestojitcompilerers,典型地提示。

JavaScript可用于前端和后端开发。前端通过DOM操作增强用户体验,后端通过Node.js处理服务器任务。1.前端示例:改变网页文本内容。2.后端示例:创建Node.js服务器。

选择Python还是JavaScript应基于职业发展、学习曲线和生态系统:1)职业发展:Python适合数据科学和后端开发,JavaScript适合前端和全栈开发。2)学习曲线:Python语法简洁,适合初学者;JavaScript语法灵活。3)生态系统:Python有丰富的科学计算库,JavaScript有强大的前端框架。

JavaScript框架的强大之处在于简化开发、提升用户体验和应用性能。选择框架时应考虑:1.项目规模和复杂度,2.团队经验,3.生态系统和社区支持。

引言我知道你可能会觉得奇怪,JavaScript、C 和浏览器之间到底有什么关系?它们之间看似毫无关联,但实际上,它们在现代网络开发中扮演着非常重要的角色。今天我们就来深入探讨一下这三者之间的紧密联系。通过这篇文章,你将了解到JavaScript如何在浏览器中运行,C 在浏览器引擎中的作用,以及它们如何共同推动网页的渲染和交互。JavaScript与浏览器的关系我们都知道,JavaScript是前端开发的核心语言,它直接在浏览器中运行,让网页变得生动有趣。你是否曾经想过,为什么JavaScr

Node.js擅长于高效I/O,这在很大程度上要归功于流。 流媒体汇总处理数据,避免内存过载 - 大型文件,网络任务和实时应用程序的理想。将流与打字稿的类型安全结合起来创建POWE

Python和JavaScript在性能和效率方面的差异主要体现在:1)Python作为解释型语言,运行速度较慢,但开发效率高,适合快速原型开发;2)JavaScript在浏览器中受限于单线程,但在Node.js中可利用多线程和异步I/O提升性能,两者在实际项目中各有优势。


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

Video Face Swap
使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

SublimeText3 Linux新版
SublimeText3 Linux最新版

适用于 Eclipse 的 SAP NetWeaver 服务器适配器
将Eclipse与SAP NetWeaver应用服务器集成。

SublimeText3汉化版
中文版,非常好用

Dreamweaver Mac版
视觉化网页开发工具

PhpStorm Mac 版本
最新(2018.2.1 )专业的PHP集成开发工具