麻豆黑色丝袜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
主站蜘蛛池模板: 7777精品久久久大香线蕉| 国产老师的丝袜在线看| 黄色大片播放| 欧美特黄一片aa大片免费看| 精品国产麻豆| 极品丝袜乱系列在线阅读| 欧美八十老太另类| 特级大片| 4480yy私人影院论| 日本高清免费不卡视频| 特a级片| 国内自产拍自a免费毛片| 嫩草影院在线免费观看| 日韩欧美在线观看视频| 小婷的性放荡日记h交| 四虎永久免费地址ww484e5566| 国产福利第一视频| 亚洲午夜久久久久久尤物| 天天操夜夜操| 风间由美juy135在线观看| 啊啊深一点| 嗯~啊太紧了妖精h| 亚洲一区二区三区在线 | 大学寝室沈樵无删减| 污污免费在线观看| 好吊妞视频在线观看| 国产a级毛片| 涩涩快播| 女人张腿让男人捅| 国产精品一区二区久久精品涩爱| 卡一卡二卡三精品| yy6080午夜一级毛片超清| 444kkk视频在线观看国产| 天天躁日日躁狠狠躁| 稚嫩娇小哭叫粗大撑破h| 日韩成人在线网站| 第四色最新网站| a级毛片视频免费观看| 久久久噜噜噜久久中文字幕色伊伊| 含羞草实验室入口免费网站直接| 在线观看中文字幕码2023|