Google 的JS托管库是怎么做到的?

JavaScript030

Google 的JS托管库是怎么做到的?,第1张

jQuery在google api上创建了自己的代码库,所以你可以从该代码库引用js文件。

google并不是你用多少就发给你多少,而是使用了gzip压缩,也就是说该文件在google上使用gzip算法进行了压缩,这样传输起来就很小了,到了浏览器端,浏览器识别到gzip压缩标记就会解压缩这个文件然后运行。

至于从缓存中得到也是一个服务器端的设计,在你请求代码的时候会发送请求的代码文件名和相关参数,如本地文件版本,最后修改时间等,如果这个信息和服务器端的信息匹配,那么服务器端就会返回304(表示该文件没有变化,可以继续使用本地缓存中的版本)

1、首先你得会js,然后使用iframe装载原网页,再调用其中js2、js简单,写在网页里,用winform加载网页,nodejs比较复杂,首先你要让用户在windows上安装nodejs(我没试过),然后再调用nodejs环境,nodejs是linux下用来做服务器的,和windows程序不搭边。

一、JavaScriptSerializer 类由异步通信层内部使用,用于序列化和反序列化在浏览器和 Web 服务器之间传递的数据。您无法访问序列化程序的此实例。但是,此类公开了公共 API。因此,当您希望在托管代码中使用 JavaScript 对象符号 (JSON) 时可以使用此类。

若要序列化对象,请使用 Serialize 方法。若要反序列化 JSON 字符串,请使用 Deserialize 或 DeserializeObject 方法。若要序列化和反序列化 JavaScriptSerializer 本身不支持的类型,请使用 JavaScriptConverter 类来实现自定义转换器。然后,使用 RegisterConverters 方法注册转换器。

托管类型和 JSON 之间的映射

下表显示序列化进程中托管类型和 JSON 之间的映射。JavaScriptSerializer 本身支持这些托管类型。将 JSON 字符串反序列化为托管类型时,采用相同的映射。但是,反序列化可能是非对称的,并非所有可序列化的托管类型都可以从 JSON 反序列化得到。

二、通过JavaScriptSerializer来实现。它的名字空间为:System.Web.Script.Serialization

如果要使用它,还须添加

System.Web.Extensions库文件引用

参考实体类:Customer

public class Customer

{

public int Unid { getset}

public string CustomerName { getset}

}

类JavaScriptSerializer描述:为启用 AFAX 的应用程序提供序列化和反序列化功能。

(一) 序列化

方法:public string Serialize(Object obj),用于将对象转换为 JSON 字符串

public string ScriptSerialize(Customer customer)

{

JavaScriptSerializer js = new JavaScriptSerializer()

return js.Serialize(customer)

}

测试:

Customer cc = new Customer { Unid = 1, CustomerName = "John" }

string strJson = ScriptSerialize(cc)

Console.WriteLine(strJson)

(二)反序列化

public Customer ScriptDeserialize(string strJson)

{

JavaScriptSerializer js = new JavaScriptSerializer()

return js.Deserialize<Customer>(strJson)

}

通过Deserialize<T>方法来实现。

测试:

Customer c1 = ScriptDeserialize(strJson)

Console.WriteLine(c1.Unid + " " + c1.Custome