一区二区久久-一区二区三区www-一区二区三区久久-一区二区三区久久精品-麻豆国产一区二区在线观看-麻豆国产视频

JSON 和 JavaScript eval使用說明

JSON 格式可以使對象(object)、數(shù)組(array)、值(value)、字符串(string)、數(shù)值(number)。
復制代碼 代碼如下:
<script type="text/Javascript">
var user = {
"Name":"Andy",
"Sex" :"man",
"Age" :"20",
"Phone":{"mobilephone":"123456789","telephone":"1234-12345678"},
"baby":[{"big":"xiaohong"},{"middle":"xiaoming"},{"small":"xiaoli"}] //包含數(shù)組
}
alert(user.Name);
alert(user.Phone.mobilephone);
alert(user.baby[0].big);
user.baby[0].big = "--";//修改了 JSON 值
alert(user.baby[0].big);
</script>

參考:http://www.json.org/json-zh.html



  下面來看看 JavaScript 的 eval 函數(shù)。
  eval 函數(shù)會評估給定的一個JavaScript代碼的字符串,并試圖去執(zhí)行包含在字符串里的表達式或者一系列的合法的 JavaScript 語句。eval 函數(shù)將把最后一個表達式或者語句包含的值或引用作為返回值。

代碼
復制代碼 代碼如下:
<script type="text/Javascript">
var bar = "bar";
var foobar = eval('"foo"+bar');
alert(bar + foobar);//執(zhí)行語句
foobar = eval('if(bar = "bar"){bar = "foo-bar";}else{bar = "bar-foo";}');
alert(foobar);//返回語句中包含的值
</script>

  JSON 和 對象字面量(Object Literals)的區(qū)別:JSON 的名字部分嚴格用引號+名字來表示。
代碼
復制代碼 代碼如下:
<script type="text/Javascript">
//對象字面量
var objectLiteral = {
name:"Objector.L",
age:"24",
special:"JavaScript",
sayName:function(){
return this.name;
}
};
//JSON 對象
var jsonFormat = {
"summary":"Blogs",
"blogrolls":[
{
"title":"Explore JavaScript",
"link":"http://example.com"
},
{
"title":"Explore JavaScript",
"link":"http://example.com"
}
]
};
</script>

  由于 Ajax 的興起, JSON 這種輕量級的數(shù)據(jù)格式作為客戶端與服務器端之間傳輸?shù)母袷街饾u流行起來,進而出現(xiàn)的問題是如何將服務器端構(gòu)建好的 JSON 數(shù)據(jù)轉(zhuǎn)換為可用的 JavaScript 對象,利用 eval 函數(shù)無疑是一種簡單而直接的方法。在轉(zhuǎn)化的時候需要將 JSON 字符串的外面包裝一層園括號:

var jsonObject = eval("("+ jsonFormat +")")

  加園括號的目的是迫使 eval 函數(shù)在評估 JavaScript 代碼的時候強制將括號內(nèi)的表達式(expression)轉(zhuǎn)換為對象,而不是作為語句(statement)來執(zhí)行。舉一個例子,例如對象字面量{},如若不佳加外層的括號,那么eval會將大括號之別為JavaScript代碼塊的開始結(jié)束標記機,那么{}將被認為是執(zhí)行了一句空語句。所以下面兩個執(zhí)行結(jié)果是不同的:


復制代碼 代碼如下:
alert(eval("{}")); //return undefined
alert(eval("({})")); //return [object Object]

  JSON 格式的名字部分為什么要加引號?因為eval函數(shù)會將{foo:"bar"}解釋成合法的JavaScript 語句,而非表達式。但人們往往是想讓eval將這段代碼解釋成一個對象。所以JSON 格式會強制你去在名字的外側(cè)加上引號,再結(jié)合圓括號,eval就不會錯誤的將JSON解釋成代碼塊。
  
復制代碼 代碼如下:
//eval 錯誤解析語義
alert(eval('{foo:"bar"}')); //return "bar",incorrect
//eval 正確解析JSON
alert(eval('({"foo":"bar"})'));//return JSON object,correct

JavaScript技術(shù)JSON 和 JavaScript eval使用說明,轉(zhuǎn)載需保留來源!

鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯(lián)系我們修改或刪除,多謝。

主站蜘蛛池模板: 加勒比在线 | 女人被爽到呻吟娇喘的视频动态图 | 日本伊人精品一区二区三区 | 亚洲日本一区二区三区高清在线 | 久久精选视频 | 色网站免费在线观看 | 久久婷婷六月 | 国产精品欧美亚洲韩国日本不卡 | 521香蕉永久播放地址 | 国产精品视频99 | 视频一区 国产 | 久久久久99| 国产小视频在线观看免费 | 丁香婷婷综合五月综合色啪 | 日本妇人成熟免费 | 久热99这里只有精品视频6 | 久久综合加勒比 | 亚洲综合激情视频 | 成人午夜视频在线播放 | 国产精品久久国产精麻豆99网站 | 在线精品免费视频 | 亚洲国产香蕉视频欧美 | 91久久综合精品国产丝袜长腿 | 国内精品视频在线观看 | 日本乱理伦中文三区 | 国产福利合集 | 久久最新精品 | 加勒比久久综合 | 图片专区亚洲 欧美 另类 | 91精品国产自产在线观看 | 国产成人精品cao在线 | 九月丁香十月婷婷在线观看 | 91在线播放国产 | 成年女人免费v片 | 婷婷开心激情网 | 久久精品国产一区二区三区肥胖 | 精品久久久一二三区 | 在线激情网址 | 国产91久久精品一区二区 | 91精品国产综合久久久久久 | 亚州视频一区二区 |