使用原生js发送Ajax请求-笔记

eval():

  作用:它的作用是把对应的字符串解析成js代码并运行(将json的字符串解析成为JSON对象);

  特点:它是一个全局函数;

  缺点:1>在该函数内部申明的变量都是全局变量,且申明的变量不会提升;

       2>耗性能,执行2次,一次解析成js语句,一次执行js代码;

  举例:

  1.对于服务器返回的JSON字符串,如果jquery异步请求没做类型说明,或者以字符串方式接受,那么需要做一次对象化处理,就是将字符串放到eval()函数中执行如下:

已知服务器返回JSON字符串集合:

var data="{

  student:[

    {name:'小明',age:17},

    {name:'小红',age:16},

    {name:'小鹏',age:18}

]

}";

var dataObj=eval("("+data+")");

注意:这里在data外添加"("+**+")"是由于json是以"{}"的方式包裹的,js会将以"{}"包裹的代码当成语句处理,所以在调用该函数的时候需要先强制性转换一种表达方式,

alert(eval("{}"); // return undefined;
alert(eval("({})");// return object[Object];

JSON.parse()与JSON.stringify()的区别

JSON.parse()【从json对象(数组)中解析出js对象(数组)】

例子:

//定义一个字符串

var data='{"name":"goatling"}'

//解析对象​

​JSON.parse(data)

结果是:

​name:"goatling"

JSON.stringify()【从js对象(数组)中解析出json对象(数组)】

var data={name:'goatling'}

JSON.stringify(data)

结果是:

'{"name":"goatling"}'

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值