麻豆黑色丝袜jk制服福利网站-麻豆精品传媒视频观看-麻豆精品传媒一二三区在线视频-麻豆精选传媒4区2021-在线视频99-在线视频a

千鋒教育-做有情懷、有良心、有品質的職業教育機構

手機站
千鋒教育

千鋒學習站 | 隨時隨地免費學

千鋒教育

掃一掃進入千鋒手機站

領取全套視頻
千鋒教育

關注千鋒學習站小程序
隨時隨地免費學習課程

當前位置:首頁  >  技術干貨  > JS對象轉字符串的幾種方法

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

來源:千鋒教育
發布人:xqq
時間: 2023-11-23 00:03:12 1700668992

一、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 < ndeep; i++)
    {
      indent += ' ';
    }
    gap = ndeep > 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方法存在安全問題,建議不要在生產環境中使用。

聲明:本站稿件版權均屬千鋒教育所有,未經許可不得擅自轉載。
10年以上業內強師集結,手把手帶你蛻變精英
請您保持通訊暢通,專屬學習老師24小時內將與您1V1溝通
免費領取
今日已有369人領取成功
劉同學 138****2860 剛剛成功領取
王同學 131****2015 剛剛成功領取
張同學 133****4652 剛剛成功領取
李同學 135****8607 剛剛成功領取
楊同學 132****5667 剛剛成功領取
岳同學 134****6652 剛剛成功領取
梁同學 157****2950 剛剛成功領取
劉同學 189****1015 剛剛成功領取
張同學 155****4678 剛剛成功領取
鄒同學 139****2907 剛剛成功領取
董同學 138****2867 剛剛成功領取
周同學 136****3602 剛剛成功領取
相關推薦HOT
主站蜘蛛池模板: 又黄又粗又爽免费观看| 伊人影院在线播放| 黑人性片| 日韩特黄| 欧美xxx高清| 国产成品精品午夜视频| 亚洲国产视频网| 伦理一区二区三区| 99视频免费观看| 国产自产2023最新麻豆| 日韩欧美一区二区三区免费观看| 99久久国产综合精品麻豆| 精品无码久久久久久久动漫| 久久精品a亚洲国产v高清不卡| 99久久精品国产综合一区| 欧美日韩久久中文字幕| 在线免费观看你懂的| avtt在线播放| 又大又湿又紧又爽a视频| 91高端极品外围在线观看| 日韩精品一区二区三区视频 | 久久大香伊人中文字幕| 午夜时刻免费实验区观看| ririai66在线观看视频| 樱花草在线社区www韩国| 水蜜桃视频在线免费观看| zoom和okzoom在线视频| chinese国产xxxx实拍| 成人精品一区二区三区中文字幕| 2019天堂精品视频在线观看| 中文理论片| 久久99精品国产麻豆不卡| 最好看的最新中文字幕2018免费视频| 再深点灬舒服灬太大了岳| 欧美交换乱理伦片120秒| 狠狠色狠狠色综合日日不卡| 五月深爱网| 孩交精品xxxx视频视频| 波多野结衣大片| 国产精品一区二区久久精品涩爱 | 成年男女免费视频网站|