How to test if a string is JSON or not?(如何测试字符串是否为 JSON?)
问题描述
我有一个简单的 AJAX 调用,服务器将返回包含有用数据的 JSON 字符串或由 PHP 函数 mysql_error()
生成的错误消息字符串.如何测试此数据是 JSON 字符串还是错误消息.
I have a simple AJAX call, and the server will return either a JSON string with useful data or an error message string produced by the PHP function mysql_error()
. How can I test whether this data is a JSON string or the error message.
使用名为 isJSON
的函数会很好,就像您可以使用函数 instanceof
来测试某个东西是否是数组一样.
It would be nice to use a function called isJSON
just like you can use the function instanceof
to test if something is an Array.
这就是我想要的:
if (isJSON(data)){
//do some data stuff
}else{
//report the error
alert(data);
}
推荐答案
使用 JSON.parse
Use JSON.parse
function isJson(str) {
try {
JSON.parse(str);
} catch (e) {
return false;
}
return true;
}
这篇关于如何测试字符串是否为 JSON?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:如何测试字符串是否为 JSON?


基础教程推荐
- while 在触发器内循环以遍历 sql 中表的所有列 2022-01-01
- ORA-01830:日期格式图片在转换整个输入字符串之前结束/选择日期查询的总和 2021-01-01
- CHECKSUM 和 CHECKSUM_AGG:算法是什么? 2021-01-01
- MySQL根据从其他列分组的值,对两列之间的值进行求和 2022-01-01
- 如何在 CakePHP 3 中实现 INSERT ON DUPLICATE KEY UPDATE aka upsert? 2021-01-01
- MySQL 5.7参照时间戳生成日期列 2022-01-01
- 从字符串 TSQL 中获取数字 2021-01-01
- 带有WHERE子句的LAG()函数 2022-01-01
- 带更新的 sqlite CTE 2022-01-01
- 使用 VBS 和注册表来确定安装了哪个版本和 32 位 2021-01-01