JS對象轉字符串的幾種方法

一、JSON.stringify方法

JSON.stringify方法是將一個javascript對象或值轉換成為一個 JSON字符串。

使用方法如下:

  var obj = {
    name: 'Tom',
    age: 18,
    grade: {
      math: 90,
      english: 95
    },
    hobbies: ['reading', 'music']
  };
  var str = JSON.stringify(obj);
  console.log(str);

執行結果為:

  {"name":"Tom","age":18,"grade":{"math":90,"english":95},"hobbies":["reading","music"]}

json字符串還可以通過JSON.parse方法轉換成js對象

代碼如下:

  var obj = JSON.parse(str);
  console.log(obj);

執行結果為:

  {name: "Tom", age: 18, grade: {…}, hobbies: Array(2)}

二、Function方法

Function是js中的一個對象,它有一個toSource方法,可以把一個Function對象轉換成js代碼。如果把對象通過toSource方法轉為代碼,並去掉function(…)(){…}里的function和(),就可以得到這個對象的代碼形式。

使用方法如下:

  var obj = {
    name: 'Tom',
    age: 18,
    grade: {
      math: 90,
      english: 95
    },
    hobbies: ['reading', 'music']
  };
  var str = (function(){return this;}).call(obj).toSource();
  console.log(str);

執行結果為:

  ({name:"Tom",age:18,grade:{math:90,english:95},hobbies:["reading","music"]})

三、eval方法

eval方法可以執行一段字符串形式的js代碼,把一個js對象轉換成一個可執行的js字符串,所以可以用eval方法直接把一個對象轉換成一個字符串。

使用方法如下:

  var obj = {
    name: 'Tom',
    age: 18,
    grade: {
      math: 90,
      english: 95
    },
    hobbies: ['reading', 'music']
  };
  var str = eval('(' + JSON.stringify(obj) + ')');
  console.log(str);

執行結果為:

  {name: "Tom", age: 18, grade: {…}, hobbies: Array(2)}

四、toString方法

toString方法是Object對象的一個原型方法,可以將一個對象轉換成字符串。但是這個方法只能將一個對象轉換成”[object Object]”這種基本形式的字符串。

我們可以通過重寫Object對象的toString方法來實現對象轉字符串。

使用方法如下:

  Object.prototype.toString = function(){
    return JSON.stringify(this);
  }
  var obj = {
    name: 'Tom',
    age: 18,
    grade: {
      math: 90,
      english: 95
    },
    hobbies: ['reading', 'music']
  };
  console.log(obj.toString());

執行結果為:

  {"name":"Tom","age":18,"grade":{"math":90,"english":95},"hobbies":["reading","music"]}

五、自定義方法

我們也可以通過自定義實現將一個js對象轉換成字符串。

示例代碼如下:

  function obj2str(obj, len){
    var ndeep = len || 1;
    var gap = ''; 
    var indent = ''; 
    var i = 0; 
    for(i = 0; i  1 ? '\n' : '';
    if(typeof obj === 'object')
    { 
      var str = '';
      if(obj.constructor === Array)
      { 
        for(i = 0; i < obj.length; i++)
        {
          str += gap + indent + obj2str(obj[i], ndeep + 1) + ', ';
        }
        return '[' + str.slice(0, -2) + '\n' + indent + ']';
      }
      else
      {
        for(var prop in obj)
        {
          str += gap + indent + '"' + prop + '": ';
          if(typeof obj[prop] === 'object')
          {
            str += obj2str(obj[prop], ndeep + 1) + ', ';
          }
          else if(typeof obj[prop] === 'function')
          {
            str += 'undefined' + ', ';
          }
          else
          {
            str += '"' + obj[prop] + '", ';
          }
        }
        return '{' + str.slice(0, -2) + '\n' + indent + '}';
      }
    } 
    else
    { 
      if(typeof obj === 'string')
      {
        obj = '"' + obj + '"';
      }
      return String(obj);
    }
  }

  var obj = {
    name: 'Tom',
    age: 18,
    grade: {
      math: 90,
      english: 95
    },
    hobbies: ['reading', 'music']
  };

  var str = obj2str(obj);
  console.log(str);

執行結果為:

  {
   "name": "Tom", 
   "age": "18", 
   "grade": {
    "math": "90", 
    "english": "95"
   }, 
   "hobbies": [
    "reading", 
    "music"
   ]
  }

六、總結

以上是JS對象轉字符串的幾種方法,可以根據實際需要進行選擇。需要注意的是,Function和eval方法存在安全問題,建議不要在生產環境中使用。

原創文章,作者:QQPMI,如若轉載,請註明出處:https://www.506064.com/zh-hant/n/362022.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
QQPMI的頭像QQPMI
上一篇 2025-02-25 18:17
下一篇 2025-02-25 18:17

相關推薦

發表回復

登錄後才能評論