Archive for the ‘jQuery’ Category

jQuery中不为人知的秘密之二

星期日, 08月 10th, 2008 73 views

又开始写jQuery的秘密了~ 这里写的基本上都是没啥用的东西,大家随便看看好了,有用的都放在文档里了~ 这回先说选择器, 两个特殊的选择器,没有在文档里列出来。有可能只是选择器正则匹配的失误,也可能是故意的,但我源码中看不出来。望各位看官指点。注意,下面两个特殊选择器,随时可能在以后版本中消失,慎用。本文涉及的是1.2.6,经测试1.2.3也可使用。 创建一个空jQuery对象: $(" "); //切记,引号中间至少有_一个_空格 这段简易的代码即可创建一个空的jQuery对象。这就类似创建一个代码片段。但由于是空的,所以无法append进任何东西。但你可以用add将你要的东西添加进去。 获取document,有时候需要写一些关于document的事件,比如keypress之类的,或者其他的,就可以用 $(""); //切记,引号中间_没有_空格 这一定程度上可以用于混淆代码,比如将$(document).ready()写成$("").ready(),不知道的人就看不懂了。当然,要看过本文的人就都知道了~~(笑~) 顺便一说,前端加密是没有可能的,混淆也是有限度的。有jQuery的操作是链式操作,没有中间变量,同时通常绑定函数也是匿名函数,所以对于jQuery代码的混淆更是没有太大用处。除非,不再使用匿名函数,每次都外部定义一个。同时不再使用链式操作,用next,parent之类操作的时候,统统再定义一个中间变量。这样你的jQuery代码已经没有jQuery风格了,对混淆会稍微有点点帮助。注意,以上所有混淆操作,只防君子不防小人!切记,前端开发不可能加密!所以一切都做好开源的准备!了解GPL、MIT之类的都是有必要的! 如果你要用中间变量,像前面说的为了混淆,有时候你可能需要用到之前的一个对象,就好像在链式写法中用end()的效果,那就可以用prevObject属性,end()就是返回这个属性。 $("#id").prevObject; //切记,最后没有括号,这个是属性不是方法 下面说的这个其实不是很秘密,但值得一提 attr是很伟大的方法,以下这些都是可以执行的,你就可以通过这些来进行一些简单的判断,比如这个元素的标签名啦之类的。 $("body").attr("tagName"); $("body").attr("nodeName"); $("body").attr("nodeType"); 还有个相关的,他返回的是布尔值true/false jQuery.nodeName( elem, nodeName ) 第一个参数是一个DOM对象,不是jQuery对象,第二个就是节点名称(标签名)了,大小写无关。返回true/false 有人问,为什么我不直接使用elem.nodeName==nodeName呢,爱用写这么麻烦呢? 看一下jQuery的源码就知道了 nodeName: function( elem, name ) { return elem.nodeName && elem.nodeName.toUpperCase() == name.toUpperCase(); }, 明白了么?浏览器兼容性问题,某些浏览器中的nodeName是大写,有些是小写,够恶心吧? 兼容一下总是好的~~

jQuery中Ajax事件

星期五, 08月 1st, 2008 169 views

