摘要:項(xiàng)目需要,簡單的提了個(gè)思路,將對象轉(zhuǎn)換為顯示聲明形式的字符串例如對象聲明可以采用形式,所以,采用此格式存儲對象,可以用方法,直接轉(zhuǎn)換為對象。未處理字符轉(zhuǎn)意,對象屬性可能包含與描述沖突的字符如等。
隨著更多語言的支持 json 作為數(shù)據(jù)傳輸和存儲的媒體,已經(jīng)非常成熟且應(yīng)用廣泛。
卻存在致命硬傷,不攜帶 對象方法 。在數(shù)據(jù)傳輸和存儲中,這是恰當(dāng)?shù)暮秃侠淼摹?/p>
但是在更多的應(yīng)用場景中,又是無奈的。
項(xiàng)目需要,簡單的提了個(gè)思路,將對象轉(zhuǎn)換為顯示聲明形式的字符串
例如:
var person = { name:"joe", age:40, send:function(){ console.log("hello world") } }
對象聲明可以采用{...}形式,所以,采用此格式存儲對象,可以用eval()方法,直接轉(zhuǎn)換為對象。
簡單寫了一個(gè),大概思路如此:
function o2s(o){ var r = [] for(p in o){ if(typeof o[p] == "string"){ r.push((Array.isArray(o)?""": p + ":"") + o[p] + """) }else if(typeof o[p] == "object"){ r.push((Array.isArray(o)?"":p + ":" )+ o2s(o[p])) }else{ r.push((Array.isArray(o)?"":p + ":") + o[p] ) } } r = r.join(",") if(Array.isArray(o)){ return "[" + r + "]" }else if(typeof o == "object"){ return "{" + r + "}" }else{ return r } }
捎帶一句,稍微修改即可深拷貝
存在幾個(gè)問題,
1.無法處理循環(huán)引用的對象,也就是自己包含自己,或者包含了包含自己的對象的時(shí)候。
2.未處理字符轉(zhuǎn)意,對象屬性可能包含與描述沖突的字符如“”等。
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://m.hztianpu.com/yun/99799.html
摘要:同源策略同源策略是一種約定,由公司年引入瀏覽器,它是瀏覽器最核心也最基本的安全功能,如果缺少了同源策略,瀏覽器很容易受到等攻擊。 一、Vue變化檢測 背景 初始化對象,屬性未知;某些事件觸發(fā)時(shí),對象改變(新增屬性),Vue監(jiān)聽不到 原因 Vue.js 不能檢測到對象屬性的添加或刪除,因?yàn)閂ue.js 在初始化實(shí)例時(shí)將屬性轉(zhuǎn)為 getter/setter,所以屬性必須在 dat...
摘要:類似的情況還有,方法和方法等。今天我說一個(gè)最簡單。代碼如下和也可以實(shí)現(xiàn),但是生成的是一個(gè)整數(shù),如下分割線其它類型數(shù)據(jù)轉(zhuǎn)布爾數(shù)據(jù)下面的轉(zhuǎn)換,大家一看就明白了,不多說。緩存變量循環(huán)緩存分割線第一段就是每一次循環(huán)的時(shí)候,都要查詢一次。 1.前言 從大學(xué)到現(xiàn)在,接觸前端已經(jīng)有幾年了,感想方面,就是對于程序員而言,想要提高自己的技術(shù)水平和編寫易于閱讀和維護(hù)的代碼,我覺得不能每天都是平庸的寫代碼,...
摘要:舉個(gè)例子來說明一下什么是淺拷貝什么是深拷貝淺拷貝得出的結(jié)果可以看出是淺拷貝非對象的屬性值一個(gè)改變不影響另一個(gè)的值對象屬性是引用賦值所以一個(gè)改變會影響另一個(gè)的改變出現(xiàn)這種情況的本質(zhì)是對象是按引用賦值的深拷貝指的是拷貝一個(gè)對象,改變一個(gè)值不影響 舉個(gè)例子來說明一下什么是淺拷貝什么是深拷貝 淺拷貝 var x = { a: 1, b: {f: { g: 1 ...
閱讀 2532·2023-04-25 14:17
閱讀 1707·2021-11-23 10:02
閱讀 2350·2021-11-23 09:51
閱讀 1044·2021-10-14 09:49
閱讀 3560·2021-10-11 10:57
閱讀 3073·2021-09-24 09:47
閱讀 3209·2021-08-24 10:00
閱讀 2455·2019-08-29 18:46