??xml version="1.0" encoding="utf-8" standalone="yes"?>亚洲三级视频在线观看,亚洲成在人线电影天堂色,久久精品国产亚洲http://www.tkk7.com/kissyan4916/category/42271.html哎哟 OrzQ不错喔~~希望l识更多喜爱Java的朋?<br> &nbsp;&nbsp;&nbsp;&nbsp;QQQ?5350863 MSNQchenyanhubusiness@gmail.com E-mailQchenyanhu@vip.163.comzh-cnSat, 23 Oct 2010 04:09:12 GMTSat, 23 Oct 2010 04:09:12 GMT60JQuery 分页E序(附源?http://www.tkk7.com/kissyan4916/articles/330217.html金色闪电(sh)金色闪电(sh)Sun, 29 Aug 2010 17:29:00 GMThttp://www.tkk7.com/kissyan4916/articles/330217.htmlhttp://www.tkk7.com/kissyan4916/comments/330217.htmlhttp://www.tkk7.com/kissyan4916/articles/330217.html#Feedback0http://www.tkk7.com/kissyan4916/comments/commentRss/330217.htmlhttp://www.tkk7.com/kissyan4916/services/trackbacks/330217.html 下蝲地址Q?a >http://download.csdn.net/source/2661313 .

金色闪电(sh) 2010-08-30 01:29 发表评论
]]>
Q{Q?5 ?JavaScript Web UI ?/title><link>http://www.tkk7.com/kissyan4916/articles/321419.html</link><dc:creator>金色闪电(sh)</dc:creator><author>金色闪电(sh)</author><pubDate>Wed, 19 May 2010 14:52:00 GMT</pubDate><guid>http://www.tkk7.com/kissyan4916/articles/321419.html</guid><description><![CDATA[<p>几乎所有的?Web 应用都基于一个或多个 Web UI 库或框架Q这?UI 库与框架极大地简化了(jin)开发进E,q带来一_(d)可靠Q以?qing)高度交互性的用户界面。本文介l了(jin) 15 个非常强大的 JavaScript Web UI 库,非常适合各种各种规模的富 Web 应用的开发?/p> <h2 class="subtitle">LivePipe</h2> <p><a >LivePipe UI</a> Z <a >Prototype Javascript 框架</a>Q包含了(jin)一整套l严格测试ƈ高度可扩展的 UI 控gQ拥有很好的文档Q在不支?JavaScript 的环境中Q可以无~降U用。包?Tab, H体Q文本框Q多选框Q评分控Ӟq度条,滚动条,右键菜单{多U控件?/p> <p><a ><strong>LivePipe</strong> 首页与下?/a><br /> <a ><strong>LivePipe</strong> 演示与示?/a></p> <p><a ><img style="border-right-width: 0px; border-top-width: 0px; border-bottom-width: 0px; border-left-width: 0px" alt="" src="http://speckyboy.com/wp-content/uploads/2010/05/webui_02.jpg" /></a></p> <p> </p> <h2 class="subtitle">UKI</h2> <p><a ></a></p> <p><a >UKI</a> 是一套简单的 JavaScript UI 工具集,用于快速创建桌面风格的 Web 应用。包含的控g从滑动条Q到分栏视图Q不一而。熟(zhn)?<a >jQuery</a> 的开发者会(x)发现q个工具很容易上手,非常z,无需安装框架Q不依赖 CSS 引用?/p> <p><a ><strong>UKI</strong> 主页与下?/a><br /> <a ><strong>UKI</strong> 控gQ演C,CZ</a></p> <p><a ><img style="border-right-width: 0px; border-top-width: 0px; border-bottom-width: 0px; border-left-width: 0px" alt="" src="http://speckyboy.com/wp-content/uploads/2010/05/webui_04.jpg" /></a></p> <p> </p> <h2 class="subtitle">MochaUI</h2> <p><a ></a></p> <p><a >MochaUI</a> ?<a >MooTools Javascript 框架</a> ?ExplorerCanvas 的一个备受欢q的扩展Q可以用来快速创?Web 应用QW(xu)eb 桌面Q网站,CgQ独?WindowsQModal 对话框等{?/p> <p><a ><strong>MochaUI</strong> 主页与下?/a><br /> <a ><strong>MochaUI</strong> 控gQ演C,CZ</a></p> <p><a ><img style="border-right-width: 0px; border-top-width: 0px; border-bottom-width: 0px; border-left-width: 0px" alt="" src="http://speckyboy.com/wp-content/uploads/2010/05/webui_06.jpg" /></a></p> <p>中文~译来源Q?a ><strong>锐商企业CMS</strong> |站内容理pȝ</a> 官方|站</p> <h2 class="subtitle">Sigma Ajax UI Builder</h2> <p><a >SigmaVisual</a> 是一套基?Web 的,所见即所得的 AJAX UI 创徏工具Q包含超q?0个不见,?TabQ对话框Q树(wi)形图Q时间线{,Z JavaScript ?PHP?/p> <p><a ><strong>Sigma Ajax UI Builder</strong> 主页和下?/a><br /> <a ><strong>Sigma Ajax UI Builder</strong> 控gQ演C和CZ</a></p> <p><a ><img style="border-right-width: 0px; border-top-width: 0px; border-bottom-width: 0px; border-left-width: 0px" alt="" src="http://speckyboy.com/wp-content/uploads/2010/05/webui_08.jpg" /></a></p> <p> </p> <h2 class="subtitle">JxLib based MooTools</h2> <p><a ></a></p> <p><a >JxLib</a> 是一个基?<a >MooTools</a> ?JavaScript UI 框架Q包含多?Web E序都需要的基本I间Q如按钮QTabQ菜单,?wi)Şl构Q对话框{等。JxLib q支持换肤功能?/p> <p><a ><strong>JxLib</strong> 主页与下?/a><br /> <a ><strong>JxLib</strong> 控gQ演CZCZ</a></p> <p><a ><img style="border-right-width: 0px; border-top-width: 0px; border-bottom-width: 0px; border-left-width: 0px" alt="" src="http://speckyboy.com/wp-content/uploads/2010/05/webui_10.jpg" /></a></p> <p> </p> <h2 class="subtitle">Dijit – The Dojo Toolkit</h2> <p><a ></a></p> <p><a >Dijit</a> Z <a >Dojo</a>Q也是学?Dojo 扩展的一个好L(fng)。可以用来创建非常漂亮的 Web 2.0 GUI。支持多语种Q甚x持不同语U的文字书写方向以及(qing)本地化数字,日期{等?/p> <p><a ><strong>Dijit</strong> 主页Q下?/a><br /> <a ><strong>Dijit</strong> 控gQ演C,CZ</a></p> <p><a ><img style="border-right-width: 0px; border-top-width: 0px; border-bottom-width: 0px; border-left-width: 0px" alt="" src="http://speckyboy.com/wp-content/uploads/2010/05/webui_12.jpg" /></a></p> <p> </p> <h2 class="subtitle">jQuery TOOLS</h2> <p><a ></a></p> <p><a >jQuery Tools</a> 是一个非常轻量(2.5kbQ的常用 UI 库,支持以下 jQuery 对象QTabs, 工具提示Q滚动条Q层Q表单以?Flash 嵌套?/p> <p><a ><strong>jQuery TOOLS</strong> 主页与下?/a><br /> <a ><strong>jQuery TOOLS</strong> 控gQ演C,CZ</a></p> <p><a ><img style="border-right-width: 0px; border-top-width: 0px; border-bottom-width: 0px; border-left-width: 0px" alt="" src="http://speckyboy.com/wp-content/uploads/2010/05/webui_14.jpg" /></a></p> <p> </p> <h2 class="subtitle">jQuery UI</h2> <p><a ></a></p> <p><a >jQuery UI</a> Z <a >jQuery</a>Q包?3 个大c,CgQ一些内|的 UI 对象Q效果,对各U网对象施加动L果(如爆炸效果)(j)Q鼠标交互,如拖放操作?/p> <p><a ><strong>jQuery UI</strong> 首页与下?/a><br /> <a ><strong>jQuery UI</strong> 控gQ演CZCZ</a></p> <p><a ><img style="border-right-width: 0px; border-top-width: 0px; border-bottom-width: 0px; border-left-width: 0px" alt="" src="http://speckyboy.com/wp-content/uploads/2010/05/webui_16.jpg" /></a></p> <p> </p> <h2 class="subtitle">Prototype UI</h2> <p><a ></a></p> <p><a >Prototype UI</a> Z <a >Prototype</a> ?<a >Script.aculo.us</a>Q包括多个模块(旋{木马QModal H口Q阴影,右键菜单{)(j)Q每个模块可以单独安装用?/p> <p><a ><strong>Prototype UI</strong> 主页与下?/a><br /> <a ><strong>Prototype UI</strong> 控gQ演CZCZ</a></p> <p><a ><img style="border-right-width: 0px; border-top-width: 0px; border-bottom-width: 0px; border-left-width: 0px" alt="" src="http://speckyboy.com/wp-content/uploads/2010/05/webui_18.jpg" /></a></p> <p> </p> <h2 class="subtitle">Jitsu</h2> <p><a ></a></p> <p><a >Jitsu</a> 功能包括 XML 标记Q页面编译,动画引擎QAjax 以及(qing)q行时检等{,它的 Ajax 功能使消费 Web 应用的创建变得非常简单,支持客户端数据绑定,q可以将面~译?JavaScriptQ?a >Jitsu</a> ?Firefox ?IE 中运行最佟?/p> <p><a ><strong>Jitsu</strong> 主页与下?/a><br /> <a ><strong>Jitsu</strong> 控gQ演CZCZ</a></p> <p><a ><img style="border-right-width: 0px; border-top-width: 0px; border-bottom-width: 0px; border-left-width: 0px" alt="" src="http://speckyboy.specky.netdna-cdn.com/wp-content/uploads/2010/05/webui_20.jpg" /></a></p> <p> </p> <h2 class="subtitle">Qutensil</h2> <p><a >Qutensil</a> 仍在开发中Q但其\U图已经昄出某些引人注目的东西Q基?<a >Prototype</a> ?<a >Scriptaculous</a> Q包含消息,调色板,滑动条,工具提示Q可拖放H口以及(qing)警告Q确认,提示{窗口?/p> <p><a ><strong>Qutensil</strong> 主页Q下?/a><br /> <a ><strong>Qutensil</strong> 控gQ演C,CZ</a></p> <p><a ><img style="border-right-width: 0px; border-top-width: 0px; border-bottom-width: 0px; border-left-width: 0px" alt="" src="http://speckyboy.specky.netdna-cdn.com/wp-content/uploads/2010/05/webui_22.jpg" /></a></p> <p> </p> <h2 class="subtitle">Script.aculo.us</h2> <p><a >script.aculo.us</a> 是一个备受欢q的 UI 工具集,Z <a >Prototype 框架</a>Q提供了(jin)诸如视觉效果QUI 控g以及(qing)面向 DOM 的工兗?/p> <p><a ><strong>Script.aculo.us</strong> 首页与下?/a></p> <p><a ><img style="border-right-width: 0px; border-top-width: 0px; border-bottom-width: 0px; border-left-width: 0px" alt="" src="http://speckyboy.specky.netdna-cdn.com/wp-content/uploads/2010/05/webui_24.jpg" /></a></p> <h2 class="subtitle">Alloy UI</h2> <p><a >AlloyUI</a> 是一套功能丰富的 UI 框架Q基?YUI 3Q部分基?YUI 2Q包含一套丰富的Q超q?0QUI 部gQ如囄库,对话框,?wi)Şl构Q面板,自动完成Q按钮,日历控gQ工h{?/p> <p><a ><strong>Alloy UI</strong> 首页和下?/a><br /> <a ><strong>Alloy UI</strong> 控gQ演CZCZ</a></p> <p><a ><img style="border-right-width: 0px; border-top-width: 0px; border-bottom-width: 0px; border-left-width: 0px" alt="" src="http://speckyboy.specky.netdna-cdn.com/wp-content/uploads/2010/05/webui_26.jpg" /></a></p> <p> </p> <h2 class="subtitle">iUI: iPhone UI 框架</h2> <p><a ><img style="border-right-width: 0px; border-top-width: 0px; border-bottom-width: 0px; border-left-width: 0px" alt="" src="http://speckyboy.specky.netdna-cdn.com/wp-content/uploads/2010/05/webui_27.jpg" /></a><a ></a></p> <p><a >IUI</a> 包含一?JavaScript 库,CSS 式样表及(qing)囄Q是一个轻量 iPhone UI 库,包含 iPhone 风格D菜单Q设备方向,iPhone 风格切换{功能,可以Z?Web E序带来 iPhone 般的体验?/p> <p><a ><strong>iUI</strong> 主页与下?/a></p> <h2 class="subtitle">XUI</h2> <p><a ><img style="border-right-width: 0px; border-top-width: 0px; border-bottom-width: 0px; border-left-width: 0px" alt="" src="http://speckyboy.specky.netdna-cdn.com/wp-content/uploads/2010/05/webui_29.jpg" /></a><a ></a></p> <p><a >XUI</a> 是一个用于移?Web 应用的轻量,极简Q高度模块化的框架。它之所以非常轻量的原因是,它只支持Ud览器,所有跨览器支持的代码都被剥离。它面向一U移?Web 览器,?WebkitQFennec 以及(qing) OperaQƈ有意来对移?IE 和黑莓提供支持?/p> <p><a ><strong>XUI</strong> 首页Q下?/a></p> <h2 class="subtitle">Yahoo! YUI Library</h2> <p><a ><img style="border-right-width: 0px; border-top-width: 0px; border-bottom-width: 0px; border-left-width: 0px" alt="" src="http://speckyboy.specky.netdna-cdn.com/wp-content/uploads/2010/05/webui_30.jpg" /></a></p> <p><a >Yahoo! YUI Library</a> 可谓所?Web UI 之父Q可靠,功能丰富Q目前已l发展到W?3 版。它拥有一个很庞大的开发团队,推出?jin)非怸富的功能Q就功能而言Q无可匹敌?/p> <p><a ><strong>YUI Library</strong> 主页与下?/a><br /> <a ><strong>YUI2 入门</strong></a><br /> <a ><strong>YUI3 入门</strong></a><br /> <a ><strong>YUI3</strong> 控gQ演CZCZ</a></p> <p>本文国际来源QSpecky Boy <a >15 Javascript Web UI Libraries, Frameworks and Toolkits</a></p><img src ="http://www.tkk7.com/kissyan4916/aggbug/321419.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.tkk7.com/kissyan4916/" target="_blank">金色闪电(sh)</a> 2010-05-19 22:52 <a href="http://www.tkk7.com/kissyan4916/articles/321419.html#Feedback" target="_blank" style="text-decoration:none;">发表评论</a></div>]]></description></item><item><title>Q{Q那些相见恨晚的 JavaScript 技?/title><link>http://www.tkk7.com/kissyan4916/articles/319330.html</link><dc:creator>金色闪电(sh)</dc:creator><author>金色闪电(sh)</author><pubDate>Sun, 25 Apr 2010 11:28:00 GMT</pubDate><guid>http://www.tkk7.com/kissyan4916/articles/319330.html</guid><description><![CDATA[<p>JavaScript 的成功让人|z乐道,?Web |页~写 JavaScript 代码已经是所?Web 设计师的基本功,q门有趣的语a蕴藏着许多不ؓ(f)人熟知的东西Q即使多q的 JavaScript E序员,也未能完全吃透。本文从7个方面讲q?JavaScript 中那些你不很熟知但非常实用的技巧?/p> <h2 class="subtitle">略语?/h2> <p><strong>JavaScript 可以使用略语句快速创建对象和数组Q比如下面的代码Q?/strong></p> <p><img alt="" src="http://www.comsharp.com/Writable/Resource/_Random_/2010-04-24/p1.gif" /></p> <p>可以使用略语句如下:(x)</p> <p><img alt="" src="http://www.comsharp.com/Writable/Resource/_Random_/2010-04-24/p2.gif" /></p> <p>对象 car 此创徏Q不q需要特别注意,l束花括号前一定不要加 ";" 否则?IE ?x)遇到很大麻烦(ch)?/p> <p><strong>创徏数组的传l方法是Q?/strong></p> <p><img alt="" src="http://www.comsharp.com/Writable/Resource/_Random_/2010-04-24/p3.gif" /></p> <p>使用略语句则Q?/p> <p><img alt="" src="http://www.comsharp.com/Writable/Resource/_Random_/2010-04-24/p4.gif" /></p> <p><strong>另一个可以用简略语句的地方是条件判断语句:(x)</strong></p> <p><strong><img alt="" src="http://www.comsharp.com/Writable/Resource/_Random_/2010-04-24/p5.gif" /><br /> </strong></p> <p>可以略ؓ(f)Q?/p> <p><img alt="" src="http://www.comsharp.com/Writable/Resource/_Random_/2010-04-24/p6.gif" /></p> <h2 class="subtitle">JSON 数据格式</h2> <p><a >JSON</a> ?"JavaScript Object Notation" 的羃写,?Douglas Crockford 设计QJSON 改变?JavaScript 在缓存复杂数据格式方面的困境Q如下例Q假如你要描qC个乐队,可以q样写:(x)</p> <p><img alt="" src="http://www.comsharp.com/Writable/Resource/_Random_/2010-04-24/p8.gif" /></p> <p>你可以在 JavaScript 中直接?JSONQ甚至作为某?API 的返回数据对象,以下代码调用著名书签|站 <a >delicious.com</a> 的一?APIQ返回你在该|站的所有书{,q显C在你自q|站Q?/p> <p><img alt="" src="http://www.comsharp.com/Writable/Resource/_Random_/2010-04-24/p9.gif" /></p> <h2 class="subtitle">JavaScript 本地函数 (Math, Array ?String)</h2> <p>JavaScript 有很多内|函敎ͼ有效的用,可以避免很多不必要的代码Q比如,从一个数l中扑և最大|传统的方法是Q?/p> <p><img alt="" src="http://www.comsharp.com/Writable/Resource/_Random_/2010-04-24/p10.gif" /></p> <p>使用内置函数可以更容易实玎ͼ(x)</p> <p><img alt="" src="http://www.comsharp.com/Writable/Resource/_Random_/2010-04-24/p11.gif" /></p> <p>另一个方法是使用 Math.max() Ҏ(gu)Q?/p> <p><img alt="" src="http://www.comsharp.com/Writable/Resource/_Random_/2010-04-24/p12.gif" /></p> <p>你可以用q个Ҏ(gu)帮助探测览?/p> <p><img alt="" src="http://www.comsharp.com/Writable/Resource/_Random_/2010-04-24/p13.gif" /></p> <p>q解决了(jin) IE 览器的一个问题,通过q种Ҏ(gu)Q你L可以扑ֈ那个正确的|因ؓ(f)览器不支持的那个g(x)q回 undefined?/p> <p>q可以?JavaScript 内置?split() ?join() 函数处理 HTML 对象?CSS cdQ如?HTML 对象的类名是I格隔开的多个名字,你在为它q加或删除一?CSS cd的时候需要特别注意,如果该对象还没有cd属性,可以直接新的类名赋予它Q如果已l存在类名,新增的类名前必须有一个空|用传l的 JavaScript Ҏ(gu)是这样实现的Q?/p> <p><img alt="" src="http://www.comsharp.com/Writable/Resource/_Random_/2010-04-24/p14.gif" /></p> <p>使用 split ?join Ҏ(gu)则直观优雅得多:(x)</p> <p><img alt="" src="http://www.comsharp.com/Writable/Resource/_Random_/2010-04-24/p15.gif" /></p> <h2 class="subtitle">事g代理</h2> <p>与其?HTML 文档中设计一堆事Ӟ不如直接设计一个事件代理,举例说明Q假如你有一些链接,用户点击后不x开链接Q而是执行某个事gQHTML 代码如下Q?/p> <p><img alt="" src="http://www.comsharp.com/Writable/Resource/_Random_/2010-04-24/p16.gif" /></p> <p>传统的事件处理是遍历各个链接Q加上各自的事g处理Q?/p> <p><img alt="" src="http://www.comsharp.com/Writable/Resource/_Random_/2010-04-24/p17.gif" /></p> <p>使用事g代理Q可以直接处理,无需遍历Q?/p> <p><img alt="" src="http://www.comsharp.com/Writable/Resource/_Random_/2010-04-24/p18.gif" /></p> <h2 class="subtitle">匿名函数?Module 模式</h2> <p>JavaScript 的一个问题是QQ何变量,函数或是对象Q除非是在某个函数内部定义,否则Q就是全局的,意味着同一|页的别的代码可以访问ƈ改写q个变量Q?a >ECMA ?JavaScript 5 已经改变?jin)这一状况</a> - 译者)(j)Q用匿名函敎ͼ你可以绕q这一问题?/p> <p>比如Q你有这样一D代码,很显?dng)变?name, age, status 成为全局变量</p> <p><img alt="" src="http://www.comsharp.com/Writable/Resource/_Random_/2010-04-24/p19.gif" /></p> <p>Z(jin)避免q一问题Q你可以使用匿名函数Q?/p> <p><img alt="" src="http://www.comsharp.com/Writable/Resource/_Random_/2010-04-24/p20.gif" /></p> <p>如果q个函数不会(x)被调用,可以更直接ؓ(f)Q?/p> <p><img alt="" src="http://www.comsharp.com/Writable/Resource/_Random_/2010-04-24/p21.gif" /></p> <p>如果要访问其中的对象或函敎ͼ可以Q?/p> <p><img alt="" src="http://www.comsharp.com/Writable/Resource/_Random_/2010-04-24/p22.gif" /></p> <p>q就是所?Module 模式或单例模式(SingletonQ,该模式ؓ(f) Douglas Crockford 所推崇Qƈ被大量应用在 <a >Yahoo User Interface Library YUI</a>?/p> <p>假如你想在别的地方调用里面的Ҏ(gu)Q又不想在调用前使用 myApplication q个对象名,可以在匿名函Cq回q些Ҏ(gu)Q甚至用U返回:(x)</p> <p><img alt="" src="http://www.comsharp.com/Writable/Resource/_Random_/2010-04-24/p23.gif" /></p> <h2 class="subtitle">代码配置</h2> <p>别h使用你编写的 JavaScript 代码的时候,隑օ?x)更?gu)些代码,但这?x)很困难Q因Z是每个h都很Ҏ(gu)L别h的代码,与其q样Q不如创Z个代码配|对象,别h只需要在q个对象中更Ҏ(gu)些配|即可实C码的更改。这里有一?<a >JavaScript 配置对象详解</a>的文章,单说Q?/p> <ul> <li>在代码中创徏一个叫?configuration 的对? <li>里面保存所有可以更改的配置Q如 CSS ID 和类名,按钮的标{文字,描述性文字,本地化语a讄 <li>该对象讄为全局对象Q以便别人直接访问ƈ改写 </li> </ul> <p>你应当在最后一步做q项工作Q这里有一个文章,<a >交付代码前的5件事</a>值的参考?/p> <h2 class="subtitle">同后C?/h2> <p>JavaScript 是一门前台语aQ你需要别的语a同后C互,q返回数据,使用 AJAXQ你可以?JavaScript 直接使用同后台的交互Q将复杂的数据处理交由后台处理?/p> <h2 class="subtitle">JavaScript 框架</h2> <p>自己~写适应各种览器的代码是完全浪Ҏ(gu)_(d)应当选择一?JavaScript 框架Q让q些复杂的事情交l框架处理?/p> <h2 class="subtitle">更多资源</h2> <ul> <li><a >Douglas Crockford on JavaScript</a><br /> JavaScript 深度视频教程 <li><a >The Opera Web Standards Curriculum</a><br /> JavaScript 详解 </li> </ul> <h2 class="subtitle">延阅读</h2> <ul> <li><a >有关 JavaScript ?10 件让解的事情</a> <li><a >?API L?JavaScript 操作本地文g</a> <li><a >?JavaScript 拯救 HTML5 的离U存?/a> <li><a >开源项目越来越青睐 JavaScript</a> <li><a >Javascript 是一个错误吗Q?/a> <li><a >Javascript 2 前途尘埃落?/a> <li><a >Google 排名中的 10 个最著名?JavaScript ?/a> <li><a >ECMA 推出 JavaScript 5</a> </li> </ul> <p>本文国际来源QSmashing Magazine <a >Seven JavaScript Things I Wish I Knew Much Earlier In My Career</a> Q原文作者:(x)<a title="Posts by Christian Heilmann" >Christian Heilmann</a>Q?/p><img src ="http://www.tkk7.com/kissyan4916/aggbug/319330.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.tkk7.com/kissyan4916/" target="_blank">金色闪电(sh)</a> 2010-04-25 19:28 <a href="http://www.tkk7.com/kissyan4916/articles/319330.html#Feedback" target="_blank" style="text-decoration:none;">发表评论</a></div>]]></description></item><item><title>Q{Q实用的 JavaScript 试?qing)效验工?/title><link>http://www.tkk7.com/kissyan4916/articles/319331.html</link><dc:creator>金色闪电(sh)</dc:creator><author>金色闪电(sh)</author><pubDate>Sun, 25 Apr 2010 11:28:00 GMT</pubDate><guid>http://www.tkk7.com/kissyan4916/articles/319331.html</guid><description><![CDATA[<p>JavaScript 是一Ƒּ大的q泛q用于现代Web站点?qing)应用的脚本语言。作Z个技艺精湛的 Web 开发者,掌握JavaScript可以增强用户的用体验,提供交互?qing)富客户端等功能?/p> <p>管JavaScript 的语法非常简单,但对于写E序而言仍然是困N重,是因ؓ(f)它的q行环境Q基于Web览器?/p> <p>以下(zhn)可以看到收集的8个实用的 JavaScript 试?qing)效验工P它们都可以在不同环境下进行单元测试及(qing)校验试(zhn)的脚本?/p> <p><a target="_blank">JSLint </a><br /> JSLint是基于Web的验证JavaScript错误代码的工兗它拥有的功能及(qing)特定的设|来使用(zhn)的需求,自定义你的验证算法?/p> <p><a target="_blank">JsUnit <br /> </a>JsUnit是一Ƒ֜客户?在浏览时)的单元测试JavaScript框架。对JavaScript而言QJUnit像是它的一个端口。当然它也可以在?个浏览器、多个机器的不同操作pȝ中自动运行。它的发展始?001q?月?/p> <p><a target="_blank">J3Unit <br /> </a>J3Unit是一个面向对象的JavaScript单元试框架。J3Unit在网|览器中直接运行JavaScript的测试,也可以自动运?JUnit ?Jetty。J3Unit是徏立在JUint和Script.aculo.us的基之上来更好地实现自动q行JavaScript 单元试。面向对象的JavaScript单元试是由Script.aculo.us的Test.Unit.Runner对象~写的,Z prototype JavaScript库?/p> <p><a target="_blank">Crosscheck </a><br /> Crosscheck是一Ƒּ源的校验览器中的JavaScript试框架。它可以帮助(zhn)在不同的浏览器中,诸如QInternet Explorer、Firefox{,而不需要一 一安装他们来确认?zhn)的代码是否正。?zhn)唯一需要的是必要有Java虚拟机环境?/p> <p><a target="_blank">YUI Test</a> <br /> YUI试是一Ƒ֟于浏览器Q提供解x案的试框架。用YUIQ?zhn)可以方便地添加单元测试,LJavaScript解决Ҏ(gu)。它是由 Yahoo! UI Library开发的一个JavaScriptMVC试插gQ能够让你模范大部分DOM动作Q比如写Q拖拽,比如模范AJAX响应Qƈ且能够用断a (assertions)。它能够象函C栯行,q且能够在不同的consoleH口q行集成试。虽然它不是在Q?xUnit 框架基础上开发而来Q但YUI Test仍然有很多nUnit ?JUnit的所h的特性。( While not a direct port from any specific xUnit framework, YUI Test does derive some characteristics from nUnit and JUnit. q段译得不好,但相信大致意思是对的Q?/p> <p><a >Regular Expression Tool</a> <br /> Regular Expression ToolQ正则表辑ּ工具Q是一Ƒ֜U工P用来试(zhn)的正则表达式代码是否正。当(zhn)想快速测试各U文本例子的正则表达式时非常得心(j)应手?/p> <p><a target="_blank">JSLitmus </a><br /> JSLitmus是款轻量U的工具Q用来测试JavaScript执行性能情况Q采用直观的API?/p> <p><a target="_blank">JavaScript Regular Expression Tester</a> <br /> q块便利的应用程序是在浏览器中用JavaScript来测试JavaScript正则表达式的。操作界面跟其他正则表达式测试工h异,不同?是,它测试的是JavaScript正则表达式在JavaScript中的性能情况?/p><img src ="http://www.tkk7.com/kissyan4916/aggbug/319331.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.tkk7.com/kissyan4916/" target="_blank">金色闪电(sh)</a> 2010-04-25 19:28 <a href="http://www.tkk7.com/kissyan4916/articles/319331.html#Feedback" target="_blank" style="text-decoration:none;">发表评论</a></div>]]></description></item><item><title>Q{QjQuery入门(11)Q语法ȝ和注意事?? http://www.tkk7.com/kissyan4916/articles/310677.html金色闪电(sh)金色闪电(sh)Sun, 24 Jan 2010 16:06:00 GMThttp://www.tkk7.com/kissyan4916/articles/310677.html阅读全文

金色闪电(sh) 2010-01-25 00:06 发表评论
]]>
Q{QjQuery入门(9)QAjax(调用面Ҏ(gu)和W(xu)ebService) http://www.tkk7.com/kissyan4916/articles/310675.html金色闪电(sh)金色闪电(sh)Sun, 24 Jan 2010 16:05:00 GMThttp://www.tkk7.com/kissyan4916/articles/310675.html调用面Ҏ(gu)?/span>webservice

注:(x)

web.config中要指定允许调用web服务?/span>

必须为Post方式来调用?/span>

WEB服务q回的ؓ(f)XMLԌ所以客L(fng)要{换ؓ(f)JSON再处理?/span>

        [WebMethod]

        public static string AjaxServiceTest(string str)

        {

            return string.Format("Hello,{0}", str);

        } 

    [System.Web.Script.Services.ScriptService]

    public class TestWebService : System.Web.Services.WebService

    {

        [WebMethod]

        public string HelloWorld(string s)

        {

            return "Hello World" + s ;

        }

    } 

        function WebServiceMethod() {

            $.ajax({

                type: "POST",

                contentType: "application/json;utf-8",

                url: "TestWebService.asmx/HelloWorld",

                data: "{s:""" + $("#inputName").val() + """}", //传webserviceҎ(gu)的参敎ͼs是方法的参数Q必M?nbsp;                                        

                success: function(data) {

                    //返回字W串转换为json对象

                    var json = null;

                    try {

                        json = eval('(' + data + ')');

                    } catch (e) {

                        alert("q回字符串不是json格式!");

                        return;

                    }

                    alert(json.d);

                }

            });

        }

        function PageAjaxServiceTest() {

            $.ajax({

                type: "POST",

                contentType: "application/json;utf-8",

                url: "PageService.aspx/AjaxServiceTest",

                data: "{str:""" + $("#inputName").val() + """}", //传到.cs?rn)态方法的参数Qstr是方法的参数Q必M?nbsp;                                   

                success: function(data) {

                    //返回字W串转换为json对象

                    var json = null;

                    try {

                        json = eval('(' + data + ')');

                    } catch (e) {

                        alert("q回字符串不是json格式!");

                        return;

                    }

                    alert(json.d);

                }

            });

        }

    </script>

    <div>

    <input id="inputName" type="text" value="" />

    <a href="#" onclick="WebServiceMethod();">调用web服务</a><br /><br />

    <a href="#" onclick="PageAjaxServiceTest();">调用面?rn)态方?/span></a><br /><br />

    </div> 

?/span>Q?/span>

        $.post("PagingService.asmx/GetLoginHtml", { s: "fda" },

         function(data) {

             $("#ajaxlogin").html(data);

             alert(data);

         }, "html");



金色闪电(sh) 2010-01-25 00:05 发表评论
]]>
Q{QjQuery入门(10)QAjax(利用WebService调用用户控g生成HTML) http://www.tkk7.com/kissyan4916/articles/310676.html金色闪电(sh)金色闪电(sh)Sun, 24 Jan 2010 16:05:00 GMThttp://www.tkk7.com/kissyan4916/articles/310676.html注:(x)q篇文章参考老n的"用户控g生成HTMLQ一文!

using System;

using System.Collections.Generic;

using System.Linq;

using System.Web;

using System.Web.UI;

using System.Web.Services;

using System.IO;

using WebFunction; 

namespace AstarMvc

{

    /// <summary>

    /// WsAjax 的摘要说?/span>

    /// </summary>

    [WebService(Namespace = "http://tempuri.org/")]

    [WebServiceBinding(ConformsTo = WsiProfiles.BasicProfile1_1)]

    [System.ComponentModel.ToolboxItem(false)]

    // 若要允许使用 ASP.NET AJAX 从脚本中调用?Web 服务Q请取消对下行的注释?/span>

    [System.Web.Script.Services.ScriptService]

    public class WsAjax : System.Web.Services.WebService

    {

        [WebMethod(EnableSession = true)]

        public string GetLoginHtml(string s)

        {

            ControlManager<WcUserLogin> viewManager = new ControlManager<WcUserLogin>();

            var control = viewManager.LoadViewControl("~/WcUserLogin.ascx");

           return viewManager.RenderView(control);

        }

 

        [WebMethod(EnableSession = true)]

        public string GetLoginCheck(string userName, string userPwd, string checkCode)

        {

            ControlManager<WcUserLogin> viewManager = new ControlManager<WcUserLogin>();

            var control = viewManager.LoadViewControl("~/WcUserLogin.ascx");

            control.UserName = userName;

            control.UserPwd = userPwd;

            control.CheckCode = checkCode;

            string msg = control.UserLogin() == "1" ? "LoginSucess" : "LoginError";

            //string jsonData = "{ucresult:""" + viewManager.RenderView(control) + """,msgresult:""" + msg + """}";

            return "<!--" + msg + "-->" + viewManager.RenderView(control);

       }

 

        [WebMethod(EnableSession = true)]

        public string ExitLogin(string a)

        {

            ControlManager<WcUserLogin> viewManager = new ControlManager<WcUserLogin>();

            var control = viewManager.LoadViewControl("~/WcUserLogin.ascx");

            control.ExitLogin();

            return viewManager.RenderView(control);

        }

 

        [WebMethod]

        public string GetPagingData(int page)

        {

            ControlManager<PagingData> viewManager = new ControlManager<PagingData>();

            var control = viewManager.LoadViewControl("~/PagingData.ascx");

            control.PageIndex = page;

            return viewManager.RenderView(control);

        }

    }

}



金色闪电(sh) 2010-01-25 00:05 发表评论
]]>
Q{QjQuery入门(8)Q工?http://www.tkk7.com/kissyan4916/articles/310674.html金色闪电(sh)金色闪电(sh)Sun, 24 Jan 2010 16:04:00 GMThttp://www.tkk7.com/kissyan4916/articles/310674.html工具

注:(x)jQuery都可替换?

览?/span>
jQuery.browser()
Q浏览器内核标识。依?navigator.userAgent 判断?/span>

可用? safari opera msie mozilla

?Microsoft's Internet Explorer 览器中q回 true?

代码:$.browser.msie

仅在 Safari 中提C?"this is safari!" ?

代码:

if ($.browser.safari) {

   alert("this is safari!");

}

 

jQuery.browser.version()Q浏览器渲染引擎版本?/span>

典型l果:

Internet Explorer: 6.0, 7.0

Mozilla/Firefox/Flock/Camino: 1.7.12, 1.8.1.3

Opera: 9.20

Safari/Webkit: 312.8, 418.9

 

if ( $.browser.msie )

 alert( $.browser.version );

 

jQuery.boxModel()Q当前页面中览器是否用标准盒模型渲染面

?Internet Explorer 怪癖模式QQuirksModeQ中q回 False?

代码:$.boxModel

 

数组和对象操?/span>
jQuery.each(obj,callback)
Q通用例遍Ҏ(gu)Q可用于例遍对象和数l?/span>

代码:例遍数组Q同时用元素烦(ch)引和内容?

$.each( [0,1,2], function(i, n){

 alert( "Item #" + i + ": " + n );

});

 

代码:例遍对象Q同时用成员名U和变量内容?

$.each( { name: "John", lang: "JS" }, function(i, n){

 alert( "Name: " + i + ", Value: " + n );

});

 

jQuery.extend(target,obj1,objN)Q?/span>用一个或多个其他对象来扩展一个对?/span>Q?/span>q回被扩展的对象

代码:合ƈ settings ?/span> optionsQ?/span>修改q返?/span> settings?/span>

var settings = { validate: false, limit: 5, name: "foo" };

var options = { validate: true, name: "bar" };

jQuery.extend(settings, options);

l果:settings == { validate: true, limit: 5, name: "bar" }

 

代码:合ƈ defaults ?/span> options, 不修?/span> defaults?/span>

var empty = {}

var defaults = { validate: false, limit: 5, name: "foo" };

var options = { validate: true, name: "bar" };

var settings = jQuery.extend(empty, defaults, options);

l果:

settings == { validate: true, limit: 5, name: "bar" }

empty == { validate: true, limit: 5, name: "bar" }

 

jQuery.grep(array,callback,invert)Q?/span>使用qo(h)函数qo(h)数组元素

代码:qo(h)数组中小?0 的元素?/span>

$.grep( [0,1,2], function(n,i){

 return n > 0;

});

l果:[1, 2]

 

代码:排除数组中大?0 的元素,使用W三个参数进行排除?/span>

$.grep( [0,1,2], function(n,i){

 return n > 0;

}, true);

l果:[0]

 

jQuery.makeArray(obj)Q将cLl对象{换ؓ(f)数组对象

<div>First</div><div>Second</div><div>Third</div><div>Fourth</div>

代码:qo(h)数组中小?0 的元素?/span>

var arr = jQuery.makeArray(document.getElementsByTagName("div"));

arr.reverse(); // 使用数组{函数

l果:

Fourth

Third

Second

First

 

jQuery.map(array,callback)Q?/span>一个数l中的元素{换到另一个数l中

代码:原数组中每个元素加 4 转换Z个新数组?/span>

$.map( [0,1,2], function(n){

 return n + 4;

});

l果:[4, 5, 6]

 

代码:原数l中大于 0 的元素加 1 Q否则删除?

$.map( [0,1,2], function(n){

 return n > 0 ? n + 1 : null;

});

l果:[2, 3]

 

代码:原数l中每个元素扩展Z个包含其本n和其值加 1 的数l,q{换ؓ(f)一个新数组?

$.map( [0,1,2], function(n){

 return [ n, n + 1 ];

});

l果:[0, 1, 1, 2, 2, 3]

 

jQuery.unique(array)Q?/span>删除数组中重复元?/span>

代码:删除重复 div 标签?/span>

$.unique(document.getElementsByTagName("div"));

l果:<div>, <div>, ...

 

试操作
jQuery.isFunction(obj)
Q测试对象是否ؓ(f)函数

代码:(g)是否ؓ(f)函数

    function stub() {}

     var objs = [

            function () {},

            { x:15, y:20 },

            null,

            stub,

            "function"

          ];

        jQuery.each(objs, function (i) {

        var isFunc = jQuery.isFunction(objs[i]);

        $("span:eq( " + i + ")").text(isFunc);

      }); 

l果: true,false,false,true,false 

 

字符串操?/span>
jQuery.trim(str)
Q?/span>L字符串v始和l尾的空?/span>

$.trim(" hello, how are you? "); l果:"hello, how are you?"



金色闪电(sh) 2010-01-25 00:04 发表评论
]]>
Q{QjQuery入门(7)Q效?http://www.tkk7.com/kissyan4916/articles/310673.html金色闪电(sh)金色闪电(sh)Sun, 24 Jan 2010 16:03:00 GMThttp://www.tkk7.com/kissyan4916/articles/310673.html效果 

基本
show()
Q显C隐藏的匚w元素

<p style="display: none">Hello</p>

代码:$("p").show()

 

show(speed,callback)Q显C所有匹配的元素Qƈ在显C完成后可选地触发一个回调函?/span>

<p style="display: none">Hello</p>

代码:$("p").show("slow");

代码://用迅速的动画隐藏的D落昄出来Q历?00毫秒?/span>

$("p").show("fast",function(){

   $(this).text("Animation Done!");

 });

代码://隐藏的D落用将q?U的旉昄出来

$("p").show(4000,function(){

   $(this).text("Animation Done...");

 });

 

hide()Q?/span>隐藏昄的元?/span>

$("p").hide()

 

hide(speed,callback)Q?/span>?/span>show(speed,callback)相反?/span>

 

toggle()Q?/span>切换元素的可见状态。如果元素是可见的,切换为隐藏的Q如果元素是隐藏的,切换为可见的

<p>Hello</p><p style="display: none">Hello Again</p>

代码:$("p").toggle()

l果:<p tyle="display: none">Hello</p><p style="display: block">Hello Again</p>

 

滑动
slideDown(speed,callback)
Q?/span>通过高度变化Q?/span>向下增大Q?/span>来动态地昄所有匹配的元素Q?/span>在显C完成后可选地触发一个回调函数?/span>

代码:?00毫秒~慢的将D落滑下

$("p").slideDown("slow");

代码:?00毫秒快速将D落滑下Q之后弹Z个对话框

$("p").slideDown("fast",function(){

   alert("Animation Done.");

 });

 

slideUp(speed,callback)Q通过不透明度的变化来实现所有匹配元素的淡出效果Qƈ在动d成后可选地触发一个回调函?/span>

代码:?00毫秒~慢的将D落滑上

$("p").slideUp("slow");

代码:?00毫秒快速将D落滑上Q之后弹Z个对话框

$("p").slideUp("fast",function(){

   alert("Animation Done.");

 });

 

slideToggle(speed,callback)Q通过高度变化来切换所有匹配元素的可见性,q在切换完成后可选地触发一个回调函?/span>

代码:$("p").slideToggle("slow");

代码:?00毫秒快速将D落滑上或滑下,之后弹出一个对话框

$("p").slideToggle("fast",function(){

   alert("Animation Done.");

 });

 

淡入淡出
fadeIn(speed,callback)
Q?/span>通过不透明度的变化来实现所有匹配元素的淡入效果Q?/span>q在动画完成后可选地触发一个回调函?/span>

代码:?00毫秒~慢的将D落淡入

$("p").fadeIn("slow");

代码:?00毫秒快速将D落淡入Q之后弹Z个对话框

$("p").fadeIn("fast",function(){

   alert("Animation Done.");

 });

 

fadeOut(speed,callback)Q通过不透明度的变化来实现所有匹配元素的淡出效果Qƈ在动d成后可选地触发一个回调函?/span>

代码:?00毫秒~慢的将D落淡出

$("p").fadeOut("slow");

代码:?00毫秒快速将D落淡出Q之后弹Z个对话框

$("p").fadeOut("fast",function(){

   alert("Animation Done.");

 });

 

fadetTo(speed,opacity,callback)Q把所有匹配元素的不透明度以渐进方式调整到指定的不透明度,q在动画完成后可选地触发一个回调函?/span>

代码:?00毫秒~慢的将D落的透明度调整到0.66Q大U?/3的可见度

$("p").fadeTo("slow", 0.66);$("p").fadeTo("slow", 0.66);

代码:?00毫秒快速将D落的透明度调整到0.25Q大U?/4的可见度Q之后弹Z个对话框

$("p").fadeTo("fast", 0.25, function(){

   alert("Animation Done.");

 });

 

自定?/span>
animate(params[,duration[,easing[,callback]]])

说明Q?/span>用于创徏自定义动ȝ函数

params (Options) : 一l包含作为动d性和l值的样式属性和?qing)其值的集合

duration (String,Number) : (可?/span>) 三种预定速度之一的字W串("slow", "normal", or "fast")或表C动L长的毫秒数?/span>(?/span>Q?000)

easing (String) : (可?/span>) 要用的擦除效果的名U?/span>(需要插件支?/span>).默认jQuery提供"linear" ?/span> "swing".

callback (Function) : (可?/span>) 在动d成时执行的函?/span>

 

<button id="go"> Run</button>

<div id="block">Hello!</div>

代码:// 在一个动M同时应用三种cd的效?/span>

$("#go").click(function(){

 $("#block").animate({

    width: "90%",

    height: "100%",

    fontSize: "10em",

    borderWidth: 10

 }, 1000 );

});

 

<button id="left">«</button> <button id="right">»</button>

<div class="block"></div>

代码:让指定元素左右移?/span>

$("#right").click(function(){

 $(".block").animate({left: '+50px'}, "slow");

});

$("#left").click(function(){

 $(".block").animate({left: '-50px'}, "slow");

});

 

代码:?00毫秒内切换段落的高度和透明?

$("p").animate({

   height: 'toggle', opacity: 'toggle'

 }, "slow");

 

代码:?00毫秒段落移到l(f)eft?0的地方ƈ且完全清晰显C出来(透明度ؓ(f)1Q?

$("p").animate({

   left: 50, opacity: 'show'

 }, 500);

 

代码:一个?/span>easein函数提供不同动画样式的例子。只有用了(jin)插g来提供这?/span>easein函数Q这个参数才起作用?

$("p").animate({

   opacity: 'show'

 }, "slow", "easein");

 

animate(params,options)

params (Options) : 一l包含作为动d性和l值的样式属性和?qing)其值的集合

options (Options) : 一l包含动画选项的值的集合?/span>

选项

duration (String,Number) : (默认?/span>: "normal") 三种预定速度之一的字W串("slow", "normal", or "fast")或表C动L长的毫秒数?/span>(?/span>Q?000)

easing (String) : (默认?/span>: "swing") 要用的擦除效果的名U?/span>(需要插件支?/span>).默认jQuery提供"linear" ?/span> "swing".

complete (Function) : 在动d成时执行的函?/span>

step (Callback) : Template:APICallback

queue (Boolean) : (默认?/span>: true) 讑֮?/span>false此动Mq入动画队列 (jQuery 1.2中新?/span>)

 

CZ

W一个按钮按?jin)之后展CZ(jin)不在队列中的动画。在div扩展?0%的同时也在增加字体,一旦字体改变完毕后Q边框的动画才开始?

W二个按钮按?jin)之后就是一个传l的铑ּ动画Q即{前一个动d成后Q后一个动L?x)开?

<button id="go1">» Animate Block1</button>

<button id="go2">» Animate Block2</button>

<div id="block1">Block1</div><div id="block2">Block2</div>

代码:

$("#go1").click(function(){

 $("#block1").animate( { width: "90%"}, { queue: false, duration: 5000 } )

     .animate( { fontSize: '10em' } , 1000 )

     .animate( { borderWidth: 5 }, 1000);

});

$("#go2").click(function(){

 $("#block2").animate( { width: "90%"}, 1000 )

     .animate( { fontSize: '10em' } , 1000 )

     .animate( { borderWidth: 5 }, 1000);

});

 

代码:?/span>600毫秒切换D落的高度和透明?/span>

$("p").animate({

   height: 'toggle', opacity: 'toggle'

 }, { duration: "slow" });

 

代码:?/span>500毫秒段落移?/span>left?/span>50的地方ƈ且完全清晰显C出?/span>Q?/span>透明度ؓ(f)1Q?

$("p").animate({

   left: 50, opacity: 'show'

 }, { duration: 500 });

 

代码:一个?/span>easein函数提供不同动画样式的例子。只有用了(jin)插g来提供这?/span>easein函数Q这个参数才起作用?

$("p").animate({

   opacity: 'show'

 }, { duration: "slow", easing: "easein" });

 

stop()Q?/span>停止所有在指定元素上正在运行的动画

<button id="go">Go</button> <button id="stop">STOP!</button>

<div class="block"></div>

<button id="go">Go</button> <button id="stop">STOP!</button>

<div class="block"></div>

代码:点击Go之后开始动?/span>,?/span>Stop之后?x)在当前位置停下?/span>

// Start animation

$("#go").click(function(){

 $(".block").animate({left: '+200px'}, 5000);

});

// Stop animation when button is clicked

$("#stop").click(function(){

 $(".block").stop();

});

 

queue()Q返回指向第一个匹配元素的队列(是一个函数数l?

 <style>

 div { margin:3px; width:40px; height:40px;

        position:absolute; left:0px; top:30px;

        background:green; display:none; }

 div.newcolor { background:blue; }

 span { color:red; }

 </style>

 <button id="show">Show Length of Queue</button><span></span><div></div>

代码:昄队列长度

$("#show").click(function () {

      var n = $("div").queue("fx");

      $("span").text("Queue length is: " + n.length);

});

function runIt() {

      $("div").show("slow");

      $("div").animate({left:'+=200'},2000);

      $("div").slideToggle(1000);

      $("div").slideToggle("fast");

      $("div").animate({left:'-=200'},1500);

      $("div").hide("slow");

      $("div").show(1200);

      $("div").slideUp("normal", runIt);

}

runIt();

 

queue(callback)Q在匚w的元素的动画队列中添加一个函?/span>

 

queue(queue)Q将匚w元素的动画队列用新的一个队列来代替(函数数组).

 

dequeue()Q从动画队列中移除一个队列函?/span>



金色闪电(sh) 2010-01-25 00:03 发表评论
]]>
Q{QjQuery入门(6)QAjax http://www.tkk7.com/kissyan4916/articles/310672.html金色闪电(sh)金色闪电(sh)Sun, 24 Jan 2010 16:02:00 GMThttp://www.tkk7.com/kissyan4916/articles/310672.htmlAjax

 

Ajaxh
jQuery.ajax(options)

说明Q通过 HTTP h加蝲q程数据?/span>

$.ajax()q回其创建的XMLHttpRequest对象。大多数情况下你无需直接操作该对象,但特D情况下可用于手动终止请求?/span>

注意Q?如果你指定了(jin)dataType选项Q请保服务器返回正的MIME信息Q?如xmlq回 "text/xml")。错误的 MIME cd可能D不可预知的错误?/span>

$.ajax()只有一个参敎ͼ(x)参数 key/value 对象Q包含各配置?qing)回调函C息?/span>

1.2 中可以跨域加载JSON数据Q用时需数据类型设|ؓ(f)JSONP。用JSON 形式调用函数Ӟ?"myurl?callback=?" jQuery 自动替?为正的函数名,以执行回调函数。数据类型设|ؓ(f) "jsonp" ӞjQuery 自动调用回调函数?/span>

 

选项

async(Boolean):(默认: true)所有请求均为异步请求。如要发送同步请求,讄为false。注意,同步h锁住浏览器Q用户其它操作必ȝ待请求完成才可以执行?/span>

beforeSend(Function):发送请求前可修改XMLHttpRequest对象的函敎ͼ如添加自定义 HTTP 头。XMLHttpRequest 对象是唯一的参数?/span>

cache(Boolean):(默认: true) 讄为fals 不?x)从览器缓存中加蝲h信息?/span>

complete(Function): h完成后回调函?h成功或失败时均调?。参敎ͼ(x) XMLHttpRequest 对象Q成功信息字W串?

contentType(String): (默认: "application/x-www-form-urlencoded") 发送信息至服务器时内容~码cd。默认值适合大多数应用场合?/span>

data(Object,String): 发送到服务器的数据。将自动转换求字W串格式。GET h中将附加?URL 后。查?processData 选项说明以禁止此自动转换。必Mؓ(f)Key/Value 格式。如果ؓ(f)数组QjQuery 自动ؓ(f)不同值对应同一个名U。如 {foo:["bar1", "bar2"]} 转换?'&foo=bar1&foo=bar2'?/span>

dataType(String) : 预期服务器返回的数据cd。如果不指定QjQuery 自动根?HTTP ?MIME 信息q回 responseXML ?responseTextQƈ作ؓ(f)回调函数参数传递,可用?

"xml": q回 XML 文档Q可?jQuery 处理?/span>

"html": q回U文?HTML 信息Q包?script 元素?

"script": q回U文?JavaScript 代码。不?x)自动缓存结果?/span>

"json": q回 JSON 数据 ?/span>

"jsonp": JSONP 格式。?JSONP 形式调用函数Ӟ?"myurl?callback=?" jQuery 自动替?? 为正的函数名,以执行回调函数?/span>

error(Function) : (默认:自动判断 (xml ?html)) hp|时调用时间。参敎ͼ(x)XMLHttpRequest 对象Q错误信息,Q可能)(j)捕获的错误对象?/span>

global (Boolean) : (默认: true) 是否触发全局 AJAX 事g。设|ؓ(f) false 不?x)触发全局 AJAX 事gQ如 ajaxStart ?ajaxStop 可用于控制不同的Ajax事g?/span>

ifModified (Boolean) : (默认: false) 仅在服务器数据改变时获取新数据。?HTTP ?Last-Modified 头信息判断?/span>

processData (Boolean) : (默认: true) 默认情况下,发送的数据被转换为对?技术上讲ƈ非字W串) 以配合默认内容类?"application/x-www-form-urlencoded"。如果要发?DOM ?wi)信息或其它不希望{换的信息Q请讄?false?/span>

success (Function) : h成功后回调函数。参敎ͼ(x)服务器返回数据,数据格式?/span>

timeout (Number) : 讄h时旉Q毫U)(j)。此讄覆盖全局讄?/span>

type (String) : (默认: "GET") h方式 ("POST" ?"GET")Q?默认?"GET"。注意:(x)其它 HTTP hҎ(gu)Q如 PUT ?DELETE 也可以用,但仅部分览器支持?/span>

url (String) : (默认: 当前地址) 发送请求的地址?/span>

 

加蝲q执行一?JS 文g?

$.ajax({

 type: "GET",

 url: "test.js",

 dataType: "script"

});

 

保存数据到服务器Q成功时昄信息?/span>

$.ajax({

   type: "POST",

   url: "some.php",

   data: "name=John&location=Boston",

   success: function(msg){

     alert( "Data Saved: " + msg );

   }

});

 

装入一?HTML |页最新版本?

$.ajax({

 url: "test.html",

 cache: false,

 success: function(html){

    $("#results").append(html);

 }

});

 

同步加蝲数据。发送请求时锁住览器。需要锁定用户交互操作时使用同步方式?

 var html = $.ajax({

 url: "some.php",

 async: false

 }).responseText;

 

发?XML 数据x务器。设|?processData 选项?falseQ防止自动{换数据格式?/span>

 var xmlDocument = [create xml document];

 $.ajax({

   url: "page.php",

   processData: false,

   data: xmlDocument,

   success: handleResponse

 });

 

load( url, [data], [callback] ) Q?/span>载入q程 HTML 文g代码q插入至 DOM 中,默认使用 GET 方式 - 传递附加参数时自动转换?POST 方式?/span>

url (String) : h的HTML늚URL地址?

data (Map) : (可选参? 发送至服务器的 key/value 数据。如果有[data]参数Q就?x)自动{换ؓ(f)POST方式?/span>

callback (Callback) : (可选参? h完成?不需要是success?的回调函数?

 

CZ代码Q?/span>

$(".ajax.load").load("http://www.cnblogs.com/QLeelulu/archive/2008/03/30/1130270.html",

         function (responseText, textStatus, XMLHttpRequest){

         this;//在这里this指向的是当前的DOM对象Q即$(".ajax.load")[0]

         //alert(responseText);//hq回的内?/span>

         //alert(textStatus);//h状态:(x)successQerror

         //alert(XMLHttpRequest);//XMLHttpRequest对象

});

注:(x)不知道ؓ(f)什么URL写绝对\径在FF下会(x)出错。下面的get()和post()CZ使用的是l对路径Q所以在FF下你会(x)出错q不?x)看到返回结果?/span>

 

<b>jQuery Links:</b><ul id="links"></ul>

代码:$("#links").load("/Main_Page #p-Getting-Started li");

 

代码:加蝲 feeds.html 文g内容?

$("#feeds").load("feeds.html");

 

代码:?POST 形式发送附加参数ƈ在成功时昄信息?/span>

 $("#feeds").load("feeds.php", {limit: 25}, function(){

   alert("The last 25 entries in the feed have been loaded");

 });

 

jQuery.get(url,[data],[callback])Q?/span>通过q程 HTTP GET h载入信息

CZ代码Q?/span>

$.get("./Ajax.aspx", {Action:"get",Name:"lulu"}, function (data, textStatus){

         //q回?data 可以?xmlDoc, jsonObj, html, text, {等.

         this; // 在这里this指向的是Ajaxh的选项配置信息

         alert(data);

         //alert(textStatus);//h状态:(x)successQerror{等。当然这里捕捉不到errorQ因为error的时候根本不?x)运行该回调函?/span>

         //alert(this);

});

 

h test.php |页Q忽略返回倹{?$.get("test.php");

$.get("test.php", { name: "John", time: "2pm" } );

 

昄 test.php q回?HTML ?XMLQ取决于q回??

$.get("test.php", function(data){

 alert("Data Loaded: " + data);

});

 

昄 test.cgi q回?HTML ?XMLQ取决于q回?Q添加一l请求参数?

$.get("test.cgi", { name: "John", time: "2pm" },

 function(data){

    alert("Data Loaded: " + data);

 });

 

jQuery.getJSON(url,data,callback)Q?/span>通过 HTTP GET h载入 JSON 数据

?Flickr JSONP API 载入 4 张最新的关于猫的囄?

<div id="images"></div>

代码:

$.getJSON("http://api.flickr.com/services/feeds/photos_public.gne?tags=cat&tagmode=any&format=json&jsoncallback=?",

function(data){

 $.each(data.items, function(i,item){

    $("<img/>").attr("src",

item.media.m).appendTo("#images");

    if ( i == 3 ) return false;

 });

});

 

?test.js 载入 JSON 数据q显C?JSON 数据中一?name 字段数据?

$.getJSON("test.js", function(json){

 alert("JSON Data: " + json.users[3].name);

});

 

?test.js 载入 JSON 数据Q附加参敎ͼ昄 JSON 数据中一?name 字段数据?

$.getJSON("test.js", { name: "John", time: "2pm" }, function(json){

 alert("JSON Data: " + json.users[3].name);

});

 

jQuery.getScript(url,callback)Q?/span>通过 HTTP GET h载入q执行一?JavaScript 文g?/span>

载入 jQuery 官方颜色动画插g 成功后绑定颜色变化动甅R?

<button id="go">» Run</button>

<div class="block"></div>

代码:

jQuery.getScript("http://dev.jquery.com/view/trunk/plugins/color/jquery.color.js",

function(){

 $("#go").click(function(){

    $(".block").animate( { backgroundColor: 'pink' }, 1000)

      .animate( { backgroundColor: 'blue' }, 1000);

 });

});

 

加蝲q执?test.js?$.getScript("test.js");

 

加蝲q执?test.js Q成功后昄信息?

$.getScript("test.js", function(){

 alert("Script loaded and executed.");

});

 

jQuery.post(url,data,callback,type)Q?/span>通过q程 HTTP POST h载入信息

url (String) : 发送请求的URL地址.

data (Map) : (可? 要发送给服务器的数据Q以 Key/value 的键值对形式表示?

callback (Function) : (可? 载入成功时回调函?只有当Response的返回状态是success才是调用该方??/span>

type (String) : (可?官方的说明是QType of data to be sent。其实应该ؓ(f)客户端请求的cd(JSON,XML,{等)

 

CZ代码Q?/span>

Ajax.aspxQ?/span>

Response.ContentType = "application/json";

Response.Write("{result: '" + Request["Name"] + ",你好Q?q消息来自服务器)'}");

 

代码Q?/span>

$.post("Ajax.aspx", { Action: "post", Name: "lulu" },

         function (data, textStatus){

              // data 可以?xmlDoc, jsonObj, html, text, {等.

              //this; // q个Ajaxh的选项配置信息Q请参考jQuery.get()说到的this

              alert(data.result);

         }, "json");

 

Ajax事g
ajaxComplete(callback)Q?/span>
AJAX h完成时执行函数?/span>

$("#msg").ajaxComplete(function(request, settings){

   $(this).append("<li>Request Complete.</li>");

 });

 

ajaxError(callback)Q?/span>AJAX h发生错误时执行函?/span>

 $("#msg").ajaxError(function(request, settings){

   $(this).append("<li>Error requesting page " + settings.url +

"</li>");

 });

 

ajaxSend(callback)Q?/span>AJAX h发送前执行函数

 $("#msg").ajaxSend(function(evt, request, settings){

   $(this).append("<li>Starting request at " + settings.url +

"</li>");

 });

 

ajaxStart(callback)Q?/span>AJAX h开始时执行函数

 $("#loading").ajaxStart(function(){

   $(this).show();

 });

 

ajaxStop(callback)Q?/span>AJAX hl束时执行函?/span>

 $("#loading").ajaxStop(function(){

   $(this).hide();

 });

 

ajaxSuccess(callback)Q?/span>AJAX h成功时执行函?/span>

 $("#msg").ajaxSuccess(function(evt, request, settings){

   $(this).append("<li>Successful Request!</li>");

 });

 

其它
jQuery.ajaxSetup(options)Q?/span>
讄全局 AJAX 默认选项

$.ajaxSetup({

 url: "/xmlhttp/",

 global: false,

 type: "POST"

});

$.ajax({ data: myData });

 

serialize()Q?/span>序列表表格内容ؓ(f)字符丌Ӏ?/span>

$("#results").append( "<tt>" + $("form").serialize() + "</tt>" );

 

serializeArray()Q?/span>序列化表格元?(cM '.serialize()' Ҏ(gu)) q回 JSON 数据l构数据

var fields = $("select, :radio").serializeArray();

jQuery.each( fields, function(i, field){

 $("#results").append(field.value + " ");

});



金色闪电(sh) 2010-01-25 00:02 发表评论
]]>
Q{QjQuery入门(5)Q事?http://www.tkk7.com/kissyan4916/articles/310671.html金色闪电(sh)金色闪电(sh)Sun, 24 Jan 2010 16:01:00 GMThttp://www.tkk7.com/kissyan4916/articles/310671.html事g

面载入
ready(fn)Q?/span>
当DOM载入qA可以查询?qing)操U|l定一个要执行的函数?/span>

$(document).ready(function(){

 // Your code here...

});

或者直接:(x)当然jQuery可以?

jQuery(function() {

 // Your code using failsafe $ alias here...

});

 

事g处理
bind(type,data,fn)
Q?/span>为每一个匹配元素的特定事gQ?/span>?/span>clickQ?/span>l定一个事件处理器函数

当每个段落被点击的时候,弹出其文本?/span>

$("p").bind("click", function(){

 alert( $(this).text() );

});

可以在事件处理之前传递一些附加的数据?

function handler(event) {

 alert(event.data.foo);

}

$("p").bind("click", {foo: "bar"}, handler)

通过q回false来取消默认的行ؓ(f)q止事件v泡?/span>

$("form").bind("submit", function() { return false; })

通过使用 preventDefault() Ҏ(gu)只取消默认的行ؓ(f)?

$("form").bind("submit", function(event){

 event.preventDefault();

});

通过使用 stopPropagation() Ҏ(gu)只阻止一个事件v泡?/span>

$("form").bind("submit", function(event){

 event.stopPropagation();

});

 

one(type,data,fn)Q?/span>为每一个匹配元素的特定事gQ像clickQ绑定一个一ơ性的事g处理函数

当所有段落被W一ơ点ȝ时候,昄所有其文本?

$("p").one("click", function(){

 alert( $(this).text() );

});

 

trigger(type,data)Q?/span>在每一个匹配的元素上触发某cM?/span>

提交W一个表?

$("form:first").trigger("submit")

l一个事件传递参?

$("p").click( function (event, a, b) {

 // 一个普通的点击事gӞa和b是undefinedcd

 // 如果用下面的语句触发Q那么a指向"foo",而b指向"bar"

} ).trigger("click", ["foo", "bar"]);

下面的代码可以显CZ?Hello World"

$("p").bind("myEvent", function (event, message1, message2) {

 alert(message1 + ' ' + message2);

});

$("p").trigger("myEvent", ["Hello","World!"]);

 

triggerHandler(type,data)Q?/span>q个特别的方法将?x)触发指定的事gcd上所有绑定的处理函数。但不会(x)执行览器默认动?/span>

例:(x)如果你对一个focus事g执行?.triggerHandler()Q浏览器默认动作不?x)被触发Q只?x)触发你l定的动作?/span>

<button id="old">.trigger("focus")</button>

<button id="new">.triggerHandler("focus")</button><br/><br/>

<input type="text" value="To Be Focused"/>

代码:

$("#old").click(function(){

 $("input").trigger("focus");

});

$("#new").click(function(){

 $("input").triggerHandler("focus");

});

$("input").focus(function(){   $("<span>Focused!</span>").appendTo("body").fadeOut(1000); });

 

unbind(type,data)Q?/span>bind()的反向操作,从每一个匹配的元素中删除绑定的事g

把所有段落的所有事件取消绑?/span>

$("p").unbind()

段落的click事g取消l定

$("p").unbind( "click" )

删除特定函数的绑定,函C为第二个参数传入

var foo = function () {

 // code to handle some kind of event

};

$("p").bind("click", foo);

$("p").unbind("click", foo);

 

交互处理
hover(over,out)Q?/span>
一个模仿?zhn)停事件的?gu)Q修正了(jin)使用mouseout事g的一个常见错误)(j)?/span>

over (Function) : 鼠标Ud元素上要触发的函?/span>

out (Function) : 鼠标Ud元素要触发的函数

鼠标(zhn)停的表格加上特定的c?

$("td").hover(

 function () {

    $(this).addClass("hover");

 },

 function () {

    $(this).removeClass("hover");

 }

);

 

toggle(fn,fn)Q?/span>每次点击时切换要调用的函?/span>

fn (Function) : W奇数次点击时要执行的函数?/span>

fn (Function) : W偶数次点击时要执行的函数?/span>

对表格的切换一个类

$("td").toggle(

 function () {

    $(this).addClass("selected");

 },

 function () {

    $(this).removeClass("selected");

 }

);

 

ALL事g
blur()/blur(fn)

说明Q触发每一个匹配元素的blur事g/或者绑定一个事件处理函?/span>

使用Q?("p").blur(); /$("p").blur( function () { alert("Hello World!"); } );

 

change()/change(fn)

click()/click(fn)

dblclick()/dblclick(fn)

error()/error(fn)

focus()/focus(fn)

keydown()/keydown(fn)

keypress()/keypress(fn)

keyup()/keyup(fn)

 

load(fn)

mousedown(fn)

mousemove(fn)

mouserout(name)/blur(fn)

 

mouseover(fn)

mouseup(fn)

rasize(fn) 当文档窗口改变大时触发

$(document).resize(function(){

 alert("Stop it!");

});

 

scroll(fn) 当滚动条发生变化时触?/span>

$(document).scroll( function() { /* ...do something... */ } );

 

select()/select(fn)

 

submit()/submit(fn)

$("form").submit( function () {

 return false;

} );

 

upload(fn)

面卸蝲的时候弹Z个警告框: $(document).unload( function () { alert("Bye now!"); } );



金色闪电(sh) 2010-01-25 00:01 发表评论
]]>
Q{QjQuery入门(4)QCSS相关API http://www.tkk7.com/kissyan4916/articles/310670.html金色闪电(sh)金色闪电(sh)Sun, 24 Jan 2010 16:00:00 GMThttp://www.tkk7.com/kissyan4916/articles/310670.htmlCSS

 q篇单,查看以前的文档时发现q有background,color{APIQ但是在1.2以后的版本中已经找不到这些了(jin)。还是直接用css()?...

CSS
css(name)Q?/span>
讉KW一个匹配元素的样式属?/span>

例:(x)$("p").css("color");

 

css(properties)Q?/span>把一?/span>?值对对象讄为所有匹配元素的样式属性?/span>

?/span>Q?("p").css({ color: "#ff0011", background: "blue" });

如果属性名包含 "-"的话Q?/span>必须使用引号: $("p").css({ "margin-left": "10px", "background-color": "blue" });

 

css(name,value)Q?/span>在所有匹配的元素?/span>Q?/span>讄一个样式属性的?/span>Q?/span>数字自动{化ؓ(f)像素倹{?/span>

?/span>Q?("p").css("color","red");

 

位置
offset()Q?/span>
获取匚w元素在当前视口的相对偏移Q返回的对象包含两个整Ş属性:(x)top ?left。此Ҏ(gu)只对可见元素有效

<p>Hello</p><p>2nd Paragraph</p>

代码:

var p = $("p:last");

var offset = p.offset();

p.html( "left: " + offset.left + ", top: " + offset.top );

l果:<p>Hello</p><p>left: 0, top: 35</p>

 

宽高
height()
Q?/span>取得W一个匹配元素当前计的高度?/span>QpxQ?/span>。可以用来获?/span>window ?/span> document 的高

代码:$("p").height();

代码:$(document).height(); //获取文档的高

 

height(val)Q?/span>为每个匹配的元素讄CSS高度(hidth)属性的倹{如果没有明指定单位(如:(x)em?Q,使用px

代码:$("p").height(20);

 

width()Q?/span>取得W一个匹配元素当前计的宽度|pxQ。可以用来获取window ?document 的高

width(val)Q?/span>为每个匹配的元素讄CSS宽度(width)属性的倹{?/span>



金色闪电(sh) 2010-01-25 00:00 发表评论
]]>
Q{QjQuery入门(3)QDOMQ选择器,属性,{选,文档处理Q?http://www.tkk7.com/kissyan4916/articles/310669.html金色闪电(sh)金色闪电(sh)Sun, 24 Jan 2010 15:59:00 GMThttp://www.tkk7.com/kissyan4916/articles/310669.html阅读全文

金色闪电(sh) 2010-01-24 23:59 发表评论
]]>
Q{QjQuery入门(2)Q核?j)(核?j)函数,对象讉KQ多库共存)(j) http://www.tkk7.com/kissyan4916/articles/310668.html金色闪电(sh)金色闪电(sh)Sun, 24 Jan 2010 15:58:00 GMThttp://www.tkk7.com/kissyan4916/articles/310668.html核心(j)Q核?j)函?对象讉KQ多库共存)(j)

注:(x)其中jQuery()可替换ؓ(f)快捷方式$()Q如?被其它对象占用,可?span style="color: red">jQuery.noConflict()函数取消快捷方式?/span>

核心(j)函数

$(expr,[context])/jQuery(expression,[context])
该函数可以通过css选择器,Xpath或html代码来匹配目标元素,所有的jQuery操作都以此ؓ(f)基础
expression (String)用来查找的字W串,context(Element, jQuery)(可?作ؓ(f)待查扄DOM元素集、文档或 jQuery 对象?br /> 例子
<p>one</p>
<div><p>two</p></div>
<
p>three</p>
 
<a href="#" id="test" onClick="jq()">jQuery</a>
jQuery代码?qing)功能?x)

function jq(){  
    alert($("div>p").html());  
}

当点击id为test的元素时Q弹出对话框文字为twoQ即div标签下p元素的内?

function jq(){
    $("<div><p>Hello</p></div>").appendTo("body");
}

当点击id为test的元素时Q向body中添?/span><div><p>Hello</p></div>

 

context

在文档的W一个表单中Q查找所有的单选按?? type gؓ(f) radio ?input 元素)?$("input:radio", document.forms[0]);

在一个由 AJAX q回?XML 文档中,查找所有的 div 元素?("div", xml.responseXML);


$(elem)

限制jQuery作用于一个特定的dom元素Q这个函C接受xml文档和windows对象
 elemQ通过jQuery对象压羃的DOM元素
例子
<p>one</p>

<div><p>two</p></div>

<p>three</p>
<a href="#" id="test" onClick="jq()">jQuery</a>

jQuery代码?qing)功能?x)

function jq(){
    alert($(document).find("div>p").html());
}

当点击id为test的元素时Q弹出对话框文字为twoQ即div标签下p元素的内?

function jq(){
   $(document.body).background("black");
}

q行Q当点击id为test的元素时Q背景色变成黑色


$(elems)
限制jQuery作用于一l特定的DOM元素
 elemQ一l通过jQuery对象压羃的DOM元素
例子
<form
 id="form1">
<input type="text" name="textfield">
<input type="submit" name="Submit" value="提交">
</form>
<a href="#" id="test" onClick="jq()">jQuery</a>

jQuery代码?qing)功能?x)

function jq(){ 
   $(form1.elements).hide(); 
}

当点击id为test的元素时Q隐藏form1表单中的所有元素?/span>


$(fn)/jQuery(callback)
$(document).ready()的简写,当文档全部蝲入时执行函数。可以有多个$(fn)当文档蝲入时Q同时执行所有函敎ͼ
fn(Function):当文档蝲入时执行的函敎ͼ
例子

$(function() {

    alert($(document.body).html());

});

当文档蝲入时背景变成黑色Q相当于onLoad?/span>


$(obj)
复制一个jQuery对象
obj (jQuery): 要复制的jQuery对象
例子
<p>one</p>
<div><p>two</p></div>
<p>three</p>
<a
 href="#" id="test" onClick="jq()">jQuery</a>

jQuery代码?qing)功能?x)

function jq(){
    var f = $("div"); 
    alert($(f).find("p").html()) 
}

当点击id为test的元素时Q弹出对话框文字为twoQ即div标签下p元素的内宏V?/span>

$("<input>").attr("type", "checkbox");// 在IE中无?微Y规定 <input>元素的type只能写一?/span>

$("<input type='checkbox'>");// 在IE中有?

 

对象讉K


each(callback)
以每一个匹配的元素作ؓ(f)上下文来执行一个函数。每ơ执行传递进来的函数Ӟ函数中的this关键字都指向一个不同的DOM元素Q每ơ都是一个不同的匚w元素Q。在每次执行函数Ӟ都会(x)l函C递一个表CZ为执行环境的元素在匹配的元素集合中所处位|的数字g为参敎ͼ从零开始的整ŞQ。返?'false' 停止@?像在普通的循环中?break')。返?'true' 跌下一个@?像在普通的循环中?continue')?/span>

对于每个匚w的元素所要执行的函数

例子

<img/><img/>

jQuery代码

$("img").each(function(i){

   this.src = "test" + i + ".jpg";

 });

l果:<img src="test0.jpg" /><img src="test1.jpg" /> 

 

可以使用 $(this) 函数得到 jQuery对象?

jQuery 代码:

$("img").each(function(){

 $(this).toggleClass("example");

});

 

可以使用 'return' 来提前蟩?each() 循环?

<button>Change colors</button>

<span></span><div></div><div></div><div></div> <div></div><div id="stop">Stop here</div><div></div><div></div><div></div>

jQuery代码

$("button").click(function () {

     $("div").each(function (index, domEle) {

      // domEle == this

      $(domEle).css("backgroundColor", "yellow"); 

      if ($(this).is("#stop")) {

          $("span").text("Stopped at div index #" + index);

          return false;

      }

     });

});


eq(pos)
减少匚w对象C个单独得dom元素
pos (Number): 期望限制的烦(ch)引,?开?br /> 例子
<p>This
 is just a test.</p>
<p>So is this</p>
<a href="#" id="test" onClick="jq()">jQuery</a>

jQuery代码?qing)功能?x)

function jq(){
    alert($("p").eq(1).html())
}

当点击id为test的元素时Qalert对话框显C:(x)So is thisQ即W二?lt;p>标签的内?/span>


get()/get(num)
获取匚w元素Qget(num)q回匚w元素中的某一个元?br /> get(Number): 期望限制的烦(ch)引,?开?br /> 例子
<p>This
 is just a test.</p>
<p>So is this</p>
<a href="#" id="test" onClick="jq()">jQuery</a>

jQuery代码?qing)功能?x)

function jq(){
    alert($("p").get(1).innerHTML);
}

当点击id为test的元素时Qalert对话框显C:(x)So is thisQ即W二?lt;p>标签的内?/span>

注意get和eq的区别,eqq回的是jQuery对象Qgetq回的是所匚w的dom对象Q所有取$("p").eq(1)对象的内容用jQueryҎ(gu)html()Q而取$("p").get(1)的内容用innerHTML


index(obj)
q回对象索引,如果扑ֈ?jin)匹配的元素Q从0开始返回;如果没有扑ֈ匚w的元素,q回-1?br /> obj(Object)要查扄对象
例子
<div
 id="test1"></div>
<div id="test2"></div>
<a href="#" id="test" onClick="jq()">jQuery</a>

jQuery代码?qing)功能?x)

function jq(){
    alert($("div").index(document.getElementById('test1')));
    alert($("div").index(document.getElementById('test2')));
}

当点击id为test的元素时Q两ơ弹出alert对话框分别显C?Q?


size()/Length
jQuery对象中元素的个数,与jQuery对象?length' 属性一致?/span>

例子
<img
 src="test1.jpg"/>
<img src="test2.jpg"/>
<a href="#" id="test" onClick="jq()">jQuery</a>

jQuery代码?qing)功能?x)

function jq(){
    alert($("img").length);
}

当点击id为test的元素时Q弹出alert对话框显C?Q表C找C个匹配对?/span> 

 

多库共存

 

jQuery.noConflict()

q行q个函数变?的控制权让渡l第一个实现它的那个库?/span>

q有助于保jQuery不会(x)与其他库?对象发生冲突。在q行q个函数后,只能用jQuery变量讉KjQuery对象。例如,在要用到$("div p")的地方,必L成jQuery("div p")?

CZ

jQuery.noConflict();

jQuery("div p").hide();// 使用 jQuery

$("content").style.display = 'none'; // 使用其他库的 $()

 

恢复使用别名$Q然后创建ƈ执行一个函敎ͼ在这个函数的作用域中仍然?作ؓ(f)jQuery的别名来使用。在q个函数中,原来?对象是无效的。这个函数对于大多数不依赖于其他库的插g都十分有效?

jQuery.noConflict();

(function($) {

 $(function() {

    //使用 $ 作ؓ(f) jQuery 别名的代?/span>

 });

})(jQuery);

// 其他?$ 作ؓ(f)别名的库的代?

 

创徏一个新的别名用以在接下来的库中使用jQuery对象?

var j = jQuery.noConflict();

j("div p").hide();// Z jQuery 的代?/span>

$("content").style.display = 'none'; // Z其他库的 $() 代码


jQuery.noConflict(extreme)

?和jQuery的控制权都交q给原来的库。用之前误(g)虑清楚!

q是相对于简单的 noConflict Ҏ(gu)更极端的版本Q因完全重新定义jQuery。这通常用于一U极端的情况Q比如你惌jQuery嵌入一个高度冲H的环境。注?调用此方法后极有可能D插g失效?/span>

extreme (Boolean):传入true来允许彻底将jQuery变量q原

 

完全jQueryUd一个新的命名空间?

var dom = {};

dom.query = jQuery.noConflict(true);

l果:

dom.query("div p").hide();// ?jQuery 的代?/span>

$("content").style.display = 'none';// 另一个库 $() 的代?/span>

jQuery("div > p").hide(); // 另一个版?jQuery 的代?/span>



金色闪电(sh) 2010-01-24 23:58 发表评论
]]>
Q{QjQuery入门(1)Q介l?http://www.tkk7.com/kissyan4916/articles/310667.html金色闪电(sh)金色闪电(sh)Sun, 24 Jan 2010 15:56:00 GMThttp://www.tkk7.com/kissyan4916/articles/310667.html学习(fn)完ASP.NET AJAX客户端编E后Q感觉自己应该再学会(x)使用另外一个轻量AJAX框架。上ơ安装上ASP.NET MVC BETA后发现自动引入了(jin)jquery。也听说?jin)MS和jquery的全部,q有VS08也提供了(jin)补丁jquery的智能提C?/p>

从网上找?jin)些资料和?sh)子书。这个系列是我看qjQuery1.2API中文文档后的W记。希望对大家有帮助~

 

jQuery

jQuery库ؓ(f)共同?/span>web脚本提供?jin)一U通用的抽象层Qƈ且它几乎?/span>44U脚本环境都是有用的。它以插件的形式持箋地通过开发加入新的功能。这核心(j)的特性,满以下的需?/span>:

获取面的部分内容,不?/span>JavaScript库,必须写很多行代码来遍?/span>DOM?wi),q定位一?/span>HTML文档的指定部分?/span>jQuery提供?jin)一个强大而有效的选择机制来返回被(g)查或者被操作的文档?/span>

 

修改面的外观,CSS提供?jin)一个Ş响文档渲染的张大Ҏ(gu)Q当web览器不支持同样的标准时Q它却是不尽人意的?/span>jQuery能I补这个差距,提供?jin)跨所有浏览器的同L(fng)标准的支持。另外,即ə面被渲染后Q?/span>jQUery仍可改变文档一部分中的cL者独立的样式属性?/span>

 

修改面的内容,不仅限外观的改变Q?/span>jQueryq可以用很少的按键就可修Ҏ(gu)档的内容本n。文本可改变Q图像可插入或替换,列表可重新排序或者整?/span>HTMLl构可被重写和扩展?/span>

在页面中响应用户的交互,当它们发生时Q如果我们不能控Ӟ即ɭ周密蛟强大的行ؓ(f)也是没有用的.jQUery库提供了(jin)一个优雅的Ҏ(gu)来截取多U事Ӟ例如用户单击链接Q我

们不需要将事g句柄h?/span>HTML代码中。同Ӟ事g句柄API删除览器不一致性,往往?x)?/span>web开发者感到很?ch)恼?/span>

 

l页面加上动画,Z(jin)有效地执行交互行为,设计师必L供可视的反馈l用PjQuery库提供了(jin)一l效果来推进它,效果如揭Ԍ空来,也可定制一套新?/span>T兗?/span>

 

无刷新返回服务器端的信息Q这个代码模式己l以^synchronous JavaScript and XML(AJAX)著称?jin)?/span>;仁协?/span>web开发者制作可响应的功能丰富的|站?/span>

 

化共同的JavaScriptdQ除?/span>jQuery指定的文档的所有特性外Q这个库q提供了(jin)改进基本?/span>JavaScriptl构Q如U代和数l操作?/span>

 

下蝲Q?/span>http://www.cnblogs.com/lyj/archive/2008/11/08/1329713.html

 

?/span>VS08中添加智能提C:(x)http://www.cnblogs.com/lyj/archive/2008/11/08/1329713.html

 

引入Q?/span><script type="text/javascript" src="js/jquery-1.2.6.js"></script> 或用 <ScriptManager>引入



金色闪电(sh) 2010-01-24 23:56 发表评论
]]>
վ֩ģ壺 ˳Ƶ߲Ų| ҹ޾ƷƬ | ߾þ֮ۺ߾þ| Ƶ| 911Ʒձ| ëƬһAPP| AVרƬ߹ۿ| 3344߿Ƭ| þþƷ| 㶮ַѹ| ޹Ʒþþѿ| 13СϴƵվ| պŷAVҹҹ | ɫAVպ߹ۿ| Ů߾Ʒѹۿ| ŷavۺɫ| Ʒѹۿһ| ݺady޾Ʒ| ?V˾Ʒպ| ޾ƷƵѹۿ| ߹ۿavÿո| ˵Ӱѹۿ| ձ߹ۿ| 鶹Ƶѹۿ| ɫվwwwͬ | ɫͼɫС˵| ĻѾƷƵ| ޳AƬ߲| պһƵ| רר| ۺϾƷվ| һëƬ޶| 񼶵Ӱ| Ƶ| ֱӽѿƵվ| þӰԺһ| ˳Ƶ߹ۿվ| һëƬ߹ۿ| 98Ƶ| 51ҹƷƵ| ޹˾Ʒԭ|