前些日子买了本《征服AJAX-WEB2.0技术详解》开始学习AJAX技术和JAVASCRIPT脚本语言.在书中介绍javascript面向对象章节中接触了一点点prototye1.3.1.js,但由于书上介绍得较浅,又加上小弟刚住那地方没有连到网,一直没有去网上下这个javascript包,然后公司让开发的系统又用到了ajax技术,所以就上网囫囵吞枣的去网上细翻了些资料,看到prototype1.5已经出来了(嘻嘻,可能很多大哥大姐都发现了),也顺便学学1.5的东西.对自己学js提供一个便捷.废话不要太多.今天就聊聊它的一些概念和比较.
1. Prototype是什么?
prototype.js 是一个由Sam Stephenson写的JavaScript包。这个构思奇妙编写良好的一段兼容标准的一段代码将承担创造胖客户端, 高交互性WEB应用程序的重担。轻松加入Web 2.0特性.
2. 通用性方法
这个程序包里面包含了许多预定义的对象和通用性方法。编写这些方法的明显的目的就是为了减少你大量的重复编码和惯用法。
从Prototype1.5.x版本开始,你可以更方便的如下面代码一样操作DOM对象了:
程序代码
var ele = $("element");
ele.hide(); //隐藏DOM对象对比从前的版本var ele = $("element");
Element.hide(ele); //隐藏DOM对象
这样的改变有啥好处呢? 我觉得首先是更面向对象了,其次就是便于将来部分IDE里的代码提示
2.1. 使用 $()方法
$() 方法是在DOM中使用过于频繁的 document.getElementById() 方法的一个便利的简写,就像DOM方法一样,这个方法返回参数传入的id的那个元素。
比起DOM中的方法,这个更好一些.我们可以传入多个id作为参数然后 $() 返回一个带有所有要求的元素的一个 Array 对象。下面的例子来描述这些.(导入的是1.3)
程序代码
js 代码
- <script src=< span="">"prototype-1.3.1.js"></script>
-
- <script>
- function try1()
- {
- var d = $('myDiv');
- alert(d.innerHTML);
- }
-
- function try2()
- {
- var divs = $('myDiv','myOtherDiv');
- for(i=0; i<divs.length; i++) < span="">
- {
- alert(divs[i].innerHTML);
- }
- }
- </script>
这个方法的另一个好处就是你可以传入id字符串或者元素对象自己,这使得在创建可以传入任何形式参数的方法的时候, 它变得非常有用。
2.2. 使用$F()方法
$F()方法是另一个非常受欢迎的简写。它可以返回任何输入表单控件的值,如文本框或下拉框。 这个方法可以传入元素的id或者元素自己。
程序代码
js 代码
- <script>
- function try3()
- {
- alert( $F('Name') );
- }
- </script>
2.3. 使用Try.these()方法
Try.these() 方法使得实现当你想调用不同的方法直到其中的一个成功正常的这种需求变得非常容易, 他把一系列的方法作为参数并且按顺序的一个一个的执行这些方法直到其中的一个成功执行,返回成功执行的那个方法的返回值。
在下面的例子中, xmlNode.text在一些浏览器中好用,但是xmlNode.textContent在另一些浏览器中正常工作。 使用Try.these()方法我们可以得到正常工作的那个方法的返回值。
程序代码
js 代码
- <script language=< span="">"javascript">
- function getXmlNodeValue(xmlNode){
- return Try.these(
- function() {return xmlNode.text;},
- function() {return xmlNode.textContent;)
- );
- }
- </script>
3. Ajax 对象
上面提到的共通方法非常好,但是面对它吧,它们不是最高级的那类东西。它们是吗?你很可能自己编写了这些甚至在你的脚本里面有类似功能的方法。但是这些方法只是冰山一角。
我很肯定你对prototype.js感兴趣的原因很可能是由于它的AJAX能力。所以让我们解释当你需要完成AJAX逻辑的时候,这个包如何让它更容易。
Ajax 对象是一个预定义对象,由这个包创建,为了封装和简化编写AJAX 功能涉及的狡猾的代码。 这个对象包含一系列的封装AJAX逻辑的类。我们来看看它们的一些。
3.1. 使用 Ajax.Request类
如果你不使用任何的帮助程序包,你很可能编写了整个大量的代码来创建XMLHttpRequest对象并且异步的跟踪它的进程, 然后解析出响应 然后处理它。当你不需要支持多于一种类型的浏览器时你会感到非常的幸运。
为了支持 AJAX 功能。这个包定义了 Ajax.Request 类。
假如你有一个应用程序可以通过url http://yoursever/app/get_sales?empID=1234&year=1998与服务器通信。它返回下面这样的XML 响应。
程序代码
xml 代码
- xml version="1.0" encoding="utf-8" ?>
- <ajax-response>
- <response type="object" id="productDetails">
- <monthly-sales>
- <employee-sales>
- <employee-id>1234<!---->employee-id>
- <year-month>1998-01<!---->year-month>
- <sales>$8,115.36<!---->sales>
- <!---->employee-sales>
- <!---->response>
- <!---->ajax-response>
用 Ajax.Request对象和服务器通信并且得到这段XML是非常简单的。下面的例子演示了它是如何完成的。
程序代码
js 代码
- <script language=< span="">"javasript">
- function searchSales()
- {
- var empID = $F('lstEmployees');
- var y = $F('lstYears');
- var url = 'http:
- var pars = 'empID=' + empID + '&year=' + y;
- var myAjax = new Ajax.Request(
- url,
- {method: 'get', parameters: pars, onComplete: showResponse}
- );
-
- }
-
- function showResponse(originalRequest)
- {
- $('result').value = originalRequest.responseText;
- }
- </script>
你看到传入 Ajax.Request构造方法的第二个对象了吗? 参数{method: 'get', parameters: pars, onComplete: showResponse} 表示一个匿名对象的真实写法。他表示你传入的这个对象有一个名为 method 值为 'get'的属性,另一个属性名为 parameters 包含HTTP请求的查询字符串,和一个onComplete 属性/方法包含函数 showResponse。
还有一些其它的属性可以在这个对象里面定义和设置,如 asynchronous,可以为true 或 false 来决定AJAX对服务器的调用是否是异步的(默认值是 true)。
这个参数定义AJAX调用的选项。在我们的例子中,在第一个参数通过HTTP GET命令请求那个url,传入了变量 pars包含的查询字符串, Ajax.Request 对象在它完成接收响应的时候将调用showResponse 方法。
也 许你知道, XMLHttpRequest在HTTP请求期间将报告进度情况。这个进度被描述为四个不同阶段:Loading, Loaded, Interactive, 或 Complete。你可以使 Ajax.Request 对象在任何阶段调用自定义方法 ,Complete 是最常用 的一个。想调用自定义的方法只需要简单的在请求的选项参数中的名为 onXXXXX 属性/方法中提供自定义的方法对象。 就像我们例子中的 onComplete 。你传入的方法将会被用一个参数调用,这个参数是 XMLHttpRequest 对象自己。你将会用这个对象去得到返回的数据 并且或许检查包含有在这次调用中的HTTP结果代码的 status 属性。
还有另外两个有用的选项用来处理结果。我们可以在 onSuccess 选项处传入一个方法,当AJAX无误的执行完后调用, 相反的,也可以在onFailure选项处传入一个方法,当服务器端出现错误 时调用。正如onXXXXX 选项传入的方法一样,这两个在被调用的时候也传入一个带有AJAX请求的XMLHttpRequest对象。
我们的例子没有用任何有趣的方式处理这个 XML响应, 我们只是把这段XML放进了一个文本域里面。对这个响应的一个典型的应用很可能就是找到其中的想要的信息,然后更新页面中的某些元素, 或者甚至可能做某些XSLT转换而在页面中产生一些HTML。
3.2. 使用 Ajax.Updater 类
如果你的服务器的另一端返回的信息已经是HTML了,那么使用这个程序包中 Ajax.Updater 类将使你的生活变得更加得容易。用它你只需提供哪一个元素需要被AJAX请求返回的HTML填充就可以了,例子比我写说明的更清楚。
程序代码
js 代码
- <script language="javascript“>
- function getHTML()
- {
- var url = 'http:
- var pars = 'someParameter=ABC';
-
- var myAjax = new Ajax.Updater('placeholder', url, {method: 'get', parameters: pars});
-
- }
- </script>
你可以看到,这段代码比前面的例子更加简洁,不包括 onComplete 方法,但是在构造方法中传入了一个元素id。 我们来稍稍修改一下代码来描述如何在客户端处理服务器段错误成为可能。
我们将加入更多的选项, 指定处理错误的一个方法。这个是用 onFailure 选项来完成的。
我 们也指定了一个 placeholder 只有在成功请求之后才会被填充。为了完成这个目的我们修改了第一个参数从一个简单的元素id到一个带有两个属性 的对象, success (一切OK的时候被用到) 和 failure (有地方出问题的时候被用到) 在下面的例子中没有用到failure属性, 而仅仅在 onFailure 处使用了 reportError 方法。
程序代码
js 代码
- <script language="javascript">
- function getHTML()
- {
- var url = 'http:
- var pars = 'someParameter=ABC';
- var myAjax = new Ajax.Updater(
- {success: 'placeholder'},
- url,
- {method: 'get', parameters: pars, onFailure: reportError});
-
- }
-
- function reportError(request)
- {
- alert('Sorry. There was an error.');
- }
- </script>
相对应的HTML代码自己加上
分享到:
相关推荐
以上就是关于`prototype.js`文件的基本介绍和使用方法。通过这个库,你可以更高效地进行JavaScript编程,实现丰富的Web交互功能。记得结合`prototype.js`开发手册,深入学习并熟练掌握其各种用法,提升你的...
通过学习和使用prototype.js,开发者可以编写出结构更清晰、可维护性更强的JavaScript代码,同时也能提高开发效率,减少跨浏览器兼容性的烦恼。然而,随着ES6及后续版本的推出,许多prototype.js的功能已被原生...
**Prototype.js 1.6 知识点详解** Prototype.js 是一个开源的JavaScript库,它扩展了JavaScript语言,为开发者提供..."prototypeAPI"这个文件可能包含了Prototype.js的API参考文档,是学习和查阅该库功能的重要资源。
下载并使用"prototype.js"文件,即可开始体验这些强大的功能。不过要注意,随着现代前端框架的兴起,像React、Vue、Angular等,Prototype.js的使用逐渐减少,但它的设计理念和模式仍然值得学习和借鉴。
Prototype.js 是一个广泛使用的 JavaScript 库,它为浏览器环境提供了许多实用的功能,尤其是在对象操作和事件处理方面。1.6 版本是该库的一个重要里程碑,引入了许多改进和优化,使得开发人员能够更加高效地编写 ...
通过引入这个文件,开发者可以立即使用Prototype提供的各种功能。 二、Prototype中的核心概念 1. Object.extend:这是Prototype中最基本的扩展方法,用于将一个对象的属性复制到另一个对象上,实现对象的继承。...
此外,压缩包还包含了不同版本的jQuery库文件,如`jquery-1.4.js`、`jquery-1.4.min.js`,供开发者在项目中使用。 学习和掌握Prototype与jQuery,能够提升JavaScript开发效率,更好地构建交互式的Web应用。这些源码...
文件名"WebSite14"可能代表一个完整的网站项目,包含HTML、CSS、JavaScript文件以及可能的图片和其他资源。通过检查这个项目的源代码,我们可以更深入地了解如何在VS2005中具体实现模态弹出窗口。 总结来说,"在VS...
本话题主要聚焦于三个JavaScript文件:moo.fx、moo.fx.pack和prototype.lite,它们是用于构建轻量级网页特效的工具,尤其适用于那些对性能有高要求且希望避免大型框架的项目。 首先,moo.fx是一个轻量级的...
学习Prototype.js,可以参考其官方文档(如提供的CHM文件),以及社区中的教程和示例代码。Stack Overflow、GitHub和网上论坛都有很多关于Prototype.js的问题解答和讨论,是提升技能的好去处。 总结,Prototype.js...
在压缩包中提供的`prototype.js开发手册.rar`文件,应该是Prototype.js的官方或社区编写的开发指南,它会详细介绍如何使用这个库的各个功能,包括基本用法、高级特性和最佳实践。通过阅读这份手册,开发者可以更深入...
Prototype.js 是一个广泛使用的JavaScript库,它为JavaScript编程提供了丰富的功能和便利,旨在简化和优化在浏览器环境中进行的脚本编写。1.6.0.3 版本是该库的一个稳定版本,它包含了对先前版本的改进和修复,以...
《Prototype开发者手册(中文版)》是一本专为JavaScript开发者准备的重要参考资料,它详细介绍了Prototype JavaScript框架的使用方法和核心概念。Prototype是一个广泛使用的开源JavaScript库,它的目标是简化...
Prototype.js的CHM手册包含了库的API参考、示例和教程,是开发者理解和使用Prototype.js的重要资源。 8. **多语言支持**:提供中英文两种语言的文档,意味着不同语言背景的开发者都能找到适合自己的学习资料,有助...
`prototype.js`是Prototype的核心库文件,它是JavaScript源代码文件,包含了Prototype的所有功能。当你在网页中引入这个脚本,就可以利用Prototype提供的API来编写更简洁、高效的JavaScript代码。Prototype的核心...
百度的Ajax.js文件 常用JS prototype.js的系列文章——$R()函数 prototype.js的系列文章——Ajax.Request类 prototype.js的系列文章——Ajax.Updater类 prototype.js的系列文章——Try.these())函数
Prototype.js 是一个广泛使用的 JavaScript 库,它为浏览器环境提供了许多实用的功能,极大地简化了 JavaScript 的开发。这个库的核心理念是扩展JavaScript的基本对象和类型,使其更加面向对象,同时提供了丰富的DOM...
4. prototype.js:Prototype是一个广泛使用的JavaScript库,它扩展了JavaScript的基本对象,为开发Web应用程序提供了便利。Prototype的核心特性包括DOM操作、Ajax支持以及强大的对象操作功能。其中,JSON支持是...
“prototype-1.6.0.3.js”则是该版本的源码文件,可以直接在项目中使用。而“prototype_js 1_4版开发者手册 - Lyn-事繁勿慌,事闲勿荒,取象于取,外圆内方 - 博客园.mht”和“compdoc2cn prototype_js开发笔记.mht...