参考资料地址: http://docs.jquery.com/Ajax_Events Ajax会触发很多事件。 有两种事件,一种是局部事件,一种是全局事件: 局部事件:通过$.ajax来调用并且分配。 $.ajax({ beforeSend: function(){ // Handle the beforeSend event }, complete: function(){ // Handle the complete event } // ... }); 全局事件,可以用bind来绑定,用unbind来取消绑定。这个跟click/mousedown/keyup等事件类似。但他可以传递到每一个DOM元素上。 $("#loading").bind("ajaxSend", function(){ //使用bind $(this).show(); }).ajaxComplete(function(){ //直接使用ajaxComplete $(this).hide(); }); 当然,你某一个Ajax请求不希望产生全局的事件,则可以设置global:false $.ajax({ url: "test.html", global: false, // ... }); 事件的顺序如下: ajaxStart 全局事件 开始新的Ajax请求,并且此时没有其他ajax请求正在进行。 beforeSend 局部事件 当一个Ajax请求开始时触发。如果需要,你可以在这里设置XHR对象。 ajaxSend 全局事件 请求开始前触发的全局事件 success 局部事件 请求成功时触发。即服务器没有返回错误,返回的数据也没有错误。 ajaxSuccess 全局事件 全局的请求成功 error 局部事件 仅当发生错误时触发。你无法同时执行success和error两个回调函数。 ajaxError 全局事件 全局的发生错误时触发 complete 局部事件 不管你请求成功还是失败,即便是同步请求,你都能在请求完成时触发这个事件。 ajaxComplete 全局事件 全局的请求完成时触发 ajaxStop 全局事件 当没有Ajax正在进行中的时候,触发。 局部事件回调的参数在文档中写的很清楚了,这里就不累述了。 全局事件中,除了ajaxStart和ajaxStop之外,其他的事件都有3个参数 event, XMLHttpRequest, ajaxOptions 第一个是事件,第二个是XHR对象,第三个参数最有用,是当时调用这个ajax的时候的参数。 对于ajaxError,还有第四个参数thrownError,只有当异常发生时才会被传递。 我们可以利用ajaxOptions来写一个全局的ajax事件。 比如 $("#msg").beforeSend(function(e,xhr,o) { $(this).html("正在请求"+o.url); }).ajaxSuccess(function(e,xhr,o) { $(this).html(o.url+"请求成功"); }).ajaxError(function(e,xhr,o) { $(this).html(o.url+"请求失败"); }); 对于这个例子, 这样我们就可以很方便的全局地在某个地方显示当前的ajax状态。 当然,之前说了,第三个参数实际上是传递给ajax的参数。get/post/load/getScript/getJSON等方法本质上都是调用ajax方法的,所以ajaxOptions.url属性总是有效的。 还有更丰富的例子。 如果你用ajax调用,还可以传递自定义参数。下面的例子我就自定义了一个msg参数给了ajax调用 //自定义参数msg $.ajax({url:"test1.html",type:"get",msg:"页面一"}); $.ajax({url:"test2.html",type:"get",msg:"页面二"}); $.ajax({url:"test3.html",type:"get",msg:"页面三"}); $.ajax({url:"test4.html",type:"get",msg:"页面四"}); //这里就能获取到自定义参数msg。 //这可以用来区别对待不同的ajax请求。 $("#msg").beforeSend(function(e,xhr,o) { $(this).html("正在请求"+o.msg); }).ajaxSuccess(function(e,xhr,o) { $(this).html(o.msg+"请求成功"); }).ajaxError(function(e,xhr,o) ...

页面加载完成后新建的元素事件绑定问题(下)

星期四, 07月 24th, 2008 294 views

页面加载完成后新建的元素事件绑定问题(上) ============================= 2号解决方案——事件冒泡法 利用事件冒泡的原理,我们给这个按钮的祖先元素绑定事件处理函数。 然后通过event.target这个对象来判断,这个事件是不是我们要找的对象触发的。 通常可以利用一些DOM属性,比如event.target.className、event.target.tagName等之类的来判断。 删除 jQuery(function($) { //第四个表格的删除按钮事件绑定 $("#table4").click(function(e) { if (e.target.className=="del") { $(e.target).parents("tr").remove(); }; }); //第四个表格的添加按钮事件绑定 ...

页面加载完成后新建的元素事件绑定问题(上)

星期四, 07月 24th, 2008 259 views

本文demo:http://shawphy.com/demo/event/event.html 很多人会像我一样遇到这样一个问题: 在页面加载完成后给元素绑定了事件,但又新增加的元素上却没有绑定任何事件。 js的事件监听跟css不一样,css只要设定好了样式,不论是原来就有的还是新添加的,都有一样的表现。而事件监听不是,你必须给每一个元素单独绑定事件。 常见的例子是处理表格的时候。每行行末有个删除按钮,点了这个能够删除这一行。 这行原来就有 删除 ...

jQuery中不为人知的秘密之一

星期三, 07月 16th, 2008 355 views

jQuery的向来以其完善的文档著称,而不像早期的Prototype那样库写的很牛,而文档很糟糕,其他使用者不得不看他的源码以了解一些功能。 但是,不得不说,文档的更新速度是远没有其程序变化的快的。 这个专题就是用于介绍一些隐藏在jQuery源码内部的事情。 今天先揭秘2条 1,序列化一个对象 类似于Prototype中的$H(obj).toQueryString() jQuery中也有一个内部函数,用于在ajax时候序列化对象用: jQuery.param var obj={A:1,B:2,C:3}; jQuery.param(obj); //A=1&B=2&C=3 2,获取原始的event对象 用过jQuery都知道,jQuery提供了一个事件对象,用于在事件处理函数中使用,并且这个对象已经将ie中的事件修复成了标准的W3C事件。具体可以参考我这篇日志 但他并没有完全统一所有事件,比如获取mousemove的event事件中鼠标的相对坐标的位置,ie和ff分别用的x和layerX来实现,而jQuery没有给统一。我们只能使用原始的event对象再自己判断,此时就可以使用 e.originalEvent 这样就得到了原始的event对象了 在ie中,这个指向的是window.event,而在其他浏览器中,就是传递给事件处理函数的第一个参数。 像上面那个例子,我就用了如下的代码,用于获取鼠标的相对坐标。 $("#menuWrap").mousemove(function(e) { var xx=e.originalEvent.x||e.originalEvent.layerX||0; }); 可以参考我写的一个简单的菜单。 这个页面看上去动作还有点僵硬,是由于动画函数的问题。 关于动画函数,将在以后详细讲解。

jQuery的链式动画写法中加入setTimeout

星期六, 07月 12th, 2008 217 views

今日闲逛,看到一个简单的封装,用于在两次animate之间,加入一定的时间间隔的等待。 原文地址:http://docs.jquery.com/Cookbook/wait 你还可以在里边看到demo $.fn.wait = function(time, type) { time = time || 1000; type = type || "fx"; return this.queue(type, function() { var self = this; setTimeout(function() { $(self).dequeue(); }, time); }); }; 具体用法是,.wait( [time], [type] ) 第一个参数是时间,默认是1000毫秒。 第二个参数是类型,默认是fx即动画效果 function runIt() { $("div").wait() .animate({left:'+=200'},2000) .wait() .animate({left:'-=200'},1500,runIt); } runIt(); 由于我对对queue这个函数用法不是很熟,所以我也不太清楚第二个参数还能设置除了fx之外的其他什么。 有熟悉的朋友可以帮忙解释一下。

读jQuery基础教程时的需要注意的1.1和1.2版的差别

星期二, 06月 24th, 2008 261 views

jQuery基础教程这本书已经出版咯~ 这本书可以用于快速入门,大大缩短jQuery入门所需要的时间(实际上就算没有这本书,看现有的资料,1个星期也足够入门了)。 但还是强烈建议购买此书,因为这能让你能达到看现在有资料好几个月也未必能达到的水平。 至少我现在依然能从上面学到不少东西! 最近书到手了,翻阅了一下 也知道由于译者比较忠于原著,所以未能对其中少部分过时的内容予以修订。 看到他写了不少的“译者注”,但对于1.2的更新是完全没有涉及。 已知的重大变更是: (1),1.2以后中属性选择器均不需要@,但依然兼容1.1的选择器。 (2),第一章里提到了XPath选择符在1.2中因为不常用且影响效率而取消了,如需使用则需要兼容1.1中的XPath插件(http://plugins.jquery.com/project/xpath),同样第六章和第九章涉及XML解析等也无法使用XPath语法了。关于更多xml解析的问题,可以看http://shawphy.com/2008/01/load-xml-by-ajax-with-jquery-and-parse-it.html (3),第五章,关于clone(false)的描述,在1.2中,已经整合了复制绑定事件的插件了,即增加了clone(true)功能用于连同元素绑定的事件一起复制。而取消了clone(false)这个只复制元素而不复制内容的方法。读者需要注意。可以用.clone().empty()代替。 (4),第七章中部分地方使用了已被废弃的gt()和lt()方法。可以使用slice代替,或者用:gt和:lt选择符代替。具体请参考文档。 (5),第十章,流行插件中,由于Dimensions插件过于流行,已经被整合进jQuery,所以你无需再另行导入。而Interface插件也已经更新换代,又官方重新编写后改名为jQuery UI。(http://ui.jquery.com)

用闭包制作简单动画效果

星期一, 06月 9th, 2008 134 views

刚才用书上看来的写了一下,貌似还蛮好玩的 http://shawphy.com/demo/closure/animate.html 大家看那个小红方框 ie6请点上面链接查看效果,或者弹开后刷新一下看效果 function tipUpdown(obj){ var objorg=obj.css("top").replace(/px/,"")-0; for(var i=0;i

jQuery UI 1.5 正式版发布

星期一, 06月 9th, 2008 172 views

原文: http://jquery.com/blog/2008/06/09/jquery-ui-v15-released-focus-on-consistent-api-and-effects/ 实在太长,懒得翻译了…… 总体来说,蛮好用的看上去。官方的文档还没有完全跟上,只有老的一些了。 等下回官网的文档好了,我也一并更新下吧。 主要是统一了API * $(”div”).draggable() creates a draggable * $(”div”).draggable(”destroy”) destroys it * $(”div”).draggable(”method”) calls another method on the plugin. 修正了N多的BUG 增加了http://script.aculo.us/这里很多特效 http://ui.jquery.com/themeroller 这里可以做自己的主题 http://ui.jquery.com/download 这里可以下载到最新版 http://docs.jquery.com/UI 这里是文档 记得datepicker吧,里边的简体中文部分是cloudream翻译的~

jQuery 1.2.6 发布信息

星期三, 06月 4th, 2008 79 views

姗姗来迟的1.2.6的发布信息,其实本来是1.2.4的,结果扯出点小事来。 这回jq文件97.8K,直逼100K大关啦。估计下个版本就破了。 其实pack版破30也是很早以前的事情了 好了,多的不说了 主要是性能更新, 可以看这里: http://spreadsheets.google.com/pub?key=pFIHldY_CksyThxfgx6krfA 没有IE6,被无视咯~ 事件处理快了103% ——快了很多啊 CSS选择器快了13%——非常好,这个最重要了,越快越好。不过受限于正则的速度。。。是由于jQuery.map() 提升866% 还有 jQuery.extend() 19% 提升速度,所以导致整个都快了 .offset() 21% .css() 25% 然后是新特性 Dimensions插件彻底融入jquery内核。这个上次已经说过了。 .attr()重写了,解决了15项bug .toggle() 能接受更多函数了 比如: $("div").toggle(function(){ $(this).removeClass("three").addClass("one"); }, function(){ $(this).removeClass("one").addClass("two"); }, function(){ $(this).removeClass("two").addClass("three"); }); .index() 支持jQuery集合了 var test = $("div.test"); $("div").index( test ) == 3 jQuery.makeArray可以把任何东西弄成数组了 jQuery.makeArray( document.getElementsByTagName("div") ) // => [ div, div, div ] jQuery.makeArray( true ) // => [ true ] jQuery.makeArray() // => [] beforeSend 能取消Ajax调用了 $.ajax({ beforeSend: function(){ ...