综合学习---JSON详情

/**
 * 关于JSON
 */
JSON(JavaScript Object Notation,JavaScript对象表示法)是一个轻量级的数据格式,可以简化表示复杂数据结构的工作量。

支持表示三种类型的值:

	简单值 : 5 或者 “hello world” [数值]或者[字符串]或者[布尔值]或者[null]。但
	         不支持undefined;
	对象: 带引号的键值对儿 
		{ 
			“name”:“Yumay”, 
			“age”: 18, 
			“sex”:“female" 
		}
	数组 
		[ 
			{ 
			“name”:“Yumay”, 
			“age”: 18, 
			“sex”:“female" 
			}, 
			{ 
			“name”:“Yumay”, 
			“age”: 18, 
			“sex”:“female" 
			}, 
			{ 
			“name”:“Yumay”, 
			“age”: 18, 
			“sex”:“female" 
			} 
		] 


解析JSON
{
	方法一、使用eval函数。 
	var dataObj = eval(“(“+json+”)”);

	加上圆括号的目的是迫使eval函数在处理JavaScript代码的时候强制将括号内的表达式(expression)转化为对象,而不是作为语句(statement)来执行将json数据转换为json对象。

	使用eval函数解析JSON是一种很不安全的方式,能不用最好就不用,原因是eval不但可以解析JSON字符串,还会执行其中的代码块(如果有的话)

	方法二、使用JSON.parse()方法解析 比较常用
	var obj = JSON.parse(jsondata);
}
[说明]
为什么要 eval这里要添加 “("("+data+")");//”呢?

原因在于:eval本身的问题。 由于json是以”{}”的方式来开始以及结束的,在JS中,它会被当成一个语句块来处理,所以必须强制性的将它转换成一种表达式。

加上圆括号的目的是迫使eval函数在处理JavaScript代码的时候强制将括号内的表达式(expression)转化为对象,而不是作为语句(statement)来执行。举一个例子,例如对象字面量{},如若不加外层的括号,那么eval会将大括号识别为JavaScript代码块的开始和结束标记,那么{}将会被认为是执行了一句空语句。所以下面两个执行结果是不同的:
alert(eval("{}"); // return undefined
alert(eval("({})");// return object[Object]


/**
 * js调用
 */
{
	原来js在文件内部是不用$(function(){})也能自动执行。而在外部加载时,由于没有$(function(){})就不执行了。
}

/**
 * js数据转义
 */
encodeURI() --- 把字符串作为 URI 进行编码。转为[十六进制]
decodeURI() --- 解码


/**
 * JSON使用格式
 */
$str1 = '{
  "code": 200,
  "msg": "success",
  "data": {
	  	"aa" : "bb",
	  	"cc" : "dd"
  	}
}';
<!-- 
array(3) {
  ["code"]=>
  int(200)
  ["msg"]=>
  string(7) "success"
  ["data"]=>
  array(2) {
    ["aa"]=>
    string(2) "bb"
    ["cc"]=>
    string(2) "dd"
  }
}
 -->

$str2 = '{
  "code": 200,
  "msg": "success",
  "data": [{
	  	"aa" : "bb",
	  	"cc" : "dd"
  	},
  	{
	  	"name" : "ningwang",
	  	"sex" : "boy"
  	}]
}';

<!-- array(3) {
  ["code"]=>
  int(200)
  ["msg"]=>
  string(7) "success"
  ["data"]=>
  array(2) {
    [0]=>
    array(2) {
      ["aa"]=>
      string(2) "bb"
      ["cc"]=>
      string(2) "dd"
    }
    [1]=>
    array(2) {
      ["name"]=>
      string(8) "ningwang"
      ["sex"]=>
      string(3) "boy"
    }
  }
} -->

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

红尘炼炼心

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值