逆袭的红酒 · vba match精确查找-掘金· 1 年前 · |
坐怀不乱的小笼包 · h5微聊-高仿微信聊天界面实战案例分享-阿里 ...· 1 年前 · |
从未表白的眼镜 · 推荐收藏!2023 ...· 1 年前 · |
迷茫的皮带 · HTTP常见状态码 200 301 302 ...· 1 年前 · |
3.例子三: jQuery中选择器参数使用变量应该注意的问题
var li_index = $(this).index();
var $content_index = li_index + 2;
var $content_progress = $(“div.content:eq(” + $content_index + “)”);
var $newavalue = $(this).find(“a”).attr(“name”);
var $resource = $(this).find(“a”).html().replace(“首页”,$newavalue);
var $afterresource = $resource.replace($newavalue,””);
var $afterresource = $newavalue + $afterresource.replace(“首页”,$newavalue);
其中第三行的正确写法为:
$(“div.content:nth-child(” + $content_index + “)”);
注: 选择器 里面用变量 还要用到+号
基于 变量 进行动画和 在内容以外的其他属性 中 使用 attr()值。 由于JavaScript不能直接操纵这些元素,因为它们不被视为“真实”元素,因此几乎不支持这种功能。 将来可能会改变... 在 jQuery 之后安装插件,您应该一切顺利。 只要逻辑上适当,就对父元素 使用 pseudo方法。 $el.pseudo("after","margin-top", "10px"); 该插件的选项当前是固定的,它们如下(按顺序): 伪 选择器 :之前,之后 由Makis Tracend( )发起 受到安德鲁·麦吉维(Andrew McGivery)的图书馆的启发 内容简介: jQuery 是继Prototype之后的又一个优秀JavaScript框架,深受全球开发者欢迎,已经成为Web开发领域的事实标准。 jQuery 以其轻巧的体积、强大的 选择器 、出色的DOM封装、丰富的插件支持使得广大的Web前端开发者得心应手,极大地提高了他们的开发效率;此外, jQuery 中 完善的Ajax功能、行为与结构层的分离、可靠的事件处理机制也同样使得Web后端开发者如虎添翼, 使用 少量代码就可以 实现 复杂的功能。特别是新版本1.4.x的发布, jQuery 在功能和性能方面都有质的提升,极大地满足了广大开发者提出的更高要求。因此,为了提高Web开发的效率和强化Web应用的功能,熟练 使用 jQuery 是Web开发者必备的一种能力。 《 jQuery 权威指南》由国内资深Web技术专家亲自执笔,4大Web开发社区一致鼎力推荐,权威性毋庸置疑。 内容新颖,基于 jQuery 的最新版本撰写,所有新功能和新特性一览无余;内容全面,不仅讲解了 jQuery 技术本身的方方面面,而且还包括与 jQuery 相关的扩展知识;实战性强,不仅每个知识点都配有完整的小案例,而且还有两个综合性的案例。本书不仅能满足读者系统学习理论知识的需求,还能满足需要充分实践的需求。 全书一共分为11章,首先以示例的方式对 jQuery 做了全局性的介绍,以便于为读者建立 jQuery 的大局观,这对初学者尤为重要;其次详细讲解了 jQuery 的各种 选择器 、 jQuery 操作DOM的方法、 jQuery 中 的事件与应用、 jQuery 中 的动画和特效、Ajax在 jQuery 中 的应用,以及各种常用的 jQuery 插件的 使用 方法和技巧,所有这些知识点都配有完整的示例(包括需求分析、代码 实现 和结果展示三部分);再接着对 jQuery UI和 jQuery 实用工具函数等扩展知识,以及 jQuery 的开发技巧与性能优化等方面的重要知识做了详尽的阐述;最后以两个具有代表性的综合案例结束全书,希望能帮助读者将前面所学的理论知识真正贯穿于实践 中 ,迅速进入 jQuery 的殿堂。 作者简介: 陶国荣,资深Web技术专家,有10余年开发经验,是国内较早专业从事Web开发的一线技术人员和培训讲师。醉心于对JavaScript、 jQuery 和Ajax等Web开发技术的研究与实践,并长期专注于HTML页面的优化与用户体验的研究,在页面框架搭建、数据流向分析、页面静态优化方面拥有丰富的实践经验。此外,他还是微软技术方面的专家,精通C#、ASP.NET 和SQL Server等技术,出版相关著作多部。 媒体推荐: jQuery 的发展之迅速和取得的成功之巨大是其他所有开发框架都难以企及的,它已经成为Web开发者必备的核心技能之一。如果你尚未掌握 jQuery 或功力还不够,推荐你认真阅读这本书并付诸实践,与同类的 jQuery 图书相比,它有3大优势:内容非常全面,几乎包含 jQuery 的所有内容;基于 jQuery 的最新版本撰写,所有新功能特性一览无余;实战性极强,不仅有118个小型案例,而且还有两个综合案例。—— jQuery 中 文社区 jQuery 因为 使用 简单、功能强大、插件丰富而深受Web开发者青睐。《 jQuery 权威指南》不仅完整地呈现了 jQuery 本身所有的功能,而且讲解了 jQuery UI等扩展功能;更值得一提的是,还包括最佳实践和性能优化方面的技巧,内容全面,结构合理。除此之外,本书还包括大量的实例,不仅每个知识点都配有小 例子 ,而且还有两个综合性的案例。对于初学者而言,本书应该是学习 jQuery 的首选。—— jQuery 中 文用户组 jQuery 因为易于 使用 和功能强大著称,是所有Web开发者应该掌握的一种利器,初学者如何才能快速而有效地掌握 jQuery 呢?最好的方法莫过于一边学习理论,一边动手实践这些理论,本书就是按照这种思路为读者打造的,强烈推荐。——JavaScript开发者社区 jQuery 从众多的Ajax框架 中 脱颖而出,已经成为Web开发领域的事实标准。《 jQuery 权威指南》除了理论知识丰富而全面外,它还有一个最大的特点就是注重实战,每个知识点都有一个完整的案例,包括需求分析、代码 实现 和结果展示三个部分,而且还包含两个综合性的案例,它的实践性之强是目前所有同类书都不具备的,恰好这一点又是初学者最需要的。如果能阅读本书并付诸实践,进入jQu 演示 jQuery hide() 函数,隐藏所有 class="test" 的元素。 jQuery 语法 jQuery 语法是为 HTML 元素的选取编制的,可以对元素执行某些操作。 基础语法是:$(selector).action() • 美元符号定义 jQuery • 选择 符(selector)“查询”和“查找” HTML 元素 • jQuery 的 action() 执行对元素的操作 $(this).hide() - 隐藏当前元素 $("p").hide() - 隐藏所有段落 $("p.test").hide() - 隐藏所有 class="test" 的段落 $("#test").hide() - 隐藏所有 id="test" 的元素 提示: jQuery 使用 的语法是 XPath 与 CSS 选择器 语法的组合。在本教程接下来的章节,您将学习到更多有关 选择器 的语法。 文档就绪函数 您也许已经注意到在我们的实例 中 的所有 jQuery 函数位于一个 document ready 函数 中 : $(document).ready(function(){ --- jQuery functions go here ---- 这是为了防止文档在完全加载(就绪)之前运行 jQuery 代码。 二. jQuery 选择器 在前面的章节 中 ,我们展示了一些有关如何选取 HTML 元素的实例。 关键点是学习 jQuery 选择器 是如何准确地选取您希望应用效果的元素。 jQuery 元素 选择器 和属性 选择器 允许您通过标签名、属性名或内容对 HTML 元素进行 选择 。 选择器 允许您对 HTML 元素组或单个元素进行操作。 在 HTML DOM 术语 中 : 选择器 允许您对 DOM 元素组或单个 DOM 节点进行操作。 jQuery 元素 选择器 jQuery 使用 CSS 选择器 来选取 HTML 元素。 $("p") 选取 元素。 $("p.intro") 选取所有 class="intro" 的 元素。 $("p#demo") 选取 id="demo" 的第一个 元素。 jQuery 属性 选择器 jQuery 使用 XPath 表达式来 选择 带有给定属性的元素。 $("[href]") 选取所有带有 href 属性的元素。 $("[href='#']") 选取所有带有 href 值等于 "#" 的元素。 $("[href!='#']") 选取所有带有 href 值不等于 "#" 的元素。 $("[href$='.jpg']") 选取所有 href 值以 ".jpg" 结尾的元素。 jQuery CSS 选择器 jQuery CSS 选择器 可用于改变 HTML 元素的 CSS 属性。 下面的 例子 把所有 p 元素的背景颜色更改为红色: $("p").css("background-color","red"); 更多的 选择器 实例 语法 描述 $(this) 当前 HTML 元素 $("p") 所有 元素 $("p.intro") 所有 class="intro" 的 元素 $(".intro") 所有 class="intro" 的元素 $("#intro") id="intro" 的第一个元素 $("ul li:first") 每个 的第一个 元素 $("[href$='.jpg']") 所有带有以 ".jpg" 结尾的属性值的 href 属性 $("div#intro .head") id="intro" 的 元素 中 的所有 class="head" 的元素 三. jQuery 事件函数 jQuery 事件处理方法是 jQuery 中 的核心函数。 事件处理程序指的是当 HTML 中 发生某些事件时所调用的方法。术语由事件“触发”(或“激发”)经常会被 使用 。 通常会把 jQuery 代码放到 部分的事件处理方法 中 : 在上面的 例子 中 ,当按钮的点击事件被触发时会调用一个函数: $("button").click(function() {..some code... } ) 该方法隐藏所有 元素: $("p").hide(); 单独文件 中 的函数 如果您的网站包含许多页面,并且您希望您的 jQuery 函数易于维护,那么请把您的 jQuery 函数放到独立的 .js 文件 中 。 当我们在教程 中 演示 jQuery 时,会将函数直接添加到 部分 中 。不过,把它们放到一个单独的文件 中 会更好,就像这样(通过 src 属性来引用文件): jQuery 名称冲突 jQuery 使用 $ 符号作为 jQuery 的简介方式。 某些其他 JavaScript 库 中 的函数(比如 Prototype)同样 使用 $ 符号。 jQuery 使用 名为 noConflict() 的方法来解决该问题。 var jq= jQuery .noConflict(),帮助您 使用 自己的名称(比如 jq)来代替 $ 符号。 亲自试一试 由于 jQuery 是为处理 HTML 事件而特别设计的,那么当您遵循以下原则时,您的代码会更恰当且更易维护: • 把所有 jQuery 代码置于事件处理函数 中 • 把所有事件处理函数置于文档就绪事件处理器 中 • 把 jQuery 代码置于单独的 .js 文件 中 • 如果存在名称冲突,则重命名 jQuery 库 jQuery 事件 下面是 jQuery 中 事件方法的一些 例子 : Event 函数 绑定函数至 $(document).ready(function) 将函数绑定到文档的就绪事件(当文档完成加载时) $(selector).click(function) 触发或将函数绑定到被选元素的点击事件 $(selector).dblclick(function) 触发或将函数绑定到被选元素的双击事件 $(selector).focus(function) 触发或将函数绑定到被选元素的获得焦点事件 $(selector).mouseover(function) 触发或将函数绑定到被选元素的鼠标悬停事件 四. jQuery 实例 jQuery hide() 演示简单的 jQuery hide() 函数。 $(document).ready(function(){ $(".ex .hide").click(function(){ $(this).parents(".ex").hide("slow"); div.ex background-color:#e5eecc; padding:7px; border:solid 1px #c3c3c3; $(document).ready(function(){ $(".flip").click(function(){ $(".panel").slideToggle("slow"); div.panel,p.flip margin:0px; padding:5px; text-align:center; background:#e5eecc; border:solid 1px #c3c3c3; div.panel height:120px; ; $(document).ready(function(){ $("#start").click(function(){ $("#box").animate({height:300},"slow"); $("#box").animate({width:300},"slow"); $("#box").animate({height:100},"slow"); $("#box").animate({width:100},"slow"); $(selector).show(speed,callback) speed 参数规定显示或隐藏的速度。可以设置这些值:"slow", "fast", "normal" 或毫秒。 callback 参数是在 hide 或 show 函数完成之后被执行的函数名称。您将在本教程下面的章节学习更多有关 callback 参数的知识。 $("button").click(function(){ $("p").hide(1000); 亲自试一试 $(document).ready(function(){ $("button").click(function(){ $("p").hide(1000); This is a paragraph with little content. This is another small paragraph. jQuery 切换 jQuery toggle() 函数 使用 show() 或 hide() 函数来切换 HTML 元素的可见状态。 隐藏显示的元素,显示隐藏的元素。 $(selector).toggle(speed,callback) speed 参数可以设置这些值:"slow", "fast", "normal" 或 毫秒。 $("button").click(function(){ $("p").toggle(); 亲自试一试 $(document).ready(function(){ $("button").click(function(){ $("p").toggle(); This is a paragraph with little content. This is another small paragraph. callback 参数是在该函数完成之后被执行的函数名称。您将在本教程下面的章节学习更多有关 callback 参数的知识。 jQuery 滑动函数 - slideDown, slideUp, slideToggle jQuery 拥有以下滑动函数: $(selector).slideDown(speed,callback) $(selector).slideUp(speed,callback) $(selector).slideToggle(speed,callback) speed 参数可以设置这些值:"slow", "fast", "normal" 或毫秒。 callback 参数是在该函数完成之后被执行的函数名称。您将在本教程下面的章节学习更多有关 callback 参数的知识。 slideDown() 实例 $(".flip").click(function(){ $(".panel").slideDown(); 亲自试一试 $(document).ready(function(){ $(".flip").click(function(){ $(".panel").slideToggle("slow"); div.panel,p.flip margin:0px; padding:5px; text-align:center; background:#e5eecc; border:solid 1px #c3c3c3; div.panel height:120px; ; jQuery Fade 函数 - fadeIn(), fadeOut(), fadeTo() jQuery 拥有以下 fade 函数: $(selector).fadeIn(speed,callback) $(selector).fadeOut(speed,callback) $(selector).fadeTo(speed,opacity,callback) speed 参数可以设置这些值:"slow", "fast", "normal" 或 毫秒。 fadeTo() 函数 中 的 opacity 参数规定减弱到给定的不透明度。 callback 参数是在该函数完成之后被执行的函数名称。您将在本教程下面的章节学习更多有关 callback 参数的知识。 fadeTo() 实例 $("button").click(function(){ $("div").fadeTo("slow",0.25); 亲自试一试 $(document).ready(function(){ $("button").click(function(){ $("div").fadeTo("slow",0.25); jQuery 自定义动画 jQuery 函数创建自定义动画的语法: $(selector).animate({params},[duration],[easing],[callback]) 关键的参数是 params。它定义产生动画的 CSS 属性。可以同时设置多个此类属性: animate({width:"70%",opacity:0.4,marginLeft:"0.6in",fontSize:"3em"}); 第二个参数是 duration。它定义用来应用到动画的时间。它设置的值是:"slow", "fast", "normal" 或毫秒。 $(document).ready(function(){ $("#start").click(function(){ $("#box").animate({height:300},"slow"); $("#box").animate({width:300},"slow"); $("#box").animate({height:100},"slow"); $("#box").animate({width:100},"slow"); 亲自试一试 $(document).ready(function(){ $("#start").click(function(){ $("#box").animate({height:300},"slow"); $("#box").animate({width:300},"slow"); $("#box").animate({height:100},"slow"); $("#box").animate({width:100},"slow"); $(document).ready(function(){ $("#start").click(function(){ $("#box").animate({left:"100px"},"slow"); $("#box").animate({fontSize:"3em"},"slow"); 亲自试一试 $(document).ready(function(){ $("#start").click(function(){ $("#box").animate({left:"100px"},"slow"); $("#box").animate({fontSize:"3em"},"slow"); HTML 元素默认是静态定位,且无法移动。 如需使元素可以移动,请把 CSS 的 position 设置为 relative 或 absolute。 jQuery 效果 - 来自本页 函数 描述 $(selector).hide() 隐藏被选元素 $(selector).show() 显示被选元素 $(selector).toggle() 切换(在隐藏与显示之间)被选元素 $(selector).slideDown() 向下滑动(显示)被选元素 $(selector).slideUp() 向上滑动(隐藏)被选元素 $(selector).slideToggle() 对被选元素切换向上滑动和向下滑动 $(selector).fadeIn() 淡入被选元素 $(selector).fadeOut() 淡出被选元素 $(selector).fadeTo() 把被选元素淡出为给定的不透明度 $(selector).animate() 对被选元素执行自定义动画 五. JQuery Callback 函数 jQuery 动画的问题 许多 jQuery 函数涉及动画。这些函数也许会将 speed 或 duration 作为可选参数。 例子 :$("p").hide("slow") speed 或 duration 参数可以设置许多不同的值,比如 "slow", "fast", "normal" 或毫秒。 $("button").click(function(){ $("p").hide(1000); 亲自试一试 $(document).ready(function(){ $("button").click(function(){ $("p").hide(1000); This is a paragraph with little content. This is another small paragraph. 由于 JavaScript 语句(指令)是逐一执行的 - 按照次序,动画之后的语句可能会产生错误或页面冲突,因为动画还没有完成。 为了避免这个情况,您可以以参数的形式添加 Callback 函数。 jQuery Callback 函数 当动画 100% 完成后,即调用 Callback 函数。 典型的语法: $(selector).hide(speed,callback) callback 参数是一个在 hide 操作完成后被执行的函数。 错误(没有 callback) $("p").hide(1000); alert("The paragraph is now hidden"); 亲自试一试 $(document).ready(function(){ $("button").click(function(){ $("p").hide(2000); alert("The paragraph is now hidden"); This is a paragraph with little content. 正确(有 callback) $("p").hide(1000,function(){ alert("The paragraph is now hidden"); 亲自试一试 $(document).ready(function(){ $("button").click(function(){ $("p").hide(1000,function(){ alert("The paragraph is now hidden"); This is a paragraph with little content. 六. jQuery 包含很多供改变和操作 HTML 的强大函数。 改变 HTML 内容 $(selector).html(content) html() 函数改变所匹配的 HTML 元素的内容(innerHTML)。 $("p").html("W3School"); 亲自试一试 $(document).ready(function(){ $("button").click(function(){ $("p").html("W3School"); 函数 描述 $(selector).html(content) 改变被选元素的(内部)HTML $(selector).append(content) 向被选元素的(内部)HTML 追加内容 $(selector).prepend(content) 向被选元素的(内部)HTML “预置”(Prepend)内容 $(selector).after(content) 在被选元素之后添加 HTML $(selector).before(content) 在被选元素之前添加 HTML 七. jQuery CSS 操作 jQuery 拥有三种用于 CSS 操作的重要函数: • $(selector).css(name,value) • $(selector).css({properties}) • $(selector).css(name) CSS 操作实例 函数 css(name,value) 为所有匹配元素的给定 CSS 属性设置值: $(selector).css(name,value) $("p").css("background-color","red"); 亲自试一试 $(document).ready(function(){ $("button").click(function(){ $("p").css("background-color","red"); $(selector).css({properties}) $("p").css({"background-color":"red","font-size":"200%"}); 亲自试一试 $(document).ready(function(){ $("button").click(function(){ $("p").css({"background-color":"red","font-size":"200%"}); $(document).ready(function(){ $("div").click(function(){ $("#result").html($(this).css("background-color")); CSS 属性 描述 $(selector).css(name,value) 为匹配元素设置样式属性的值 $(selector).css({properties}) 为匹配元素设置多个样式属性 $(selector).css(name) 获得第一个匹配元素的样式属性值 $(selector).height(value) 设置匹配元素的高度 $(selector).width(value) 设置匹配元素的宽度 八. jQuery 参考手册 @ jQuery 选择器 选择器 实例 选取 $("*") 所有元素 $("#lastname") id="lastname" 的元素 .class $(".intro") 所有 class="intro" 的元素 element $("p") 所有 元素 .class.class $(".intro.demo") 所有 class="intro" 且 class="demo" 的元素 :first $("p:first") 第一个 元素 :last $("p:last") 最后一个 元素 :even $("tr:even") 所有偶数 元素 $("tr:odd") 所有奇数 元素 :eq(index) $("ul li:eq(3)") 列表 中 的第四个元素(index 从 0 开始) :gt(no) $("ul li:gt(3)") 列出 index 大于 3 的元素 :lt(no) $("ul li:lt(3)") 列出 index 小于 3 的元素 :not(selector) $("input:not(:empty)") 所有不为空的 input 元素 :header $(":header") 所有标题元素 - :animated 所有动画元素 :contains(text) $(":contains('W3School')") 包含指定字符串的所有元素 :empty $(":empty") 无子(元素)节点的所有元素 :hidden $("p:hidden") 所有隐藏的 元素 :visible $("table:visible") 所有可见的表格 s1,s2,s3 $("th,td,.intro") 所有带有匹配 选择 的元素 [attribute] $("[href]") 所有带有 href 属性的元素 [attribute=value] $("[href='#']") 所有 href 属性的值等于 "#" 的元素 [attribute!=value] $("[href!='#']") 所有 href 属性的值不等于 "#" 的元素 [attribute$=value] $("[href$='.jpg']") 所有 href 属性的值包含 ".jpg" 的元素 :input $(":input") 所有 元素 :text $(":text") 所有 type="text" 的 元素 :password $(":password") 所有 type="password" 的 元素 :radio $(":radio") 所有 type="radio" 的 元素 :checkbox $(":checkbox") 所有 type="checkbox" 的 元素 :submit $(":submit") 所有 type="submit" 的 元素 :reset $(":reset") 所有 type="reset" 的 元素 :button $(":button") 所有 type="button" 的 元素 :image $(":image") 所有 type="image" 的 元素 :file $(":file") 所有 type="file" 的 元素 :enabled $(":enabled") 所有激活的 input 元素 :disabled $(":disabled") 所有禁用的 input 元素 :selected $(":selected") 所有被选取的 input 元素 :checked $(":checked") 所有被选 中 的 input 元素 @ jQuery 事件方法 事件方法会触发匹配元素的事件,或将函数绑定到所有匹配元素的某个事件。 触发实例: $("button#demo").click() 上面的 例子 将触发 id="demo" 的 button 元素的 click 事件。 绑定实例: $("button#demo").click(function(){$("img").hide()}) 上面的 例子 会在点击 id="demo" 的按钮时隐藏所有图像。 方法 描述 bind() 向匹配元素附加一个或更多事件处理器 blur() 触发、或将函数绑定到指定元素的 blur 事件 change() 触发、或将函数绑定到指定元素的 change 事件 click() 触发、或将函数绑定到指定元素的 click 事件 dblclick() 触发、或将函数绑定到指定元素的 double click 事件 delegate() 向匹配元素的当前或未来的子元素附加一个或多个事件处理器 die() 移除所有通过 live() 函数添加的事件处理程序。 error() 触发、或将函数绑定到指定元素的 error 事件 event.isDefaultPrevented() 返回 event 对象上是否调用了 event.preventDefault()。 event.pageX 相对于文档左边缘的鼠标位置。 event.pageY 相对于文档上边缘的鼠标位置。 event.preventDefault() 阻止事件的默认动作。 event.result 包含由被指定事件触发的事件处理器返回的最后一个值。 event.target 触发事件的 DOM 元素。 event.timeStamp 该属性返回从 1970 年 1 月 1 日到事件发生时的毫秒数。 event.type 描述事件的类型。 event.which 指示按了哪个键或按钮。 focus() 触发、或将函数绑定到指定元素的 focus 事件 keydown() 触发、或将函数绑定到指定元素的 key down 事件 keypress() 触发、或将函数绑定到指定元素的 key press 事件 keyup() 触发、或将函数绑定到指定元素的 key up 事件 live() 触发、或将函数绑定到指定元素的 load 事件 load() 触发、或将函数绑定到指定元素的 load 事件 mousedown() 触发、或将函数绑定到指定元素的 mouse down 事件 mouseenter() 触发、或将函数绑定到指定元素的 mouse enter 事件 mouseleave() 触发、或将函数绑定到指定元素的 mouse leave 事件 mousemove() 触发、或将函数绑定到指定元素的 mouse move 事件 mouseout() 触发、或将函数绑定到指定元素的 mouse out 事件 mouseover() 触发、或将函数绑定到指定元素的 mouse over 事件 mouseup() 触发、或将函数绑定到指定元素的 mouse up 事件 one() 向匹配元素添加事件处理器。每个元素只能触发一次该处理器。 ready() 文档就绪事件(当 HTML 文档就绪可用时) resize() 触发、或将函数绑定到指定元素的 resize 事件 scroll() 触发、或将函数绑定到指定元素的 scroll 事件 select() 触发、或将函数绑定到指定元素的 select 事件 submit() 触发、或将函数绑定到指定元素的 submit 事件 toggle() 绑定两个或多个事件处理器函数,当发生轮流的 click 事件时执行。 trigger() 所有匹配元素的指定事件 triggerHandler() 第一个被匹配元素的指定事件 unbind() 从匹配元素移除一个被添加的事件处理器 undelegate() 从匹配元素移除一个被添加的事件处理器,现在或将来 unload() 触发、或将函数绑定到指定元素的 unload 事件 @ jQuery 效果函数 方法 描述 animate() 对被选元素应用“自定义”的动画 clearQueue() 对被选元素移除所有排队的函数(仍未运行的) delay() 对被选元素的所有排队函数(仍未运行)设置延迟 dequeue() 运行被选元素的下一个排队函数 fadeIn() 淡入被选元素至完全不透明 fadeOut() 淡出被选元素至完全不透明 fadeTo() 把被选元素减弱至给定的不透明度 hide() 隐藏被选的元素 queue() 显示被选元素的排队函数 show() 显示被选的元素 slideDown() 通过调整高度来滑动显示被选元素 slideToggle() 对被选元素进行滑动隐藏和滑动显示的切换 slideUp() 通过调整高度来滑动隐藏被选元素 stop() 停止在被选元素上运行动画 toggle() 对被选元素进行隐藏和显示的切换 @ jQuery 文档操作方法 这些方法对于 XML 文档和 HTML 文档均是适用的,除了:html()。 方法 描述 addClass() 向匹配的元素添加指定的类名。 after() 在匹配的元素之后插入内容。 append() 向匹配的元素内部追加内容。 appendTo() 向匹配的元素内部追加内容。 attr() 设置或返回匹配元素的属性和值。 before() 在每个匹配的元素之前插入内容。 clone() 创建匹配元素集合的副本。 detach() 从 DOM 中 移除匹配元素集合。 empty() 删除匹配的元素集合 中 所有的子节点。 hasClass() 检查匹配的元素是否拥有指定的类。 html() 设置或返回匹配的元素集合 中 的 HTML 内容。 insertAfter() 把匹配的元素插入到另一个指定的元素集合的后面。 insertBefore() 把匹配的元素插入到另一个指定的元素集合的前面。 prepend() 向每个匹配的元素内部前置内容。 prependTo() 向每个匹配的元素内部前置内容。 remove() 移除所有匹配的元素。 removeAttr() 从所有匹配的元素 中 移除指定的属性。 removeClass() 从所有匹配的元素 中 删除全部或者指定的类。 replaceAll() 用匹配的元素替换所有匹配到的元素。 replaceWith() 用新内容替换匹配的元素。 text() 设置或返回匹配元素的内容。 toggleClass() 从匹配的元素 中 添加或删除一个类。 unwrap() 移除并替换指定元素的父元素。 val() 设置或返回匹配元素的值。 wrap() 把匹配的元素用指定的内容或元素包裹起来。 wrapAll() 把所有匹配的元素用指定的内容或元素包裹起来。 wrapinner() 将每一个匹配的元素的子内容用指定的内容或元素包裹起来。 @ jQuery 属性操作方法 下面列出的这些方法获得或设置元素的 DOM 属性。 这些方法对于 XML 文档和 HTML 文档均是适用的,除了:html()。 方法 描述 addClass() 向匹配的元素添加指定的类名。 attr() 设置或返回匹配元素的属性和值。 hasClass() 检查匹配的元素是否拥有指定的类。 html() 设置或返回匹配的元素集合 中 的 HTML 内容。 removeAttr() 从所有匹配的元素 中 移除指定的属性。 removeClass() 从所有匹配的元素 中 删除全部或者指定的类。 toggleClass() 从匹配的元素 中 添加或删除一个类。 val() 设置或返回匹配元素的值。 @ jQuery CSS 操作函数 下面列出的这些方法设置或返回元素的 CSS 相关属性。 CSS 属性 描述 css() 设置或返回匹配元素的样式属性。 height() 设置或返回匹配元素的高度。 offset() 返回第一个匹配元素相对于文档的位置。 offsetParent() 返回最近的定位祖先元素。 position() 返回第一个匹配元素相对于父元素的位置。 scrollLeft() 设置或返回匹配元素相对滚动条顶部的偏移。 scrollTop() 设置或返回匹配元素相对滚动条左侧的偏移。 width() 设置或返回匹配元素的宽度。 @ jQuery Ajax 操作函数 jQuery 库拥有完整的 Ajax 兼容套件。其 中 的函数和方法允许我们在不刷新浏览器的情况下从服务器加载数据。 函数 描述 jQuery .ajax() 执行异步 HTTP (Ajax) 请求。 .ajaxComplete() 当 Ajax 请求完成时注册要调用的处理程序。这是一个 Ajax 事件。 .ajaxError() 当 Ajax 请求完成且出现错误时注册要调用的处理程序。这是一个 Ajax 事件。 .ajaxSend() 在 Ajax 请求发送之前显示一条消息。 jQuery .ajaxSetup() 设置将来的 Ajax 请求的默认值。 .ajaxStart() 当首个 Ajax 请求完成开始时注册要调用的处理程序。这是一个 Ajax 事件。 .ajaxStop() 当所有 Ajax 请求完成时注册要调用的处理程序。这是一个 Ajax 事件。 .ajaxSuccess() 当 Ajax 请求成功完成时显示一条消息。 jQuery .get() 使用 HTTP GET 请求从服务器加载数据。 jQuery .getJSON() 使用 HTTP GET 请求从服务器加载 JSON 编码数据。 jQuery .getScript() 使用 HTTP GET 请求从服务器加载 JavaScript 文件,然后执行该文件。 .load() 从服务器加载数据,然后把返回到 HTML 放入匹配元素。 jQuery .param() 创建数组或对象的序列化表示,适合在 URL 查询字符串或 Ajax 请求 中 使用 。 jQuery .post() 使用 HTTP POST 请求从服务器加载数据。 .serialize() 将表单内容序列化为字符串。 .serializeArray() 序列化表单元素,返回 JSON 数据结构数据。 @ jQuery 遍历函数 jQuery 遍历函数包括了用于筛选、查找和串联元素的方法。 函数 描述 .add() 将元素添加到匹配元素的集合 中 。 .andSelf() 把堆栈 中 之前的元素集添加到当前集合 中 。 .children() 获得匹配元素集合 中 每个元素的所有子元素。 .closest() 从元素本身开始,逐级向上级元素匹配,并返回最先匹配的祖先元素。 .contents() 获得匹配元素集合 中 每个元素的子元素,包括文本和注释节点。 .each() 对 jQuery 对象进行迭代,为每个匹配元素执行函数。 .end() 结束当前链 中 最近的一次筛选操作,并将匹配元素集合返回到前一次的状态。 .eq() 将匹配元素集合缩减为位于指定索引的新元素。 .filter() 将匹配元素集合缩减为匹配 选择器 或匹配函数返回值的新元素。 .find() 获得当前匹配元素集合 中 每个元素的后代,由 选择器 进行筛选。 .first() 将匹配元素集合缩减为集合 中 的第一个元素。 .has() 将匹配元素集合缩减为包含特定元素的后代的集合。 .is() 根据 选择器 检查当前的匹配元素集合,如果存在至少一个匹配元素,则返回 true。 .last() 将匹配元素集合缩减为集合 中 的最后一个元素。 .map() 把当前匹配集合 中 的每个元素传递给一个函数,产生包含返回值的新的 jQuery 对象。 .next() 获得匹配元素集合 中 每个元素紧邻的同辈元素。 .nextAll() 获得匹配元素集合 中 每个元素之后的所有同辈元素,由 选择器 进行筛选(可选)。 .nextUntil() 获得每个元素之后所有的同辈元素,直到遇到匹配 选择器 的元素为止。 .not() 从匹配元素集合 中 删除元素。 .offsetParent() 获得用于定位的第一个父元素。 .parent() 获得当前匹配元素集合 中 每个元素的父元素,由 选择器 筛选(可选)。 .parentsUntil() 获得当前匹配元素集合 中 每个元素的祖先元素,直到遇到匹配 选择器 的元素为止。 .prev() 获得匹配元素集合 中 每个元素紧邻的前一个同辈元素,由 选择器 筛选(可选)。 .prevAll() 获得匹配元素集合 中 每个元素之前的所有同辈元素,由 选择器 进行筛选(可选)。 .prevUntil() 获得每个元素之前所有的同辈元素,直到遇到匹配 选择器 的元素为止。 .siblings() 获得匹配元素集合 中 所有元素的同辈元素,由 选择器 筛选(可选)。 .slice() 将匹配元素集合缩减为指定范围的子集。 @ jQuery 数据存储函数 这些方法允许我们将指定的 DOM 元素与任意数据相关联。 函数 描述 .data() 存储与匹配元素相关的任意数据。 jQuery .data() 存储与指定元素相关的任意数据。 .removeData() 移除之前存放的数据。 jQuery .removeData() 移除之前存放的数据。 @ jQuery 队列控制函数 函数 描述 .clearQueue() 从队列 中 删除所有未运行的项目。 .dequeue() 从队列最前端移除一个队列函数,并执行它。 jQuery .dequeue() 从队列最前端移除一个队列函数,并执行它。 .queue() 显示或操作匹配元素所执行函数的队列。 jQuery .queue() 显示或操作匹配元素所执行函数的队列。 九. jQuery 核心函数 函数 描述 jQuery () 接受一个字符串,其 中 包含了用于匹配元素集合的 CSS 选择器 。 找出所有属于 div 元素的子元素的 p 元素,然后设置其边框属性: $("div > p").css("border", "1px solid gray"); 亲自试一试 定义和用法 jQuery () 方法接受一个字符串,其 中 包含了用于匹配元素集合的 CSS 选择器 。 jQuery () 函数有三种语法: 接受一个字符串,其 中 包含了用于匹配元素集合的 CSS 选择器 : jQuery (selector, [context]) 使用 原始 HTML 的字符串来创建 DOM 元素: jQuery (html,[ownerDocument]) 绑定一个在 DOM 文档载入完成后执行的函数: jQuery ( callback ) jQuery ( selector, [ context ] ) 该语法有以下几种用法: 用法 1 :设置 选择器 环境 jQuery (selector, [context]) 默认情况下, 选择器 从文档根部对 DOM 进行搜索。不过,可以为 $() 设置可选的 context 参数。 例如,如果我们希望在一个 callback 中 搜索一个元素,可以限定下面的搜索: $("div.foo").click(function() { $("span", this).addClass("bar"); 由于我们已经将 span 选择器 限定到 this 这个环境 中 ,只有被点击元素 中 的 span 会得到附加的 class。 在内部, 选择器 环境是通过 .find() 方法 实现 的,因此 $("span", this) 等价于 $(this).find("span")。 jQuery 的核心功能都是通过这个函数 实现 的。 jQuery 中 的一切都基于这个函数,或者说都是在以某种方式 使用 这个函数。这个函数最基本的用法就是向它传递一个表达式(通常由 CSS 选择器 组成),然后根据这个表达式来查找所有匹配的元素。 默认情况下, 如果没有指定 context 参数,$() 将在当前的 HTML document 中 查找 DOM 元素;如果指定了 context 参数,如一个 DOM 元素集或 jQuery 对象,那就会在这个 context 中 查找。在 jQuery 1.3.2 以后,其返回的元素顺序等同于在 context 中 出现的先后顺序。 用法 2 : 使用 DOM 元素 jQuery (element) 该函数允许我们通过 使用 以其他方式找到的 DOM 元素来创建 jQuery 对象。该功能通常的用法是,对已经通过 this 关键字传递到 callback 函数的元素调用 jQuery 的方法: $("div.foo").click(function() { $(this).slideUp(); 此例会在元素被点击时 使用 滑动动画对其进行隐藏。由于处理程序接受的 this 关键词 中 的被点击项目是纯的 DOM 元素,因此在对其调用 jQuery 的方法之前,必须用 jQuery 对象包装该元素。 这个函数也可以接收 XML 文档和 Window 对象(虽然它们不是 DOM 元素)作为有效的参数。 当 XML 数据从 Ajax 调用 中 返回后,我们可以 使用 $() 函数通过 jQuery 对象包装该数据。一旦完成,我们就可以 使用 .find() 和其他 DOM 遍历方法来取回 XML 结构 中 单个元素。 用法 3 :克隆 jQuery 对象 jQuery ( jQuery object) 当以参数的形式向 $() 函数传递 jQuery 对象后,会创建一个该对象的副本。与初始对象一样,新的 jQuery 对象引用相同的 DOM 元素。 用法 4 :返回空的集合 jQuery () 对于 jQuery 1.4,调用无参数的 jQuery () 方法会返回空的 jQuery 集合。在之前版本的 jQuery 中 ,这样会返回包含 document 节点的集合。 jQuery ( html, [ ownerDocument ] ) 该语法有以下几种用法: 用法 1 :创建新的元素 jQuery (html,[ownerDocument]) 你可以传递一个手写的 HTML 字符串,或者由某些模板引擎或插件创建的字符串,也可以是通过 AJAX 加载过来的字符串。但是在你创建 input 元素的时会有限制,可以参考第二个示例。 当然这个字符串可以包含斜杠 (比如一个图像地址),还有反斜杠。当你创建单个元素时,请 使用 闭合标签或 XHTML 格式。例如,创建一个 span ,可以用 $("") 或 $("") ,但不推荐 $("")。在 jQuery 中 ,这个语法等同于 $(document.createElement("span"))。 如果以参数的形式将字符串传递给 $(), jQuery 会检查字符串是否是 HTML (比如,字符串某些位置存在标签)。如果不是,则把字符串解释为 选择器 表达式,请见上面的讲解。但如果字符串是 HTML 片段,则 jQuery 试图创建由该 HTML 片段描述的 DOM 元素。然后会创建并返回一个引用这些 DOM 元素的 jQuery 对象: $("My new text").appendTo("body"); 如果 HTML 片段比不含属性的简单标签更复杂,如同上面 例子 中 的 HTML,那么元素实际的创建过程是由浏览器的 innerHTML 机制完成的。具体地讲, jQuery 会创建新的 元素,然后为传入的 HTML 片段设置元素的 innerHTML 属性。当参数只是简单的标签,比如$("") 或 $(""), jQuery 会通过内生的 JavaScript createElement() 函数来创建元素。 要确保跨平台兼容性,片段的结构必须良好。能够包含其他元素的标签必须成对出现(带有关闭标签): $(""); 不过, jQuery 也允许类似 XML 的标签语法: $(""); 无法包含其他元素的标签可以关闭,也可以不关闭: $(""); $(""); 用法 2 :设置属性和事件 jQuery (html,props) 对于 jQuery 1.4,我们可以向第二个参数传递一个属性映射。该参数接受能够传递给 .attr() 方法的属性的超集。此外,可以传递任意的事件类型,并可以调用下面的 jQuery 方法:val, css, html, text, data, width, height, or offset. 注意,Internet Explorer 不允许你创建 input 元素并改变其类型;您必须 使用 例如 "" 来规定类型。 创建一个 元素,同时设定 type 属性、属性值,以及一些事件。 $("", { type: "text", val: "Test", focusin: function() { $(this).addClass("active"); focusout: function() { $(this).removeClass("active"); }).appendTo("form"); jQuery ( callback ) 允许你绑定一个在 DOM 文档载入完成后执行的函数。 该函数的作用如同 $(document).ready() 一样,只不过用这个函数时,需要把页面 中 所有需要在 DOM 加载完成时执行的其他 $() 操作符都包装到其 中 来。尽管从技术上来说,这个函数是可链接的,但真正以这种方式链接的情况并不多。 当DOM加载完成后,执行其 中 的函数: $(function(){ // 文档就绪 函数 描述 jQuery .noConflict() 运行这个函数将 变量 $ 的控制权让渡给第一个 实现 它的那个库。 定义和用法 noConflict() 方法让渡 变量 $ 的 jQuery 控制权。 jQuery .noConflict([removeAll]) 参数 描述 removeAll 布尔值。指示是否允许彻底将 jQuery 变量 还原。 许多 JavaScript 库 使用 $ 作为函数或 变量 名, jQuery 也一样。在 jQuery 中 ,$ 仅仅是 jQuery 的别名,因此即使不 使用 $ 也能保证所有功能性。假如我们需要 使用 jQuery 之外的另一 JavaScript 库,我们可以通过调用 $.noConflict() 向该库返回控制权: 此外,通过向该方法传递参数 true,我们可以将 $ 和 jQuery 的控制权都交还给原来的库。用之前请考虑清楚! 这是相对于简单的 noConflict 方法更极端的版本,因为这将完全重新定义 jQuery 。这通常用于一种极端的情况,比如你想要将 jQuery 嵌入一个高度冲突的环境。注意:调用此方法后极有可能导致插件失效。 将 $ 引用的对象映射回原始的对象: jQuery .noConflict(); jQuery ("div p").hide(); // 使用 jQuery $("content").style.display = "none"; // 使用 其他库的 $() 恢复 使用 别名 $,然后创建并执行一个函数,在这个函数的作用域 中 仍然将 $ 作为 jQuery 的别名来 使用 。在这个函数 中 ,原来的 $ 对象是无效的。这个函数对于大多数不依赖于其他库的插件都十分有效: jQuery .noConflict(); (function($) { $(function() { // 使用 $ 作为 jQuery 别名的代码 })( jQuery ); ... // 其他用 $ 作为别名的库的代码 可以将 jQuery .noConflict() 与简写的 ready 结合,使代码更紧凑: jQuery .noConflict()(function(){ // 使用 jQuery 的代码 ... // 其他库 使用 $ 做别名的代码 创建一个新的别名用以在接下来的库 中 使用 jQuery 对象: var j = jQuery .noConflict(); j("div p").hide(); // 基于 jQuery 的代码 $("content").style.display = "none"; // 基于其他库的 $() 代码 完全将 jQuery 移到一个新的命名空间: var dom = {}; dom.query = jQuery .noConflict(true); dom.query("div p").hide(); // 新 jQuery 的代码 $("content").style.display = "none"; // 另一个库 $() 的代码 jQuery ("div > p").hide(); // 另一个版本 jQuery 的代码 《JavaScript权威指南(第6版)》要讲述的内容涵盖JavaScript语言本身,以及web浏览器所 实现 的JavaScript API。本书第6版涵盖了 html5 和 ecmascript 5,很多章节完全重写,增加了当今 web 开发的最佳实践的内容,新增的章节包括 jQuery 、服务器端 JavaScript、图形编程以及JavaScript式的面向对象。本书不仅适合初学者系统学习,也适合有经验的 JavaScript开发者随手翻阅。 《JavaScript权威指南(第6版)》是程序员学习核心JavaScript语言和由WEB浏览器定义的JavaScript API的指南和综合参考手册。 《JavaScript权威指南(第6版)》涵盖html5和ecmascript 5。很多章节完全重写,以便与时俱进,紧跟当今的最佳web开发实践。本书新增章节描述了 jQuery 和服务器端JavaScript。 本书适合那些希望学习WEB编程语言的初、 中 级程序员和希望精通JavaScript的程序员阅读。 作者:(美国)弗兰纳根(David Flanagan) 译者:淘宝前端团队 弗兰纳根(David Flanagan)是一名程序员,也是一名作家,他在O’Reilly出版的其他畅销书还包括《JavaScript Pocket Reference》、《The Ruby Programming Language》、以及《Java in a Nutshell》。David毕业于麻省理工学院,获得计算机科学与工程学位。他和妻子和孩子一起生活在西雅图和温哥华之间的美国太平洋西北海岸。 第1章 javascript概述 5 1.1 javascript语言核心 8 1.2 客户端javascript 12 第一部分 javascript 语言核心 第2章 词法结构 25 2.1 字符集 25 2.2 注释 27 2.3 直接量 27 2.4 标识符和保留字 28 2.5 可选的分号 30 第3章 类型、值和 变量 32 3.1 数字 34 3.2 文本 38 3.3 布尔值 43 3.4 null和undefined 44 3.5 全局对象 45 3.6 包装对象 46 3.7 不可变的原始值和可变的对象引用 47 .3.8 类型转换 48 3.9 变量 声明 55 3.10 变量 作用域 56 第4章 表达式和运算符 60 4.1 原始表达式 60 4.2 对象和数组的初始化表达式 61 4.3 函数定义表达式 62 4.4 属性访问表达式 63 4.5 调用表达式 64 4.6 对象创建表达式 64 4.7 运算符概述 65 4.8 算术表达式 69 4.9 关系表达式 74 4.10 逻辑表达式 79 4.11 赋值表达式 81 4.12 表达式计算 83 4.13 其他运算符 86 第5章 语句 91 5.1 表达式语句 92 5.2 复合语句和空语句 92 5.3 声明语句 94 5.4 条件语句 96 5.5 循环 101 5.6 跳转 106 5.7 其他语句类型 113 5.8 javascript语句小结 116 第6章 对象 118 6.1 创建对象 120 6.2 属性的查询和设置 123 6.3 删除属性 127 6.4 检测属性 128 6.5 枚举属性 130 6.6 属性getter和setter 132 6.7 属性的特性 134 6.8 对象的三个属性 138 6.9 序列化对象 141 6.10 对象方法 142 第7章 数组 144 7.1 创建数组 144 7.2 数组元素的读和写 145 7.3 稀疏数组 147 7.4 数组长度 148 7.5 数组元素的添加和删除 149 7.6 数组遍历 149 7.7 多维数组 151 7.8 数组方法 152 7.9 ecmascript 5 中 的数组方法 156 7.10 数组类型 160 7.11 类数组对象 161 7.12 作为数组的字符串 163 第8章 函数 165 8.1 函数定义 166 8.2 函数调用 168 8.3 函数的实参和形参 173 8.4 作为值的函数 178 8.5 作为命名空间的函数 181 8.6 闭包 182 8.7 函数属性、方法和构造函数 188 8.8 函数式编程 194 第9章 类和模块 201 9.1 类和原型 202 9.2 类和构造函数 203 9.3 javascript 中 java式的类继承 207 9.4 类的扩充 210 9.5 类和类型 212 9.6 javascript 中 的面向对象技术 217 9.7 子类 230 9.8 ecmascript 5 中 的类 2 find()会在div元素内 寻找 class为classname的元素。 filter()则是筛选div的class为classname的元素。 基本是find子元素找,filter是平级找 ·find 函数是在当前对象集合的子元素 中 进行查询; ·filter 函数是对当前对象集合进行过滤, 利用过滤条件缩小范围; ·find 函数的参数是 jQuery 选择器 表达式; ·filter 的参数也是 选择器 表达式, 但可以有多个条件, 用逗号分隔(逻辑或关系); ·filter 的参数也可以是个函数, 调用函数时会自动传入 index 参数, 函数需返回 true或false 以选 中 或排除元素. 1、属性 选择器 是 变量 时,("div[属性=′"+ 变量 属性值+"′]");2、多属性 选择器 时,("div[属性 = '"+ 变量 属性值+"']"); 2、多属性 选择器 时,("div[属性=′"+ 变量 属性值+"′]");2、多属性 选择器 时,(“div[属性一 = 属性值一 ][属性二 = 属性值二]”); <div data-value="test" data-status="on">div_test_on</div> <div data-value= 最近写项目,要用到 jquery 的属性 选择器 ,对这种 选择 虽然知道,但是书写的方法,不怎么知道,通过查阅资料,了解了这种详情。 var id = item.attr(“data-id”); item.parent().find(“tr[data-id=’” + id + “’]”).remove(); 希望可以帮助到大家。 例子 一:用户名状态张三正常李四冻结王二麻子冻结$(document).ready(function(){var uid = 1001;$("td[data-uid = "+ uid +"]").html('正常');} 例子 二:$(function(){alert(123);var v=4;var test=$("input[type='radio'][value='"+v+"']");//直接拼接... 今日内容概要1 > DOM操作标签1.1 > 动态 创建一个a 标签1.2 > 默认与自定义属性1.3 > getAttribute和removAttribute 方法1.4 > innerText与innerHTML2 > 获取值操作2.1 > 获取普通值数据2.2 > 获取文件数据3 > 属性操作3.1 > 类属性操作3.2 > 样式操作4 > 事件5 > 事件案例5.1 > 数据校验5.2 > 搜索框案例5.3 1、 变量 id 添加到 jquery 中 var User = ["Uno", "Uname", "Usex", "Uid", "Ujob", "Udept", "Unow", "Ucphone", "Ucemail", "Uip", "Uphone", "Uhphone" <html> <head> <script type="text/javascript" src="/ jquery / jquery .js"></script> </head> <bod jquery 作为一个经久不衰的js库,用起来其实是很方便的。就单单那 选择器 来说,可以秒杀js几条街。 原生js要document.getElementsByTagName("ul") 这么麻烦的写法,jq一个$("ul") 就解决了。 但是在实践操作的时候也遇到了问题。 想 实现 查询到第i个ul并为其增加class为city的li标签。 如果 使用 原生js,虽然可以查到第i个ul,但是增加节点
逆袭的红酒 · vba match精确查找-掘金 1 年前 |