麻豆黑色丝袜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
主站蜘蛛池模板: 动漫成人在线| 欧美美女被艹| 正在播放宾馆露脸对白视频| stoya在线观看| 天天想你在线视频免费观看| 欧美三级电影免费| 宝宝才三根手指头就湿成这样| 久久精品国产99精品最新| 在公交车上被站着被c| 亚洲国产综合专区在线电影| 免费人成在线观看网站| 免费阿v| 国产无套护士丝袜在线观看| 97se色综合一区二区二区| 奶水哺乳理论电影| 又爽又黄又无遮挡的视频在线观看| 天使萌一区二区在线观看| 最好看的免费观看视频| 欧美在线不卡| 波多野吉衣视频| 三级黄色在线观看| 日本电影二区| 亚洲二区电影| 亚洲日产2021三区| 红字电影| 好妈妈5韩国电影高清中字| 深夜福利gif动态图158期| 秋霞日韩一区二区三区在线观看| 亚洲成a人片在线观| 久久久久久亚洲精品中文字幕| 热久久精品免费视频| 波多野结衣波多野结衣| 国产精品素人福利| 成年片人免费www| 国产精品多p对白交换绿帽| 男人边摸边吃奶边做下面| 国产欧美日韩中文久久| 全免费a级毛片免费看| 扒开老师的蕾丝内裤漫画| 天堂亚洲国产日韩在线看| 久久久久亚洲精品中文字幕|