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