JSON 表达式
JSON语法规则:
数据在名称/值对中;
数据由逗号分隔;
大括号保存对象;
中括号保存数组
1、访问对象值:
-
var myObj,x;
-
myObj = {"name":"runoob","alexa":10000,"site":null};
-
x = myObj.name; //使用点号(.)来访问对象的值
-
x = myObj["name"]; //使用中括号([])来访问对象的值
2、使用for-in 来循环对象的属性:
-
<p id="demo"></p>
-
<script>
-
var myObj = { "name":"runoob", "alexa":10000, "site":null };
-
for (x in myObj) {
-
document.getElementById("demo").innerHTML += x + "<br>";
-
}
-
</script>
3、for-in循环对象的属性时,使用中括号([])来访问属性的值:
-
<p id="demo"></p>
-
<script>
-
var myObj = { "name":"runoob", "alexa":10000, "site":null };
-
for (x in myObj) {
-
document.getElementById("demo").innerHTML += myObj[x] + "<br>";
-
}
-
</script>
4、修改 JSON 对象的值:
myObj.sites.site1 = "www.google.com";
5、删除 JSON 对象的属性:
delete myObj.sites.site1;
5、使用索引值来访问数组:
-
<script>
-
var myObj, x;
-
myObj = {"name":"网站","num":3, "sites":[ "Google", "Runoob", "Taobao" ] }
-
x = myObj.sites[0];
-
document.getElementById("demo").innerHTML = x;
-
</script>
6、使用for-in 来访问数组:
-
<script>
-
var myObj, i, x = "";
-
myObj = {
-
"name":"网站",
-
"num":3,
-
"sites":[ "Google", "Runoob", "Taobao" ]
-
};
-
for (i in myObj.sites) {
-
x += myObj.sites[i] + "<br>";
-
}
-
document.getElementById("demo").innerHTML = x;
-
</script>
******************************************************************************************************************************************
1、JSON 通常用于与服务端交换数据。在接收服务器数据时一般是字符串。我们可以使用 JSON.parse() 方法将数据转换为 JavaScript 对象
语法: JSON.parse(text,reviver)
text:必需, 一个有效的 JSON 字符串。
reviver: 可选,一个转换结果的函数, 将为对象的每个成员调用此函数。
var obj = JSON.parse('{ "name":"runoob", "alexa":10000, "site":"www.runoob.com" }');
解析完成后,我们就可以在网页上使用 JSON 数据了:
-
<p id="demo"></p>
-
<script>
-
var obj = JSON.parse('{ "name":"runoob", "alexa":10000, "site":"www.runoob.com" }');
-
document.getElementById("demo").innerHTML = obj.name + ":" + obj.site;
-
</script>
2、使用AJAX 从服务器请求 JSON 数据,并解析为 JavaScript 对象:
-
var xmlhttp = new XMLHttpRequest();
-
xmlhttp.onreadystatechange = function(){
-
if(this.readyState == 4 && this.status == 200){
-
myObj = JSON.parse(this.responseText);
-
document.getElementById("demo").innerHTML = myObj.name;
-
}};
-
xmlhttp.open("GET","/try/ajax/json_demo.txt",true);
-
xmlhttp.send();
3、 JSON.stringify()方法:
JSON 通常用于与服务端交换数据。在向服务器发送数据时一般是字符串。我们可以使用 JSON.stringify() 方法将 JavaScript 对象转换为字符串。
语法: JSON.stringify(value,replacer,space)
value:必需, 一个有效的 JSON 字符串。
replacer:可选。用于转换结果的函数或数组。
如果 replacer 为函数,则 JSON.stringify 将调用该函数,并传入每个成员的键和值。使用返回值而不是原始值。如果此函数返回 undefined,则排除成员。根对象的键是一个空字符串:""。
如果 replacer 是一个数组,则仅转换该数组中具有键值的成员。成员的转换顺序与键在数组中的顺序一样。当 value 参数也为数组时,将忽略 replacer 数组。
space:可选,文本添加缩进、空格和换行符,如果 space 是一个数字,则返回值文本在每个级别缩进指定数目的空格,如果 space 大于 10,则文本缩进 10 个空格。space 有可以使用非数字,如:\t。
-
var obj = {"name":"runoob","alexa":10000,"site":"www.runoob.com"};
-
var myJSON = JSON.stringify(obj);
-
document.getElementById("demo").innerHTML = myJSON;
JavaScript 函数 eval() 可用于将 JSON 文本转换为 JavaScript 对象:
-
var txt = '{ "sites" : [' +'{"name":"菜鸟教程" , "url":"www.runoob.com" },' +'{ "name":"google" , "url":"www.google.com" },'+'{ "name":"微博" , "url":"www.weibo.com" } ]}';
-
var obj = eval("("+ txt + ")");
-
document.getElementById("name").innerHTML=obj.sites[0].name
-
document.getElementById("url").innerHTML=obj.sites[0].url
JSON 表达式的更多相关文章
- s表达式和json表达式
s表达式 + 1 2 3普通表达式 1+2+3json表达式{ +:[1, 2, 3]}优点,一个运算符,无限个参数 s表达式 * (+ 1 2) 3普通表达式 1+(2*3)json表达式{ *:[ ...
- QT解析嵌套JSON表达式
QT5开发环境集成了解析JSON表达式的库.使用很方便. 友情提示一下,好像在QT4环境里.须要到官网下载相关的库文件才干使用解析功能.话不多说,上代码 1.在pro文件里增加 QT += scrip ...
- Jmeter之Json表达式关联
Jmeter使用中,通常用的最多的是正则表达式和Xpath表达式,但是现在大多数网站都用的Json返回数据,而且数据还特长的那种,作为合格的测试人员也要适应技术潮流发展,下面介绍利用Json Extr ...
- Jmeter 提取http请求返回值里json数据参数化方法
第三方插件下载地址:http://jmeter-plugins.org/downloads/all/ 插件下载后解压:找到JMeterPlugins-Extras.jar,把JMeterPlugins ...
- 【JEMTER】后置处理器JSON Path Extractor获取server端返回的json中某项值
需求1:点击所有报表模板时,server端返回所有报表模板的ID(templateId),测试时需要下载某个模板生成的报表 需求2:点击单个报表模板时,server端返回这个报表模板下的所有报表ID( ...
- mysql 5.7 laravel json类型数据相关操作
2018年10月16日18:14:21 官方文档中文翻译版 原文:https://dev.mysql.com/doc/refman/5.7/en/json.html 最后有部分实例和一个小总结 11. ...
- JSON Extractor
JMeter处理responses 的json 对于请求1返回的结果,处理以后作为请求2的参数,JMeter提供了JSON 提取器 比如 responses 返回: {"statusCode ...
- [笔记] Python 中JSON数据的读写
前言 JSON(JavaScript Object Notation,JavaScript对象表示法)是一种轻量级的数据交换语言 JSON是独立于语言的文本格式, JSON 数据格式与语言无关 JSO ...
- python初步学习-python 模块之 json
json 模块 JSON(JavaScript Object Notation)是一种轻量级的数据交换格式,易于人阅读和编写.一般API返回的数据大多是 JSON.XML,如果返回JSON的话,将获取 ...
随机推荐
- 11.typeid
#include <iostream> using namespace std; void main() { int a; cout << typeid(a).name() & ...
- Android EditText回车不换行
有时候我们需要在EditText组件输入完直接点回车进入 回车点击事件中处理相关业务,总是换行很伤脑筋,索性网上搜了一个办法,很实用,在这里记下来. 首先获取组件id: edt_city= (Edit ...
- 每天自动备份MySQL数据库的shell脚本
经常备份数据库是一个好习惯,虽然数据库损坏或数据丢失的概率很低,但一旦发生这种事情,后悔是没用的.一般网站或应用的后台都有备份数据库的功能按钮,但需要去手工执行.我们需要一种安全的,每天自动备份的方法 ...
- Node.js自学笔记之回调函数
写在前面:如果你是一个前端程序员,你不懂得像PHP.Python或Ruby等动态编程语言,然后你想创建自己的服务,那么Node.js是一个非常好的选择.这段时间对node.js进行了简单的学习,在这里 ...
- startActivityForResult()方法具体解释
我们都知道.要开启一个Activity能够在上下文环境中调用startActivity()方法. 可是假设想从开启的Activity中获取某些数据,就能够使用startActivityForResul ...
- thinkphp模型中的获取器和修改器(根据字段名自动调用模型中的方法)
thinkphp模型中的获取器和修改器(根据字段名自动调用模型中的方法) 一.总结 记得看下面 1.获取器的作用是在获取数据的字段值后自动进行处理 2.修改器的作用是可以在数据赋值的时候自动进行转换处 ...
- jtag引脚
如果不能下载,可能原因也许是电量不足了... 在电力不足的时候,仿真也不能进行... ///////////////////////////////////////////////////////// ...
- 8、linux下输入子系统
input_sync(button_dev); /*通知接收者,一个报告发送完毕*/ 参考:http://www.51hei.com/bbs/dpj-27652-1.html 很详细说明 in ...
- 9、基于Linux的v4l2视频架构应用编写
Linux系统中,视频设备被当作一个设备文件来看待,设备文件存放在 /dev目录下,完整路径的设备文件名为: /dev/video0 . 视频采集基本步骤流程如下: 打开视频设备,设置视频设备属性及采 ...
- OCulus Rift 游戏开发六原则
本文章由cartzhang编写,转载请注明出处. 所有权利保留. 文章链接:http://blog.csdn.net/cartzhang/article/details/46685477 作者:car ...