LOGO OA教程 ERP教程 模切知识交流 PMS教程 CRM教程 开发文档 其他文档  
 
网站管理员

【ASP】JSON object class 3.8.1 读写类

admin
2024年12月12日 17:17 本文热度 3441

MIT license: http://opensource.org/licenses/mit-license.php
The MIT License (MIT)
Copyright (c) 2016 RCDMK - rcdmk[at]hotmail[dot]com

Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:

The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.

THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.


How to use:

This lib requires LCID (Locale Code IDentifier) property of your ASP application before use. You can do this by setting the LCID in one of the following ways:

  • On the page declaration at the top of the page to set it to the entire page (eg.: <%@ LCID=1046 %>), OR

  • On the Session object to set it to all pages in the entire session (eg.: Session.LCID = 1046), OR

  • On the Response object, before using the class, to set it beyond this point on the page (eg.: Response.LCID = 1046)

Response.LCID = 1046 ' REQUIRED! Set your LCID here (1046 = Brazilian). Could also be the LCID property of the page declaration or the Session.LCID property


' instantiate the class

set JSON = New JSONobject


' add properties

JSON.Add "prop1", "someString"

JSON.Add "prop2", 12.3

JSON.Add "prop3", Array(1, 2, "three")


' remove properties

JSON.Remove "prop2"

JSON.Remove "thisDoesNotExistsAndWillDoNothing"


' change some values

JSON.Change "prop1", "someOtherString"

JSON.Change "prop4", "thisWillBeCreated" ' this property doen't exists and will be created automagically


' get the values

Response.Write JSON.Value("prop1") & "<br>"

Response.Write JSON.Value("prop2") & "<br>"

Response.Write JSON("prop3").Serialize() & "<br>" ' default function is equivalent to `.Value(propName)` - this property returns a JSONarray object

Response.Write JSON("prop4") & "<br>"


' get the JSON formatted output

Dim jsonString

jsonString = JSON.Serialize() ' this will contain the string representation of the JSON object


JSON.Write() ' this will write the output to the Response - equivalent to: Response.Write JSON.Serialize()


' load and parse some JSON formatted string

jsonString = "[{ ""strings"" : ""valorTexto"", ""numbers"": 123.456, ""arrays"": [1, ""2"", 3.4, [5, 6, [7, 8]]], ""objects"": { ""prop1"": ""outroTexto"", ""prop2"": [ { ""id"": 1, ""name"": ""item1"" }, { ""id"": 2, ""name"": ""item2"", ""teste"": { ""maisum"": [1, 2, 3] } } ] } }]" ' double double quotes here because of the VBScript quotes scaping


set oJSONoutput = JSON.Parse(jsonString) ' this method returns the parsed object. Arrays are parsed to JSONarray objects


JSON.Write() ' outputs: '{"data":[{"strings":"valorTexto","numbers":123.456,"arrays":[1,"2",3.4,[5,6,[7,8]]],"objects":{"prop1":"outroTexto","prop2":[{"id":1,"name":"item1"},{"id":2,"name":"item2","teste":{"maisum":[1,2,3]}}]}}]}'

oJSONoutput.Write() ' outputs: '[{"strings":"valorTexto","numbers":123.456,"arrays":[1,"2",3.4,[5,6,[7,8]]],"objects":{"prop1":"outroTexto","prop2":[{"id":1,"name":"item1"},{"id":2,"name":"item2","teste":{"maisum":[1,2,3]}}]}}]'


' if the string represents an object (not an array of objects), the current object is returned so there is no need to set the return to a new variable

jsonString = "{ ""strings"" : ""valorTexto"", ""numbers"": 123.456, ""arrays"": [1, ""2"", 3.4, [5, 6, [7, 8]]] }"


JSON.Parse(jsonString)

JSON.Write() ' outputs: '{"strings":"valorTexto","numbers":123.456,"arrays":[1,"2",3.4,[5,6,[7,8]]]}'

To load records from a database:

' load records from an ADODB.Recordset

dim cn, rs

set cn = CreateObject("ADODB.Connection")

cn.Open "yourConnectionStringGoesHere"


set rs = cn.execute("SELECT id, nome, valor FROM pedidos ORDER BY id ASC")

' this could also be:

' set rs = CreateObject("ADODB.Recordset")

' rs.Open "SELECT id, nome, valor FROM pedidos ORDER BY id ASC", cn


JSON.LoadRecordset rs

JSONarr.LoadRecordset rs


rs.Close

cn.Close

set rs = Nothing

set cn = Nothing


JSON.Write() ' outputs: {"data":[{"id":1,"nome":"nome 1","valor":10.99},{"id":2,"nome":"nome 2","valor":19.1}]}

JSONarr.Write() ' outputs: [{"id":1,"nome":"nome 1","valor":10.99},{"id":2,"nome":"nome 2","valor":19.1}]

To change the default property name ("data") when loading arrays and recordsets, use the defaultPropertyName property:

JSON.defaultPropertyName = "CustomName"

JSON.Write() ' outputs: {"CustomName":[{"id":1,"nome":"nome 1","valor":10.99},{"id":2,"nome":"nome 2","valor":19.1}]}

If you want to use arrays, I have something for you too

' instantiate the class

set JSONarr = New JSONarray


' add something to the array

JSONarr.Push JSON ' Can be JSON objects, and even JSON arrays

JSONarr.Push 1.25 ' Can be numbers

JSONarr.Push "and strings too"


' write to page

JSONarr.Write() ' Guess what? This does the same as the Write method from JSON object

To loop arrays you have to access the items property of the JSONarray object and you can also access the items trough its index:

dim i, item


' more readable loop

for each item in JSONarr.items

if isObject(item) and typeName(item) = "JSONobject" then

item.write()

else

response.write item

end if


response.write "<br>"

next


' faster but less readable

for i = 0 to JSONarr.length - 1

if isObject(JSONarr(i)) then

set item = JSONarr(i)


if typeName(item) = "JSONobject" then

item.write()

else

response.write item

end if

else

item = JSONarr(i)

response.write item

end if


response.write "<br>"

next


该文章在 2024/12/12 17:36:55 编辑过
关键字查询
相关文章
正在查询...
点晴ERP是一款针对中小制造业的专业生产管理软件系统,系统成熟度和易用性得到了国内大量中小企业的青睐。
点晴PMS码头管理系统主要针对港口码头集装箱与散货日常运作、调度、堆场、车队、财务费用、相关报表等业务管理,结合码头的业务特点,围绕调度、堆场作业而开发的。集技术的先进性、管理的有效性于一体,是物流码头及其他港口类企业的高效ERP管理信息系统。
点晴WMS仓储管理系统提供了货物产品管理,销售管理,采购管理,仓储管理,仓库管理,保质期管理,货位管理,库位管理,生产管理,WMS管理系统,标签打印,条形码,二维码管理,批号管理软件。
点晴免费OA是一款软件和通用服务都免费,不限功能、不限时间、不限用户的免费OA协同办公管理系统。
Copyright 2010-2025 ClickSun All Rights Reserved