|
本帖最后由 m199312 于 2016-12-19 22:39 编辑
本次发布的算是本人为易语言JSON事业贡献的第三个大版本。
上个版本:http://bbs.eyuyan.com/read.php?tid=387876
官方论坛:http://bbs.eyuyan.com/read.php?tid=397739
本此版本三大特点:《优雅》、《面向对象》、《高效》、《稳定》。
(生成Json有着媲美甚至超越JScript的体验)
如果要生成一段这样的JSON文本:
{
"开发商信息":
{
"公司名": "异编软件",
"网址": "http://www.ybrj.net"
},
"鸣谢":
[
{
"公司名": "云外归鸟工作室",
"网址": "http://www.ywgn.net"
},
{
"公司名": "易语言软件开发有限公司",
"网址": "http://www.eyuyan.com"
}
]
} |
var json={};
json.开发商信息={};
json.开发商信息.公司名="异编软件";
json.开发商信息.网址="http://www.ybrj.net";
json.鸣谢=[];
json.鸣谢[0]={};
josn.鸣谢[0].公司名="云外归鸟工作室";
josn.鸣谢[0].网址="http://www.ywgn.net";
json.鸣谢[1]={};
josn.鸣谢[1].公司名="易语言软件开发有限公司";
josn.鸣谢[1].网址="http://www.eyuyan.com";
json.置项目值("","{}")
json.插入项目("","开发商信息")
json.置项目值("开发商信息","{}")
json.插入项目("开发商信息","公司名")
json.置项目值("开发商信息.公司名","异编软件")
json.插入项目("开发商信息","网址")
json.置项目值("开发商信息.网址","http://www.ybrj.net")
json.插入项目("","鸣谢")
json.置项目值("鸣谢","[]")
json.插入项目("鸣谢","0")
json.置项目值("鸣谢[0]","{}")
json.插入项目("鸣谢[0]","公司名")
json.置项目值("鸣谢[0].公司名","云外归鸟工作室")
json.插入项目("鸣谢[0]","网址")
json.置项目值("鸣谢[0].网址","http://www.ywgn.net")
json.插入项目("鸣谢","1")
json.置项目值("鸣谢[1]","{}")
json.插入项目("鸣谢[1","公司名")
json.置项目值("鸣谢[1].公司名","易语言软件开发有限公司")
json.插入项目("鸣谢[1]","网址")
json.置项目值("鸣谢[1].网址","http://www.eyuyan.com")
|
json.K("开发商信息").K("公司名").置文本("异编软件")
json.K("开发商信息").K("网址").置文本("http://www.ybrj.net")
json.K("鸣谢").I(0).K("公司名").置文本("云外归鸟工作室")
json.K("鸣谢").I(0).K("网址").置文本("http://www.ywgn.net")
json.K("鸣谢").I(1).K("公司名").置文本("易语言软件开发有限公司")
json.K("鸣谢").I(1).K("网址").置文本("http://www.eyuyan.com") |
类中两大关键方法,均返回Json类型对象。
Json.I() '以数组下标方式获得成员,返回一个Json类型的对象(即返回一个和调用类型一样的对象)。
Json.K() '以键名方式获得成员,返回一个Json类型的对象 意味着一句代码可以无限层次进入子对象中,比如这样的json中:
{data:[ obj:{ code: 8 , data:[ msg:{ error :-8 ,errorData:{ text: 'Incorrect password' , date:1451577600}} ] } ]}
只需如下代码便可获得错误原因
错误原因=Json.K("data").I(0).K("data").K("msg").K("errorData").K("text").取文本()
当然新的版本还保留了传统的表达式方式取得对象,虽然已不推荐使用(表达式方式没有IDE提示,而且需要自己检查语法错误等缺点),具体用法如下:
错误原因=Json.X("data[0].data.msg.errorData.text").取文本() |
弃用上一版的自研发内核(虽然上一版容错能力惊人,但执行效率较低,短期内没有精力改进)转采用Win32API中的JScript引擎辅以内联汇编实现了类似于Java的对象引用机制,即 Json.I() / Json.K() / Json.X() 所返回的对象实际上和调用对象其实是绑定的同一个Jscript对象,因此相比上个版本可大幅提高解析和查找速度。
依托于对象引用机制,无论对哪个子对象进行改变,都能稳定同步更新,而且本版集成了JSONP跨域格式的解析功能,再也不用为这样的数据格式伤脑筋了“_callback1451577600({code:-10086,msg:'密码错误!'})”。
复制变量不可以使用如下方式直接复制(因对象引用机制有着引用数计次,直接复制会导致计次异常而提前释放内存继而引发程序崩溃)。
错误的方法演示:
Json2=Json1
正确做法:
Json2=Json1.复制()
---------------关于多线程-----------------
模块默认为多线程方式初始化的COM库,值得注意的是精易模块中有很多命令都会卸载多线程初始化(比如正则、网页访问等都会调用卸载CoUninitialize()),他们会造成程序崩溃,如果要兼容精易模块请不要调用本方法(多线程初始化COM() ),并在每个线程首次使用Json类的方法前加上 单线程初始化COM()。 注:这样初始化的变量不支持多线程共享,只能被最先使用的线程使用。
|
评分
-
查看全部评分
|