1、后端返回的值
"{\"msg\":\"InvalidParameterValue.NoFaceInPhoto-圖片中沒有人臉。\",\"code\":500}”
關於為何會返回如上json字符串的場景:文件上傳「聲明了Content-Type」
wx.uploadFile({
url: common.apiServer+'wx/user/uploadImg?openid='+openid,
filePath: _self.data.src,
name: 'file',
header: {
"Content-Type": "multipart/form-data"
},
success: function (uploadFileRes) {
},
error: function(e){
wx.hideLoading();
console.log("文件上傳失敗");
}
});
2、區分json字符串,json對象的區別
上方后端返回的就是json字符串,再具體一下它的特征:使用單引號或者雙引號引起來
我們來看一下常用的json對象↓↓↓:
{"msg":"InvalidParameterValue.NoFaceInPhoto-圖片中沒有人臉。","code":500}
那么兩者在使用上有什么區別呢?
對象是可以通過 對象.屬性 取值的,而json字符串不可以。
比如返回數據中的 data.code「假設返回數據為data」 在json字符串中拿到的是 undefined,而在json對象中拿到的是 500
3、如何拿到json字符串中的數據呢
首先我們可能想到的是 js 中的 eval 函數,嘗試后報如下錯誤:
thirdScriptError
eval is not a function;at api uploadFile success callback function
TypeError: eval is not a function
由於數據安全性問題,小程序禁用了這個函數… 改用 JSON.parse 實現
JSON.parse:
let data = "{\"msg\":\"InvalidParameterValue.NoFaceInPhoto-圖片中沒有人臉。\",\"code\":500}”;
let resuleData= data.replace(" ","");
if(typeof resuleData != 'object'){
resuleData= resuleData.replace(/\ufeff/g,"");
let newData = JSON.parse(resuleData);
console.log("newData:"+JSON.stringify(newData));
console.log("new code :" + newData.code);
}
在平時遇到返回的是json字符串時,首先第一想到的就是eval函數,但由於小程序禁用了eval函數,故開此篇以記之。