亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

使用JSON.strgify無法對錯誤進行字符串化嗎?

使用JSON.strgify無法對錯誤進行字符串化嗎?

森欄 2019-07-17 10:41:04
使用JSON.strgify無法對錯誤進行字符串化嗎?再現問題在試圖使用web套接字傳遞錯誤消息時,我遇到了一個問題。我可以復制我所面臨的問題JSON.stringify為迎合更廣泛的觀眾:// node v0.10.15> var error = new Error('simple error message');     undefined> error    [Error: simple error message]> Object.getOwnPropertyNames(error);     [ 'stack', 'arguments', 'type', 'message' ]> JSON.stringify(error);     '{}'問題是,我最終得到了一個空對象。我試過的瀏覽器我首先嘗試離開node.js并在各種瀏覽器中運行它。ChromeVersion 28給了我同樣的結果,有趣的是,Firefox至少嘗試了一下,但忽略了這個信息:>>> JSON.stringify(error); // Firebug, Firefox 23{"fileName":"debug eval code","lineNumber":1,"stack":"@debug eval code:1\n"}替換函數然后我看了看錯誤原型..它顯示了原型包含的方法,如托斯特林和到源..我知道函數不能被壓縮,所以我包括了一個替換函數當調用JSON.strgify來刪除所有函數時,卻意識到它也有一些奇怪的行為:var error = new Error('simple error message');JSON.stringify(error, function(key, value) {     console.log(key === ''); // true (?)     console.log(value === error); // true (?)});它似乎不像通常那樣在對象上循環,因此我無法檢查鍵是否是函數而忽略它。問題是否有任何方法將本機錯誤消息壓縮為JSON.stringify?如果沒有,為什么會發生這種行為?繞過這件事的方法堅持使用簡單的基于字符串的錯誤消息,或者創建個人錯誤對象,而不依賴于本機錯誤對象。拉力特性:JSON.stringify({ message: error.message, stack: error.stack })
查看完整描述

3 回答

?
撒科打諢

TA貢獻1934條經驗 獲得超2個贊

您可以定義Error.prototype.toJSON檢索平原Object表示Error:

if (!('toJSON' in Error.prototype))Object.defineProperty(Error.prototype, 'toJSON', {
    value: function () {
        var alt = {};

        Object.getOwnPropertyNames(this).forEach(function (key) {
            alt[key] = this[key];
        }, this);

        return alt;
    },
    configurable: true,
    writable: true});
var error = new Error('testing');error.detail = 'foo bar';console.log(JSON.stringify(error));// {"message":"testing","detail":"foo bar"}

使用Object.defineProperty()toJSON而不是enumerable財產本身。


關于修改Error.prototype,同時toJSON()可能不會被定義為Error特別是,該方法仍是標準化的。對于一般的對象(參見:步驟3)。因此,碰撞或沖突的風險是最小的。

不過,為了完全避免,JSON.stringify()replacer參數可改為:

function replaceErrors(key, value) {
    if (value instanceof Error) {
        var error = {};

        Object.getOwnPropertyNames(value).forEach(function (key) {
            error[key] = value[key];
        });

        return error;
    }

    return value;}var error = new Error('testing');error.detail = 'foo bar';console.log(JSON.stringify(error, replaceErrors));


查看完整回答
反對 回復 2019-07-17
?
婷婷同學_

TA貢獻1844條經驗 獲得超8個贊

修改喬納森的好答案以避免猴子打補?。?/trans>

var stringifyError = function(err, filter, space) {
  var plainObject = {};
  Object.getOwnPropertyNames(err).forEach(function(key) {
    plainObject[key] = err[key];
  });
  return JSON.stringify(plainObject, filter, space);};var error = new Error('testing');error.detail = 'foo bar';console.log(stringifyError(error, null, '\t'));


查看完整回答
反對 回復 2019-07-17
?
DIEA

TA貢獻1820條經驗 獲得超2個贊

因為沒有人在談論為什么一部分,我來接。

為什么這樣JSON.stringify返回空對象?

> JSON.stringify(error);'{}'

回答

從…的文件JSON.strgify(),

對于所有其他對象實例(包括Map、Set、WeakMap和WeakSet),只有它們的可枚舉屬性才會被序列化。

Error對象沒有可枚舉的屬性,這就是它打印空對象的原因。


查看完整回答
反對 回復 2019-07-17
  • 3 回答
  • 0 關注
  • 572 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號