jQuery-3~4章
jQuery-3~5章
JQuery003-JQuery中的DOM操作
jQuery中的DOM操作:
1、查找节点
A.查找元素节点 |
B. 查找属性节点 |
var s1 = $("ul li:eq(1)"); var li_txt = s1.txt(); alert(li_txt); |
var $para = $("p"); var p_txt = $para.attr("title"); alert(p_txt); |
2、创建节点
为了使页面更加智能化,有时我们想动态的在 html 结构页面添加一个元素标签,那么在插入之前首先要做的动作就是:创建节点。
var box =
$('<div id="box">节点</div>'); //创建一个节点
$('body').append(box); //将节点插入到<body>元素内部
创建元素节点 |
创建文本节点 |
var s1 = var s2 = |
3、插入节点
在创建节点的过程中,其实我们已经演示怎么通过.append()方法来插入一个节点。但除了这个方法之余呢,jQuery 提供了其他几个方法来插入节点。
4、删除节点
remove()方法 |
detach() |
empty()方法 |
从DOM节点中删除所有匹配的元素,传入的参数作用于根据jQuery表达式来筛选元素。 $('div').remove(); //直接删除 div 元素 |
和remove()方法一样是从DOM中去掉所有匹配的元素。这个方法不会吧匹配的元素从jQuery对象中删除,因而可以在将在再使用这些匹配的元素。所有绑定的事件,附加的数据等都会保留下来。 |
清空节点而不是删除节点。 |
5、复制节点
可以使用clone()方法来实现。
6、替换节点
replaceWith() |
replaceAll() |
将所有匹配的元素都替换成HTML或者DOM元素 |
颠倒了replaceWith()操作,其作用和功能和replaceWith()是一样的。 |
7、包裹节点
wrap()方法:该方法对于要在文档中插入额外的结构化标记非常有用,而且不会破坏原始文档的语义。
jQuery 提供了一系列方法用于包裹节点, 那包裹节点是什么意思呢?其实就是使用字符串代码将指定元素的代码包含着的意思
8、属性操作
用attr()方法来获取和设置元素属性 |
用removeAttr()来删除元素属性 |
如果要获取<p>元素的属性title,只需给attr()方法传递一个参数—属性名称 |
如下代码 $("p").removeAttr("title"); |
9、样式操作
获取class和设置class都可以使用attr()方法来完成
var p_class = |
追加样式:addClass()方法
10、
设置和获取HTMl、文本和值
html()方法 |
text()方法 |
val()方法 |
该方法类似于JS中的innerHTML属性 |
该方法类似于JS中的innerText属性,可以用来读取或者设置某个元素中的文本内容 |
该方法类似于JS中的value属性,可以用来设置和获取元素的值 |
11、
遍历节点
children() |
用于取得匹配元素的子元素集合 |
next() |
用于取得匹配元素后面邻近的同辈元素 |
prev() |
取得匹配元素前面紧邻的同辈元素 |
sibling() |
取得匹配元素前后所有的同辈元素 |
closest() |
取得最近的匹配元素 |
parent() |
12、
CSS-DOM操作
几种经常使用的方法
offset() |
获取元素在当前视窗的相对便宜。返回对象包含两个属性:top和left。只对当前元素有效 |
position() |
获取元素相对于最近一个position样式属性设置为realitive或者absolute的祖父节点的相对便宜,和offset()一样,返回对象包含两个属性top和left |
scrollTop() |
获取元素滚动条距离顶端的距离 |
scrollLeft() |
获取元素滚动条距离左侧的距离 |
JQ004-jQuery中的事件和动画
一、
jQuery中的事件
1、加载DOM
JS的onload事件只能保存对一个函数的引用,后面的会自动覆盖前面的函数。而jQuery的ready()方法可以很好的处理这个问题。调用$(document).ready()方法都在现有的行为上追加新的行为,这些行为函数会根据注册的顺序依次执行。如下代码:
简写:如下
一般写法 |
简单写法 |
2、事件绑定
使用band()方法来进行对匹配元素进行特定事件的绑定。调用格式如下
bind( type [, |
bind()方法有三个参数:
事件类型:如:blur , focus , load , resize , scroll , |
可选参数,作为event.data属性值传递给事件对象的额外数据对象 |
用来绑定的处理函数 |
怎么用css样式把相应的内容隐藏起来??
使用:display:none;
简写事件绑定:
3、合成事件
jQuery有两个合成的事件。类似于之前的ready()事件。hover() toggle()方法都书序jQuery自定义的方法:
hover() |
toggle() |
用于模拟光标悬停事件,光标悬停在特定元素上时,触发事件 |
语法结构:toggle(fn1 , fn2 , fn3 , ……fnN); 该方法用于模拟鼠标连续单击事件,第一次单击元素触发指定的第一个函数,以此类推。 |
4、事件冒泡
从里往外执行。
事件冒泡会带来问题,要如何停止事件冒泡:
事件捕获:从外往里执行
5、事件对象的属性
jQuery在遵循w3c规范的情况下,对事件对象的常用属性进行了封装,使得事件在各大浏览器中都可以正常运行,而不需要进行浏览器类型判断。
event.type |
event.preventDefault()方法 |
event.stopProgation()方法 |
event.target |
获取到事件类型 |
阻止默认的事件行为 |
阻止事件的冒泡 |
获取到触发事件的元素 |
event.relatedTarget |
event.pageX和event.pageY方法 |
event.which |
event.metaKey |
用来访问mouseover和mouseout的相关元素 |
获取光标对于页面的x坐标和y坐标(如果页面中有滚动条,要加上滚动条的宽度和高度) |
获取到鼠标单击事件中获取到鼠标的左中右事件,在键盘事件中的键盘按键 |
为键盘事件中获取<ctrl>键 |
6、移除事件
unbind()方法。
参数类型如下:
没有参数:移除所有事件 |
有参数:移除该类型事件 |
把绑定时传递的处理函数作为第2个参数,则这个特定参数被删除 |
7、模拟操作
trigger():完成模拟触发操作。
$(‘#btn’).trigger(“click”); 模拟点击事件 $(‘#btn’). |
自定义触发事件:
$('#btn').bind("myClick" $('#test').qppend("<p> }); $(‘#btn’).trigger(“myClick”) |
如果只想触发绑定的focus事件不想触发浏览器默认事件,可以使用triggerHandler()方法。
$(“input”).triggerHandler(“focus”); |
8、其他用法
bind()方法不经能够为元素绑定浏览器支持的具有相同名称的事件,也可以绑定自定义事件。此外bind()方法还能做很多事情。
1、绑定多个事件类型 (可以一次性绑定多个事件类型) |
|
$(function(){ $("div").bind("mouseover $(this).toggleClass("over"); }); }); |
当光标移动到div时,该元素的class切换为over |
2、添加事件命名空间,便于管理(为元素绑定的多个事件类型用命名空间规范起来) |
|
$(function(){ $("div").bind("click.plugin", $("body").append("<p> }); $("div").bind("mouseover.plugin", $("body").append("<p> }); $("div").bind("dbclick ", $("body").append("<p> }); $("button")click(function(){ $("div")unbind(".plugin"); }); }); |
|
3、相同事件名称,不同命名空间执行方法 |
|
$(function(){ $("div").bind("click", $("body").append("<p> }); $("div").bind("click.plugin", $("body").append("<p> }); $("button").click(function(){ $("div")trigger("click!"); }); }); |
注意最后一个click后面的感叹号!。它的作用是:匹配所有不包含在命名空间中的click方法。 |
二、
jQuery中的动画
1、show() 和 hide() 方法
show() 和hide() 方法 |
相当于css的display:none或者inner、block、innerblock |
让show() 和hide() 方法动起来 修改元素的属性:高度宽度和不透明度 |
可以为他们 一个速度参数:slow $("element").show("slow"); 关键字还有normal 和 fast(事件长度分别为:600毫秒、400毫秒、200毫秒)。可以直接填写时间数据,单位为毫秒: $("element").show(1000); |
2、fadeIn() 和 fadeOut()
方法
这两个方法值改变元素的不透明度,淡入,淡出 |
3、dlideUp() 和
dlideDown() 方法
只改变元素的高度 |
4、自定义动画方法animate()
语法结构为: animate(params, speed, callback); 参数说明如下: 1、params:一个包含样式属性及值的映射 2、speed 速度参数,可选 3、callback 在动画完成时执行的函数,可选 |
累加累减动画
$(this).animate({left:"+=100px"}, |
多重动画
$(this).animate({left:"+=100px"}, .animate({height:"+=200px"}, |
综合动画
$(function(){ $("#panel").css("opacity","0.5"); $("#panel").click(function(){ $(this).animate({left:"+=100px", .animate({top:"+=200px", .fadeOut(5000) .fadeIn(5000) }); }); |
5、动画回调函数
如果最后面只是想改css样式,而不是要让动画淡入或者淡出。但是css样式方法并不会加入到队列中,而是立即执行。可以对css样式使用函数回调方法。如下代码:
$(function(){ $("#panel").css("opacity","0.5"); $("#panel").click(function(){ $(this).animate({left:"+=100px", .animate({top:"+=200px", $(this).css("border", }) }); }); |
6、停止动画和判断试够处于动画状态
使用stop()方法。
该方法有两个可选参数:clearQueue和gotoEnd。都为boolean值
clearQueue |
表示是否要清空未完成的队列 |
$("#panel").hover(function(){ $(this).stop() .animate({height: },function(){ $(this).stop() .animate({height:"22", }); |
|
gotoEnd |
表示是否当即停止动画 |
判断元素是否处于动画状态。
if(!$(element).is(“:animated”)){ //如果当前没有动画则添加新动画。 } |
动画延迟操作:
使用delay()方法 |
7、其他动画方法
四个用于交互的动画方法:
toggle(speed, |
切换元素的可见状态,如果是可见的切换为隐藏的,如果是隐藏的切换成可见的。 |
slideToogle(speed, |
通过高度变化来切换陪陪元素的可见性,通过高度变化来改变。(只调整元素的高度) |
fadeTo(speed, |
把元素的不透明度以渐进方式调整大指定的值。(只调整元素的不透明度) $(this).fadeTo(6000,0.2); //参数:事件,透明度 |
fadeToggle(speed,[easing], |
通过不透明度变化来切换匹配元素的可见性(只调整元素的不透明度) |
8、动画方法概括
方法名 |
说明 |
hide() show() |
同时修改多个样式属性:高度、宽度、不透明度 |
fadeIn() fadeOut() |
只改变不透明度 |
sildeUp() slideDown() |
只改变高度 |
fadeTo() |
只改变不透明度 |
toggle() |
用来代替hide()和show()方法,会同时修改多个属性 |
slideToggle() |
用来代替sildeUp() 和 |
fadeToggle() |
用来代替fadeIn()和fadeOut()方法,所以只改变宽度 |
animate() |
自定义动画方法(可以用来代替所有其他动画方法方法) |
jQuery-3~4章的更多相关文章
- jQuery第十一章
第十一章 一.jQuery性能优化 1.使用最新版本的jQuery类库. 2.使用合适的选择器 (1)$(“#id”) :使用id来定位DOM元素是最佳提高性能的方式. (2)$(“p”) :标签选择 ...
- jQuery系列 第二章 jQuery框架使用准备
第二章 jQuery框架使用准备 2.1 jQuery框架和JavaScript加载模式对比 jQuery框架的加载模式 <script> window.onload = function ...
- jQuery系列 第一章 jQuery框架简单介绍
第一章 jQuery框架简单介绍 1.1 jQuery简介 jQuery是一款优秀的javaScript库(框架),该框架凭借简洁的语法和跨平台的兼容性,极大的简化了开发人员对HTML文档,DOM,事 ...
- jQuery第七章插件的编写和使用
1.本章目标 编写jquery插件 2.插件 也称为扩展,是一种按照一定的规范的应用程序接口编写出来的程序 插件的目标是给已有的一系列函数做一个封装,以便在其他的地方复用,方便维护和开发效率 3.jq ...
- jQuery 第六章 jQuery在Ajax应用
1.本章目标 ajax 2.ajax 异步刷新技术,我们的网页不需要全部刷新,按需实现局部刷新,上线后台的交互 用户体验好 地图,前台验证,表单提交,修改,查询等等 原生的js和ajax packag ...
- jquery 第四章
1.回顾 节点.append(内容) 节点.prepend(内容) 节点.remove() 节点.attr("属性","值") 节点.css("样式& ...
- jquery 第三章
1.回顾$(document).ready(function(){ })$(function(){ }) ID选择器.类选择器.元素选择器层次选择器:空格(上文下:tr td{})属性过滤 ...
- 好记心不如烂笔头之jQuery学习,第一章
jQuery对象和DOM对象的转换: 1.jquery对象是对象数组,于是乎: var $cr = $('#cr'); var cr = $cr[0]; 2.使用jquery的自带函数: var $c ...
- jQuery第六章
jQuery与Ajax应用 一.Ajax的优势和不足 1.Ajax的优势: (1)不需要插件支持:不需要任何浏览器插件就可以被绝大多数浏览器支持 (2)优秀的用户体验:能在不刷新整个页面的前提下更新数 ...
- jQuery第五章
jQuery对表单.表格的操作以及更多应用 一.表单应用 1.单行文本框应用 (1)获取和失去焦点改变样式 HTML代码如下: <form action="#" method ...
随机推荐
- DPA/Ignite由于DNS问题导致连接不上被监控的数据库服务器
问题描述: 在DPA(Ignite)的管理监控界面发现有两台SQL Server数据库服务器连接不上,截图如下所示,检查其日志内容 具体错误日志如下所示, Notice:日志里面具体的服务器名称被我用 ...
- python之数据库操作
数据库操作 Python 操作 Mysql 模块的安装 1 2 3 4 5 linux: yum install MySQL-python window: http://files ...
- 从零自学Hadoop(12):Hadoop命令中
阅读目录 序 HDFS Commands User Commands Administration Commands Debug Commands 引用 系列索引 本文版权归mephisto和博客园共 ...
- PHP中的回调函数和匿名函数
html,body,div,span,applet,object,iframe,h1,h2,h3,h4,h5,h6,p,blockquote,pre,a,abbr,acronym,address,bi ...
- kali 2.0 U盘安装错误Your installation cd-rom couldn't be mounted
1.kali 2.0前天(2015.08.11)发布了.果断下载下来换掉本机的1.0版本. 2.用U盘安装的过程中,出现cd-rom无法挂载.提示错误Your installation CD-ROM ...
- 【转帖】分享一个迅为4412开发板OTG烧录批处理文件
平台:iTOP-4412开发板 Bat 功能: 1.可以分条的执行烧录,不需要每次烧录都去复制命令 2.可以批量烧录 开发板系统烧录批处理文件,请将此文件放置在fastboot程序同目录下,下载地址: ...
- WPF系列 Path表示语法详解(Path之Data属性语法)
示例: XAML(代码A): <Page xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation" ...
- CDN缓存机制
CDN也叫内容分发网络,是一个经策略性部署的整体系统,包括分布式储存.负载均衡.网络请求的重定向和内容管理4个要件.而其中内容管理和全局的网络流量管理是CDN的核心所在.通过用户就进行和服务器负载的判 ...
- LoadLibrary加载动态库失败的解决办法
from:http://blog.sina.com.cn/s/blog_62ad1b8101017qub.html 若DLL不在调用方的同一目录下,可以用LoadLibrary(L"DLL绝 ...
- 开源项目导入eclipse的一般步骤
开源项目导入eclipse的一般步骤 周银辉 下载到开源项目后,我们还是希望导入到eclipse中还看,这样要方便点,一般的步骤是这样的 打开源代码目录, 如果看到里面有.calsspath .pro ...