Why can't you stringify a function expression?

后端 未结 5 1440
醉话见心
醉话见心 2020-12-30 01:06

Why doesn\'t this produce anything?

console.log(JSON.stringify(function(){console.log(\'foobar\');}));
相关标签:
5条回答
  • 2020-12-30 01:41

    You cannot do that, but there are some third party libraries can help you do that, like: https://www.npmjs.com/package/json-fn

    0 讨论(0)
  • 2020-12-30 01:55

    If you want to use JSON.stringify to also convert functions and native objects you can pass a converter function as the second argument:

    const data = {
      fn: function(){}
    }
    
    function converter(key, val) {
      if (val && typeof val === 'function' || val.constructor === RegExp) {
        return String(val)
      }
      return val
    }
    
    console.log(JSON.stringify(data, converter, 2))
    

    Return undefined from the converter function if you want to omit the result.

    The third parameter is how many spaces you want the output to indent (optional).

    0 讨论(0)
  • 2020-12-30 01:58

    JSON can't stringify functions at all, it handles them just like undefined or null values. You can check the exact algorithm at EcmaScript 5.1 §15.12.3, see also the description at MDN.

    However you of course can stringify function expression by casting them to a string, try

    console.log("" + function(){console.log('foobar');})
    
    0 讨论(0)
  • 2020-12-30 02:02

    JSON has no means to represent a function. It is a data format designed for simplicity and compatibility across languages (and a function is the last thing that will be cross-language compatible).

    From the docs for JSON.stringify:

    If undefined, a function, or an XML value is encountered during conversion it is either omitted (when it is found in an object) or censored to null (when it is found in an array).

    0 讨论(0)
  • 2020-12-30 02:02

    yourFunctionName.toString(); will also stringify a function

    0 讨论(0)
提交回复
热议问题