本文将为您提供关于JsonCpp的简单使用方法的详细介绍,我们还将为您解释jsoncpp官方教程的相关知识,同时,我们还将为您提供关于Fastjson简单使用方法、iscroll.js的简单使用方法、
本文将为您提供关于JsonCpp的简单使用方法的详细介绍,我们还将为您解释jsoncpp官方教程的相关知识,同时,我们还将为您提供关于Fastjson简单使用方法、iscroll.js的简单使用方法、Jsoncpp 使用方法大全、jsoncpp 库的使用方法的实用信息。
本文目录一览:JsonCpp的简单使用方法(jsoncpp官方教程)
JsonCpp 是一个C++用来处理JSON 数据的开发包。下面讲一下怎么使用JsonCpp来序列化和反序列化Json对象,以实际代码为例子。
反序列化Json对象
比如一个Json对象的字符串序列如下,其中”array”:[...]表示Json对象中的数组:
{“key1″:”value1″,”array”:[{"key2":"value2"},{"key2":"value3"},{"key2":"value4"}]},那怎么分别取到key1和key2的值呢,代码如下所示:
std::string strValue = “{\”key1\”:\”value1\”,\”array\”:[{\"key2\":\"value2\"},{\"key2\":\"value3\"},{\"key2\":\"value4\"}]}”;
Json::Reader reader;
Json::Value value;
if (reader.parse(strValue, value))
{
std::string out = value["key1"].asString();
std::cout << out << std::endl;
const Json::Value arrayObj = value["array"];
for (int i=0; i<arrayObj.size(); i++)
{
out = arrayObj[i]["key2"].asString();
std::cout << out;
if (i != arrayObj.size() – 1 )
std::cout << std::endl;
}
}
序列化Json对象
先构建一个Json对象,此Json对象中含有数组,然后把Json对象序列化成字符串,代码如下:
Json::Value root;
Json::Value arrayObj;
Json::Value item;
for (int i=0; i<10; i++)
{
item["key"] = i;
arrayObj.append(item);
}
root["key1"] = “value1″;
root["key2"] = “value2″;
root["array"] = arrayObj;
root.toStyledString();
std::string out = root.toStyledString();
std::cout << out << std::endl;
删除Json对象
std::string strContent = "{\"key\":\"1\",\"name\":\"test\"}";
Json::Reader reader;
Json::Value value;
if (reader.parse(strContent, value))
{
Json::Value root=value;
root.removeMember("key");
printf("%s \n",root.toStyledString().c_str());

Fastjson简单使用方法
一、简单数据的序列化
pubic class UserInfo implements Serializable{ private String name; private int age; public void setName(String name){ this.name=name; } public String getName(){ return name; } public void setAge(int age){ this.age=age; } public int getAge(){ return age; } } public class TestOne{ public static void main(String[] args){ UserInfo info=new UserInfo(); info.setName("zhangsan"); info.setAge(24); //将对象转换为JSON字符串 String strjson=JSON.toJSONString(info); System.out.println("JSON="+strjson); } }
说明:
- 关键部分就是上述部分的JSON.toJSONString();
- JSON序列化,默认序列化出的JSON字符串中键值对是使用双引号,如果需要单引号的JSON字符串,[eg:StringjsonString=JSON.toJSONString(map,SerializerFeature.UseSingleQuotes);]fastjson序列化时可以选择的SerializerFeature有十几个属性,你可以按照自己的需要去选择使用。
二、反序列化
public void test3(){ String json="{\"name\":\"chenggang\",\"age\":24}"; //反序列化 UserInfo userInfo=JSON.parSEObject(json,UserInfo.class); System.out.println("name:"+userInfo.getName()+",age:"+userInfo.getAge()); } /**泛型的反序列化*/ public static void test4(){ String json="{\"user\":{\"name\":\"zhangsan\",\"age\":25}}"; Map<String,UserInfoBean> map = JSON.parSEObject(json,new TypeReference<Map<String,UserInfoBean>>(){}); System.out.println(map.get("user")); }
三、日期格式化
public void test5(){ Date date=new Date(); //输出毫秒值 System.out.println(JSON.toJSONString(date)); //默认格式为yyyy-MM-dd HH:mm:ss System.out.println(JSON.toJSONString(date,SerializerFeature.WriteDateUseDateFormat)); //根据自定义格式输出日期 System.out.println(JSON.toJSONStringWithDateFormat(date,"yyyy-MM-dd",SerializerFeature.WriteDateUseDateFormat)); }
说明:
阿里巴巴提供了很多SerializerFeature.XXX 这些都很符合中国人的习惯。比起Jackson各有优劣!
四、基本常用API
Fastjson API入口类是com.alibaba.fastjson.JSON,常用的序列化操作都可以在JSON类上的静态方法直接完成。 // public static final Object parse(String text); // 把JSON文本parse为JSONObject或者JSONArray // public static final JSONObject parSEObject(String text); // 把JSON文本parse成JSONObject // public static final <T> T parSEObject(String text,Class<T> clazz); // 把JSON文本parse为JavaBean // public static final JSONArray parseArray(String text); // 把JSON文本parse成JSONArray // public static final <T> List<T> parseArray(String text,Class<T> clazz); //把JSON文本parse成JavaBean集合 // public static final String toJSONString(Object object); // 将JavaBean序列化为JSON文本 // public static final String toJSONString(Object object,boolean prettyFormat); // 将JavaBean序列化为带格式的JSON文本 // public static final Object toJSON(Object javaObject); 将JavaBean转换为JSONObject或者JSONArray(和上面方法的区别是返回值是不一样的)
JackSon下载:http://repo1.maven.org/maven2/com/alibaba/fastjson/ 与 https://yunpan.cn/cu2iEKCZjXfak 访问密码 8291
iscroll.js的简单使用方法
参考链接:https://www.cnblogs.com/Renyi-Fan/tag/js%E6%8F%92%E4%BB%B6/default.html?page=2
> 一、总结(点击显示或隐藏总结内容)
一句话总结:Scroll是一个类,每个需要使用滚动功能的区域均要进行初始化。
最佳的HTML结构如下:
<div id="wrapper"> <ul> <li>...</li> <li>...</li> ... </ul> </div>
iScroll作用于滚动区域的外层。在上面的例子中,UL元素能进行滚动。只有容器元素的第一个子元素能进行滚动,其他子元素完全被忽略。
最基本的脚本初始化的方式如下:
<script type="text/javascript"> var myScroll = new IScroll(‘#wrapper‘); </script>
二、iscroll.js的简单使用方法(总结)
这篇文章讲到了iscroll的一些使用入门、参数配置和示例,并讲到了滚动条的接口,自定义事件和销毁动作等。原文:
入门
Scroll是一个类,每个需要使用滚动功能的区域均要进行初始化。每个页面上的iScroll实例数目在设备的cpu和内存能承受的范围内是没有限制的。
尽可能保持DOM结构的简洁。iScroll使用硬件合成层但是有一个限制硬件可以处理的元素。
最佳的HTML结构如下:
<div id="wrapper"> <ul> <li>...</li> <li>...</li> ... </ul> </div>
iScroll作用于滚动区域的外层。在上面的例子中,UL元素能进行滚动。只有容器元素的第一个子元素能进行滚动,其他子元素完全被忽略。
最基本的脚本初始化的方式如下:
<script type="text/javascript"> var myScroll = new IScroll(‘#wrapper‘); </script>
**第一个参数可以是滚动容器元素的DOM选择器字符串**,**也可以是滚动容器元素的引用对象**。下面是一个有效的语法:
var wrapper = document.getElementById(‘wrapper‘); var myScroll = new IScroll(wrapper);
所以基本上你要么直接传递元素,要么传递一个querySelector字符串。因此可以使用css名称代替ID去选择一个滚动器容器,如下:
var myScroll = new IScroll(‘.wrapper‘);
注意,iScroll使用的是querySelector 而不是 querySelectorAll,所以iScroll只会作用到选择器选中元素的第一个。如果你需要对多个对象使用iScroll,你需要构建自己的循环机制。
初始化
当DOM准备完成后iScroll需要被初始化。最保险的方式是在w**indow的onload事件中启动它**。
在**DOMContentLoaded**事件中或者**inline initialization**中做也可以,需要记住的是脚本需要知道滚动区域的高度和宽度。***如果你有一些图片在滚动区域导致不能立马获取区域的高度和宽度,iScroll的滚动尺寸有可能会错误***。
为滚动起容器增加position:relative或者absolute样式。这将解决大多数滚动器容器大小计算不正确的问题。
综上所述,最小的iScroll配置如下:·
<head> ... <script type="text/javascript" src="iscroll.js"></script> <script type="text/javascript"> var myScroll; function loaded() { myScroll = new IScroll(‘#wrapper‘); } </script> </head> ... <body onload="loaded()"> <div id="wrapper"> <ul> <li>...</li> <li>...</li> ... </ul> </div> </body>
**注:**如果你有一个复杂的DOM结构,最好在onload事件之后适当的延迟,再去初始化iScroll。最好给浏览器100或者200毫秒的间隙再去初始化iScroll。
参数配置
在iScroll初始化阶段可以通过构造函数的第二个参数配置它。
var myScroll = new IScroll(‘#wrapper‘,{ mouseWheel: true,scrollbars: true });
上面的例子示例了在iScroll初始化时开启鼠标滚轮支持和滚动条支持。
理解核心
iScroll使用基于设备和浏览器性能的各种技术来进行滚动。通常不需要你来配置引擎,iScroll会为你选择最佳的方式。
尽管如此,理解iScroll工作机制和了解如何去配置他们也是很重要的。
options.useTransform
默认情况下引擎会使用**Csstransform**属性。如果现在还是2007年,那么可以设置这个属性为false,这就是说:引擎将使用top/left属性来进行滚动。
这个属性在滚动器感知到Flash,iframe或者视频插件内容时会有用,但是需要注意:性能会有极大的损耗。
默认值:true
options.useTransition
iScroll使用**CSS transition**来实现动画效果(动量和弹力)。如果设置为false,那么将使用requestAnimationFrame代替。
在现在浏览器中这两者之间的差异并不明显。在老的设备上transitions执行得更好。默认值:true
options.HWCompositing
这个选项尝试使用**translateZ(0)**来把滚动器附加到硬件层,以此来改变CSS属性。在移动设备上这将提高性能,但在有些情况下,你可能想要禁用它(特别是如果你有太多的元素和硬件性能跟不上)。
默认值:true
*注:***如果不确定iScroll的最优配置。从性能角度出发,上面的所有选项应该设置为true。(或者更好的方式,让他们自动设置属性为true)。你可以尝试这配置他们,但是要小心内存泄漏。
滚动条
滚动条不只是像名字所表达的意义一样,在内部它们是作为indicators的引用。
一个指示器侦听滚动条的位置并且现实它在全局中的位置,但是它可以做更多的事情。
先从最基本的开始。
options.scrollbars
正如我们在基本功能介绍中提到的,激活滚动条只需要做一件事情,这件事情就是:
var myScroll = new IScroll(‘#wrapper‘,{ scrollbars: true });
当然这个默认的行为是可以定制的。
滚动的编程接口
当然还可以通过编程来进行滚动。
scrollTo(x,y,time,easing)
对应存在的一个叫做myScroll的iScroll实例,可以通过下面的方式滚动到任意的位置:
myScroll.scrollTo(0,-100);
通过上面的方式将向下滚动100个像素。记住:0永远是左上角。需要滚动你必须传递负数。
time 和 easing是可选项。他们控制滚动周期(毫秒级别)和动画的擦除效果。
擦除功能是一个有效的IScroll.utils.ease对象。例如应用一个一秒的经典擦除动画你应该这么做:
myScroll.scrollTo(0,-100,1000,IScroll.utils.ease.elastic);
擦除动画的类型选项有:quadratic,circular,back,bounce,elastic。
scrollBy(x,easing)
和上面一个方法类似,但是可以传递X和Y的值从当前位置进行滚动。
myScroll.scrollBy(0,-10);
上面这个语句将在当前位置向下滚动10个像素。如果你当前所在位置为-100,那么滚动结束后位置为-110.
scrolltoElement(el,offsetX,offsetY,easing)
这是一个很有用的方法,你会喜欢它的。
在这个方法中只有一个强制的参数就是el。传递一个元素或者一个选择器,iScroll将尝试滚动到这个元素的左上角位置。
time是可选项,用于设置动画周期。
offsetX 和 offsetY定义像素级的偏移量,所以你可以滚动到元素并且加上特别的偏移量。但并不仅限于此。如果把这两个参数设置为true,元素将会位于屏幕的中间。
easing参数和scrollTo方法里的一样。
对齐
iScroll能对齐到固定的位置和元素。
options.snap
最简单的对齐配置如下:
var myScroll = new IScroll(‘#wrapper‘,{ snap: true });
这将按照页面容器的大小自动分割滚动条。
snap属性也可以传递字符类型类型的值。这个值是滚动条将要对齐到的元素的选择器。比如下面:
var myScroll = new IScroll(‘#wrapper‘,{ snap: ‘li‘ });
这个示例中滚动条将会对齐到每一个LI标记的元素。
下面将帮助你快速浏览iScroll提供的关于对齐的一系列有趣的方法。
goToPage(x,easing)
x 和 y呈现你想滚动到横向轴或者纵向轴的页面数。如果你需要在单个唯独上使用滚动条,只需要为你不需要的轴向传递0值。
time属性是动画周期,easing属性是滚动到指定点使用的擦除功能类型。请参考高级功能中的option.bounceEasing。这两个属性都是可选项。
myScroll.goToPage(10,1000);
上面这个例子将在一秒内沿着横向滚动到第10页。
next()
prev()
滚动到当前位置的下一页或者前一页。
缩放
为了使用缩放功能,你最好使用iscroll-zoom.js脚本。
和前面的示例一样,一个好的缩放功能的配置如下:
myScroll = new IScroll(‘#wrapper‘,{ zoom: true,mouseWheel: true,wheelAction: ‘zoom‘ });
刷新
iScroll需要知道包装器和滚动器确切的尺寸,在iScroll初始化的时候进行计算,如果元素大小发生了变化,需要告诉iScroll DOM发生了变化。
下面将提供调用refresh方法的正确时机。
每次触摸DOM,浏览器渲染器重绘页面。一旦发生了重画我们可以安全地读新的DOM属性。重新绘制阶段不是瞬时发生的只是范围结束时触发。这就是为什么我们需要给渲染器刷新iScroll之前一点时间。
为了确保javascript得到更新后的属性,应该像下面的例子这样使用刷新方法:
ajax(‘page.PHP‘,onCompletion); function onCompletion () { // Update here your DOM setTimeout(function () { myScroll.refresh(); },0); };
这里调用refresh()使用了零秒等待,如果你需要立即刷新iScroll边界就是如此使用。当然还有其他方法可以等待页面重绘,但零超时方式相当稳定。
**注:***如果你有一个相当复杂的HTML结构,你应该给浏览器更多的执行事件,可以设置100到200毫秒的超时时间。
这通常适用于所有任务必须在DOM上进行。通常给渲染器一些执行的时间。*
自定义事件
iScroll还提供额一些你可以挂靠的有用的自定义事件。
使用on(type,fn)方法注册事件。
myScroll = new IScroll(‘#wrapper‘); myScroll.on(‘scrollEnd‘,doSomething);
上面的代码会在每次滚动停止是执行doSomething方法。
可以挂靠的事件如下:
beforeScrollStart,在用户触摸屏幕但还没有开始滚动时触发。
scrollCancel,滚动初始化完成,但没有执行。
scrollStart,开始滚动
scroll,内容滚动时触发,只有在scroll-probe.js版本中有效,请参考onScroll event。
scrollEnd,停止滚动时触发。
flick,用户打开左/右。
zoomStart,开始缩放。
zoomEnd,缩放结束。
按键绑定
你可以激活keyBindings选项来支持键盘控制。默认情况下iScroll监听方向键,上下翻页建,home/end键,但这些按键绑定完全可以自定义。
你可以通过传递一个包含按键代码列表的对象来进行按键绑定。
默认的按键值如下:
//code from http://caibaojian.com/iscroll-js.html
keyBindings: { pageUp: 33,pageDown: 34,end: 35,home: 36,left: 37,up: 38,right: 39,down: 40 }
keyBindings: { pageUp: 33,down: 40 }
当然你也可以传递字符串进行按键绑定(例如:pageUp: ‘a‘)。只要你设置了对于的按键值,那么iScroll就会响应你的设置。
滚动条信息
iScroll存储了很多有用的信息,您可以使用它们来增强您的应用。
你可能会发现有用的:
myScroll.x/y,当前位置
myScroll.directionX/Y,最后的方向 (-1 down/right,0 still,1 up/left)
myScroll.currentPage,当前对齐捕获点
下面是关于处理时间的代码示例:
myScroll = new IScroll(‘#wrapper‘); myScroll.on(‘scrollEnd‘,function () { if ( this.x < -1000 ) { // do something } });
如果 x 位置是低于-1000 像素滚轮停止时,上述执行某些代码。请注意我用这个产品而不是 myScroll,您可以使用两个当然,但 iScroll 传递本身作为这种情况下,当触发自定义事件的功能。
销毁
在不需要使用iScoll的时候调用iScroll实例的公共方法destroy()可以释放一些内存。
myScroll.destroy();
myScroll = null;
参考:
Jsoncpp 使用方法大全
Json(JavaScript Object Notation )是一种轻量级的数据交换格式。简而言之,Json组织形式就和python中的字典, C/C++中的map一样,是通过key-value对来组织的,key是任意一个唯一字符串,value可以是bool,int,string 或者嵌套的一个json。关于Json 格式可以参考官方网站。
Jsoncpp是一个用来处理 Json文本的开源C++库,下面就简单介绍使用Jsoncpp对Json文件的常见操作。
Jsoncpp 常用变量介绍
在Jsoncpp中,有几个常用的变量特别重要,首先介绍一下。
Json::Value
Json::Value 用来表示Json中的任何一种value抽象数据类型,具体来说,Json中的value可以是一下数据类型:
- 有符号整数 signed integer [range: Value::minInt - Value::maxInt]
- 无符号整数 unsigned integer (range: 0 - Value::maxUInt)
- 双精度浮点数 double
- 字符串 UTF-8 string
- 布尔型 boolean
- 空 ‘null’
- 一个Value的有序列表 an ordered list of Value
- collection of name/value pairs (javascript object)
可以通过
- 1
- 2
- 3
- 4
- 5
Json::Reader
Json::Reader可以通过对Json源目标进行解析,得到一个解析好了的Json::Value,通常字符串或者文件输入流可以作为源目标。
假设现在有一个example.json文件
5
使用Json::Reader对Json文件进行解析:
2 bool parse (const std::string &document,Value &root,bool collectComments=true) bool parse (std::istream &is,136)">true)
9
使用Json::Reader对字符串进行解析
5 bool Json::Reader::parse ( const char * beginDoc,136)">char * endDoc,Value & root,136)">bool collectComments = true )
9 Json::Value root; Json::Reader reader; const char* s = "{\"uploadid\": \"UP000000\",\"code\": 100,\"msg\": \"\files\"}"; if(!reader.parse(s,root)){ // "parse fail"; } else{ std::cout << root["uploadid"].asstring();//print "UP000000" }
Json::Writer
Json::Writer 和 Json::Reader相反,是把Json::Value对象写到string对象中,而且Json::Writer是个抽象类,被两个子类Json::FastWriter和Json::StyledWriter继承。
简单来说FastWriter就是无格式的写入,这样的Json看起来很乱没有格式,而StyledWriter就是带有格式的写入,看起来会比较友好。
13
结果:
example_styled_writer.json
true } }
example_fast_writer.json
1 {"encoding" : plug-ins" : ["ruby"],102)">true}}
Jsoncpp 其他操作
通过前面介绍的Json::value,Json::Reader,Json::Reader 可以实现对Json文件的基本操作,下面介绍一些其他的常用的操作。
判断key是否存在
10 bool Json::Value::isMember ( char * key) const Return true if the object has a member named key. Note 'key' must be null-terminated. bool Json::Value::isMember ( const std::string & const bool Json::Value::isMember ( char* key,136)">end ) const
15 // print "encoding is a member" if(root.isMember("encoding")){ cout<<"encoding is a member"<<std::endl; } else{ "encoding is not a member"<<std::endl; } // print "encode is not a member" "encode")){ "encode is a member"<<"encode is not a member"<<std::endl; }
判断Value是否为null
首先要给example.json添加一个key-value对:
11 { "encoding" : true },"tab-length":[],"tab":null }
判断是否为null的成员函数
1 bool Json::Value::isNull ( ) 3 if(root["tab"].isNull()){ cout << "isNull" <<std::endl;//print isNull }
9 "tab-length")){//true "tab-length"].isNull()){ "isNull" << std::endl; } else "not Null"<<std::endl; // print "not Null",there is a array object([]),through this array object is empty "empty: " << root["tab-length"].empty() << //print empty: 1 "size: " << root["tab-length"].size() << //print size: 0 }
另外值得强调的是,Json::Value和C++中的map有一个共同的特点,就是当你尝试访问一个不存在的 key 时,会自动生成这样一个key-value默认为null的值对。也就是说
2 root["anything-not-exist"].isNull(); //false root.isMember("anything-not-exist"); //true
总结就是要判断是否含有key,使用isMember成员函数,value是否为null使用isNull成员函数,value是否为空可以用empty() 和 size()成员函数。
得到所有的key
15 typedef std::vector<string> Json::Value::Members Value::Members Json::Value::getMemberNames ( ) const Return a list of the member names. If null,136)">return an empty list. Precondition type() is objectValue or nullValue Postcondition if type() was nullValue,it remains nullValue
可以看到Json::Value::Members实际上就是一个值为string的vector,通过getMemberNames得到所有的key。
删除成员
19
参考
http://open-source-parsers.github.io/jsoncpp-docs/doxygen/index.html
jsoncpp 库的使用方法
1. 下载jsoncpp,地址: http://sourceforge.net/projects/jsoncpp/2. 编译jsoncpp:
jsoncpp文件中提供了vs71的工程文件以及makerelease.py文件,用来编译,里面分为jsontest、lib_json、test_lib_json三个工程,按照自己需要的编译。
注意:如果使用VS默认的编译选项MTd或者MT,在使用json_libmtd.lib的时候可能会出现LNK2038错误(我使用的VS2012vc110环境),所以请修改MTD为MDd,MT为MD。
3.lib库添加进VS工程中:完成,可以在项目中使用JSONCPP库了。
错误解决:
问题:
..json_value.cpp
方法:修改生成静态库文件的工程的属性:路径为:菜单---项目--属性---配置属性---c/c++---输出文件---汇编程序输出:无列表
void readJson() {
using namespace std;
std::string strValue = "{\"name\":\"json\",\"array\":[{\"cpp\":\"jsoncpp\"},{\"java\":\"jsoninjava\"},{\"PHP\":\"support\"}]}";
Json::Reader reader;
Json::Value value;
if (reader.parse(strValue,value))
{
std::string out = value["name"].asstring();
std::cout << out << std::endl;
const Json::Value arrayObj = value["array"];
for (unsigned int i = 0; i < arrayObj.size(); i++)
{
if (!arrayObj[i].isMember("cpp"))
continue;
out = arrayObj[i]["cpp"].asstring();
std::cout << out;
if (i != (arrayObj.size() - 1))
std::cout << std::endl;
}
}
}
参考文章:
http://www.cnblogs.com/ppboy_dxh/archive/2011/03/03/1970290.html
今天关于JsonCpp的简单使用方法和jsoncpp官方教程的讲解已经结束,谢谢您的阅读,如果想了解更多关于Fastjson简单使用方法、iscroll.js的简单使用方法、Jsoncpp 使用方法大全、jsoncpp 库的使用方法的相关知识,请在本站搜索。
本文标签: