jasonencode php_PHP的json_encode()函数与JSON对象

一、问题描述

这周搬砖的时候,前端通过ajax获取后端的数据后,照例用 对象.属性 的方式取值,然而结果总是总是不能如预期般展示在页面上。

先写个 demo 还原下场景:选中一个下拉框列表选项后,会在下拉框下面展示文字。

这是下拉框的html部分:

JSON DEMO

终端设备

PC Web

PHP代码如下:用来返回数据(接收、处理过程略)

$onLines = [

1 => 'PC Web',

2 => 'iPad HD',

5 => 'Touch'

];

echo json_encode(['data' => $onLines]);

JS代码如下:

$("#device").change(function() {

var selectVal = $("#device").val();

if (selectVal == '') {

$("#tip").html('');

return;

}

# code... ajax 部分的代码见下

});

ajax 部分的代码用来接收从后端(PHP)传过来的数据,并处理。

$.ajax({

url: 'device.php',

type: 'post',

dateType: 'json',

data: {

device: selectVal

},

success: function(result) {

var onlineDevices = result.data;

var onlineTip = '允许' + onlineDevices[selectVal] + '类型的2台设备同时在线。';

$("#tip").html('');

$("#tip").append(onlineTip);

}

});

使用 console.log 在控制台输出结果,如下图所示,可以看到后端返回的数据是没有问题的,

再使用 typeof 查看返回的数据类型,前端收到的数据是JSON字符串!而不是JSON对象!

success: function(result) {

console.log(result);

console.log(result.data);

console.log(typeof result);

}

二、解决方法

找到问题就好办了,只需要把 json 字符串转成 json 对象就好了,最简单的办法是 JSON.parse()。

success: function(result) {

var onlineDevices = JSON.parse(result).data;

# code ...

}

三、总结

1、json字符串和json对象的区别

// JSON 字符串

var str1 = '{"data":{"1":"PC Web","2":"iPad HD","5":"Touch"}}';

// JSON 对象

var str2 = {"data":{"1":"PC Web","2":"iPad HD","5":"Touch"}};

console.log(str1);

console.log(typeof str1);

console.log(str2);

console.log(typeof str2);

可以看到json字符串和json对象的形式很像,但前者比后者多了一对引号,其内容包含在引号里了。调试台的结果如下:

2、json字符串转为json对象的方法

后端

设置header头中的内容类型,将 Content-Type 设置为 text/json。

header('Content-Type:text/json;charset=utf-8');

注:前端直接处理即可,不需要 JSON.parse() 处理。

但项目中用的是框架,所有的PHP文件(业务层)均没有显式设置 header,虽然在demo中此方法有效,可依然不明白为什么别的地方返回的是json对象,而这里返回的却是json字符串了。

强制类型转换(object) 此方法无效!

如果将一个对象转换成对象,它将不会有任何变化。如果其它任何类型的值被转换成对象,内置标准类 stdClass 的一个实例将被建立。

以上面的数组为例,强制类型转换的结果如下:

var_dump((object)['data' => $onLines]);

// 结果如下:

object(stdClass)#1 (1) {

["data"]=>

array(3) {

[1]=>

string(6) "PC Web"

[2]=>

string(7) "iPad HD"

[5]=>

string(5) "Touch"

}

}

而json_encode((object)['data' => $onLines]);得到的还是json字符串。

前端

var obj = JSON.parse(str);

JSON.parse()方法,必须保证传入的是json字符串,如果是json对象会报错。

var obj = jQuery.parseJSON(str);

parseJSON()方法是jQuery方法,仅支持标准json格式,否则会报错。

下面这些是无效的 JSON 字符串:

"{test: 1}"

//test是属性名称,必须加双引号

"{'test': 1}"

//test是属性名称,必须用双引号(不能用单引号)

"'test'"

//test是属性名称,必须用双引号(不能用单引号)

"undefined"

//undefined 不能表示一个 JSON 字符串; null可以

"NaN"

//NaN 不能表示一个 JSON 字符串; 用Infinity直接表示无限也是不允许的

var obj = eval('(' + str + ')');

eval()方法是js方法,也是必须保证传入的是json字符串,否则会报错。

四、疑惑

查了一下PHP的 json_encode()函数,PHP手册给出的结论是成功时返回字符串。

Return Values

Returns a JSON encoded string on success or FALSE on failure.

既然json_encode()函数返回的是字符串,为什么在项目中其他地方可以直接使用 对象.属性 的方式呢?

后记 更新于2019-02-25

今天不死心,又研究了一下,还问了一个朋友,对方提醒估计大概率是编码和头的设置有问题,然后我逐行查代码,发现 ajax 部分的dataType我写成了dateType,一字之差~

噢,天啊,太丢人了!以后绝对不能再犯这么二的错误了!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/338549.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

intext:企业_企业中的微服务:敌是友?

intext:企业宏观问题的微观解决方法? 微服务的炒作无处不在,尽管业界似乎无法就确切的定义达成共识,但我们一再被告知,从单一应用程序转向由小型服务组成的面向服务的体系结构(SOA)是正确的方法…

mui hello html5 安装,HBuilder开发App Step1——环境搭建,HelloMUI 以及真机调试(示例代码)...

No1. 必须搭建java环境只需要最基础的java环境,也就是cmd下可以运行java和javac即可,具体教程请自行百度,都会有很详细的教程,这里不重点介绍。No2. 下载安装HBuilder下载完成后请将zip包解压缩到自定义的目录(windows)&#xf…

C 析构函数

C 析构函数概述C 析构函数是一个特殊的成员函数,作用与构造函数相反,它的名字是类名的前面加一个~符号,析构函数是与构造函数作用相反的函数,当对象的生命期结束时,会自动执行析构函数。C 执行析构函数的情…

前后端分离的项目部署到tomcat_前后端分离后,tomcat服务器部署和发布

打包服务端:IDEA打开项目,等待项目初始化完成,点击Build- Build Artifacts,进行打包image.png点击之后会出现下面这个小窗口,选择红框中部分:image.png这个过程就是打包了,等待打包完成之后&…

vue 侦听器侦听对象属性_不删除侦听器–使用ListenerHandles

vue 侦听器侦听对象属性听一个可观察的实例并对它的变化做出React很有趣。 做一些必要的事情来打断或结束这种聆听会变得很有趣。 让我们看看问题的根源和解决方法。 总览 这篇文章将首先讨论这种情况,然后再讨论常见的方法和问题所在。 然后,它将提供解…

华硕笔记本桌面没有显示计算机,华硕笔记本的桌面不见了,急求高手解答

满意答案下放工人2013.04.06采纳率:54% 等级:12已帮助:5701人★桌面-点击鼠标右键-点击排列图标-点击显示桌面图标★在桌面上右键点击→“属性”→桌面项→左下有个“自定义桌面”进入设置,把…

Facebook开源 C++11 组件库,真香!

Folly是Facebook open source library的缩写,提供了类似 Boost 和 std 库的功能。包括散列、字符串、向量、内存分配、位处理等,满足大规模高性能的需求。逻辑设计Folly 是一组相对独立的组件,有的简单到几个符号。对内部依赖没有限制&#x…

sentinel接入网关应用_接入容器服务Kubernetes版应用

server:port: 8090# Eurekaeureka:instance:leaseRenewalIntervalInSeconds: 10leaseExpirationDurationInSeconds: 30client:enabled: true #若希望开启Euerka支持,则置为true并将其它服务发现置为false。serviceUrl:defaultZone: http://my-eureka-ack-springclou…

undertow ssl_SSL与WildFly 8和Undertow

undertow ssl我一直在研究WildFly 8的一些安全性主题,偶然发现了一些没有很好记录的配置选项。 其中之一是用于新的Web子系统Undertow的TLS / SSL配置。 有很多关于较旧的Web子系统的文档,并且确实仍然可以使用,但是这里是使用新方法进行配置…

div alert html,基于jQuery的弹出消息插件 DivAlert之旅(一)

想着自己学习Javascript,以及Ajax、jQuery等已经有一段时间了,不过貌似还没有写过一个插件,看到jQuery官网上那么多令人眼前一亮的插件,自己今天也动心说是不是能够写一个类似的插件来瞧瞧,了解了jQuery插件的基本格式…

C++对象的动态建立

C对象的动态建立和释放在C中,如果定义的对象是静态的,在程序运行过程中,对象所占的空间是不能随时释放的。为提高内存空间的利用率,希望在需要用到对象时才建立对象,在不需要用该对象时就撤销它,释放它所占…

java字符连接字符串数组_Java中连接字符串的最佳方法

java字符连接字符串数组最近有人问我这个问题–在Java中使用运算符连接字符串是否对性能不利? 这让我开始思考Java中连接字符串的不同方法,以及它们如何相互对抗。 这些是我要研究的方法: 使用运算符 使用StringBuilder 使用StringBuffer…

微型计算机使用的普通编码是,2017计算机一级考试选择题练习及答案(2)

35、一般计算机硬件系统的主要组成部件有五大部分,下列选项中不属于这五大部分的事( B )A)运算器 B)软件C)输入设备和输出设备 D)控制器36、微型计算机主机的主要组成部分有( A)。A)运算器和控制器B)CPU 和软盘C)CPU 和显示器D)CPU、内存储器和硬盘37、微型计算机硬…

C 构造函数重载

C 用参数初始化表对数据成员初始化在C 中,构造函数的函数可以通过体内赋值语句对数据成员实现初始化,C 还提供另一种初始化数据成员的方法,用参数初始化表来实现对数据成员的初始化。这种方法不在函数体内对数据成员初始化,而是在…

乐播投延迟很高_大屏也要高刷新!华为4K@120智慧屏初体验,屏幕软件都够硬

买电视就是买屏幕,华为智慧屏也不例外。可参数大而全的旗舰产品往往都有着相当高昂的售价,假如你不愿意将就千元级别的画质,希望电视能坚持更长时间,却又没有足以点满所有技能树的预算……华为新出的S系列智慧屏,大概正…

java常见性能优化_十大最常见的Java性能问题

java常见性能优化Java性能是所有Java应用程序开发人员都关心的问题,因为快速使应用程序与使其正常运行同等重要。 史蒂文海恩斯(Steven Haines)使用他在Java性能问题上的个人经验得出的结论是, 大多数问题都有共同的根本原因 。 因…

为甚 html 显示为源码,显示字符串作为美化HTML源代码

我正在开发一个ASP.NET MVC Web应用程序。在一个页面上,我有一个字符串,如下所示:This is some text !对于预览模式,我使用Html.Raw(Model.MyText),文本显示为呈现的HTML:此是一些文字!我现在想…

C语言 | 链表概述

C语言链表概述链表是一种常见的重要的数据结构。它是动态地进行存储分配的一种结构,是根据需要开辟内存单元。链表有一个“头指针”变量,它存放一个地址,该地址指向一个元素。链表中每一个元素称为“结点”,每个结点都应包括两个部…

笔记本电脑频繁自动重启_如何解决电脑频繁自动重启

电脑频繁自动重启的原因可能是系统问题,也可能是电脑硬件出现问题,需要经过仔细排查才能找到自动重启的原因。电脑频繁自动重启的原因一、显卡或CPU温度过高当显卡和CPU的温度达到一定温度以后,主板就会启用自动保护功能,使电脑重…

jooq_jOOQ与Hibernate:何时选择哪个

jooqHibernate已成为Java生态系统中的事实上的标准,事实上, 如果标准对您很重要 ,并且如果您将JCP与ISO,ANSI,IEEE等置于同一级别,那么Hibernate也是实际的JavaEE标准实现。 本文的目的不是讨论标准&#…