[ASP.NET AJAX]类似.NET框架的JavaScript扩展

简介:
+关注继续查看

最近AJAX风靡全世界,在CommunityServer中他运用了自己定义的封装了js,并且可以跨浏览器,在较小的应用程序中,他比较适合,而且使用也比较简单。但是对微软的Microsoft AJAX还是一点不了解的我,从今天开始也要进入学习,一步一步的去了解,慢慢的深入。在博客园里也看了一些文章,但是他们大都是说AJAXExtendControl的,我想从脚本入手来学习一下Microsoft Ajax,顺便也对脚本进行复习一遍,岂不是一举两得。从原文件中我们可以看到Microsoft Asp.net Ajax是一个很强大,而且很适合C#开发人员扩展的脚本库。在Microsoft Asp.net Ajax脚本库中添加了一个Type及System来对JavaScript对象的扩展。其中扩展并形成类似.NET中常见的命名空间(namespaces),抽象类(inheritance)(注:我是这么认为的,不知道有没有更好的说法),接口(interfaces),枚举(enumerations),以及对象反射(reflection),同时也对(字符串)strings,(数组)arrays进行了扩展。这让我们这些.NET的开发人员,特别是C#开发人员更好,更有效的对脚本的扩展。

  要达到将普通的JavaScript封装成类似.NET的框架,Type可谓是功不可没阿,通过Type中的一些方法可以将我们的脚本注册到一个类,将一个类注册到一个命名空间中等等。下面我们将会对前面几个对应的类似.NET框架的Microsoft Ajax脚本库进行逐个的介绍。

  1.Namespaces

  是一个逻辑分类(个人虚构,如有雷同纯属巧合),及时将很多个类(classes)进行分类,通过Type.registerNamesapce方法可以将一个class(一下称为"类",虽然它不象话,但总的给个说法吧!)注册到一个namespace(以下成为"命名空间")中。

  2.Classes

  引用Type,所有的类都继承自JavaScript的object(在.NET中所有的类也是继承自Object),通过Type.registerClass将一个对象注册到类中。由于应用一个面向对象的模型,在Microsoft AJAX 脚本库中也能够实现继承基类的对象实例。一个类可以包含四个成员:fields, properties, methods, and events。
  
  fields:可以通过应用当前类的实例对象来引用如myClass.name="MyName";

  properties:通过带有get和set标记的方法对其进行付值,在Asp.net Ajax中通过"get_"和"set_"与方法名称结合来给他付值,如果要对一个叫myname的属性付值,可以通过get_myname和set_myname方法来完成此项任务。

  methods:方法也就是函数,这里对不多说了。

  events:事件主要涉及到一些行为动作,当一个事件被挂起(激活)时,将调用一个或多个从handlers继承的方法来处理这个事件。
  
  3. Inheritances

  众所周知虚函数是要被重写的,大多数面向对象的编程语言都支持类的继承和重写,但是JavaScript是不支持这项功能的。但是在Asp.net Ajax中通过特殊的方式(以"_"为起始标记的方法将被视为私有方法,将不能在外部类中执行此方法)实现了这种重写的功能,将会更好的对脚本库进行扩展。

  4.Inheritances

  每一个类都可以继承自另一个基类,当一个类继承基类时此类将加载基类中的方法,属性,事件等,同时可以重写基类中的方法,事件等或直接调用基类中方法等,Asp.Net Ajax中也实现了这项功能。

  5.Interfaces

  接口知识一种约定,并没有实现方法,同样在Asp.Net Ajax中也有接口,其实就是定义一个空函数。

  6.Enumerations

  通过Type.registerEnum方法可以注册一个枚举,它主要是更直观的表达一个对象。

  7.Reflection

  使用反射可以知道类中的信息,对Type进行扩展,提供APIs对类进行分析,从而得到类中的信息。

  今天先对JavaScript Microsoft Ajax Library(我比较喜欢叫他Microsoft Ajax脚本库)有一个总体上的认识,第一碰这个东西可能很多理解都是歪理,如果人总是从不懂到懂,逐渐深入也总是需要一个过程。就像当年我对Class怎么也不理解(因为我是在没有人指导的情况下,自己研究起来的,生物工程就是我的专业-中国十大骗人专业之一,由于没有注意现在毕业证还寄在学校呢?),希望我对Ajax也能一步一步的弄懂它,如果有不对的地方还请批评指教。


本文转自网魂小兵博客园博客,原文链接:http://www.cnblogs.com/xdotnet/archive/2006/12/22/aspnet_ajax_javascript_extend.html,如需转载请自行联系原作者

相关文章
|
2月前
|
前端开发 JavaScript Java
SSM框架用Ajax增删改查一个页面(简单易懂)
SSM框架用Ajax增删改查一个页面(简单易懂)
|
5月前
|
JSON 前端开发 Java
【Java框架型项目从入门到装逼】第六节 - 用ajax请求后台数据
【Java框架型项目从入门到装逼】第六节 - 用ajax请求后台数据
|
9月前
|
JSON JavaScript 前端开发
Spring MVC框架:第十一章:Ajax
Spring MVC框架:第十一章:Ajax
84 0
Spring MVC框架:第十一章:Ajax
|
11月前
|
XML JSON 监控
Flask框架:运用Ajax轮询动态绘图
Ajax是异步JavaScript和XML可用于前后端交互,在之前`《Flask 框架:运用Ajax实现数据交互》`简单实现了前后端交互,本章将通过`Ajax`轮询获取后端的数据,前台使用`echart`绘图库进行图形的生成与展示,后台通过`render_template`方法返回一串JSON数据集,前台收到后将其应用到绘图库上,实现动态监控内存利用率的这个功能。
231 0
Flask框架:运用Ajax轮询动态绘图
|
XML 存储 JSON
学习AJAX必知必会(1)~Ajax介绍、xml介绍、express框架
学习AJAX必知必会(1)~Ajax介绍、xml介绍、express框架
118 0
|
数据采集 JSON 前端开发
13、web爬虫讲解2—Scrapy框架爬虫—Scrapy爬取百度新闻,爬取Ajax动态生成的信息
crapy爬取百度新闻,爬取Ajax动态生成的信息,抓取百度新闻首页的新闻rul地址 有多网站,当你浏览器访问时看到的信息,在html源文件里却找不到,由得信息还是滚动条滚动到对应的位置后才...
2209 0
|
JSON JavaScript 前端开发
jQuery系列 第八章 jQuery框架Ajax模块
第八章 jQuery框架Ajax模块 8.1 jQuery框架中的Ajax简介 Ajax技术的核心是XMLHTTPRequest对象,该对象是Ajax实现的关键,发送异步请求、接收服务器端的响应以及执行回调等操作都是通过XMLHTTPRequest对象来完成的。
1276 0
相关产品
云迁移中心
推荐文章
更多