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

javascript eval和JSON之間的聯系

如果您想詳細了解eval和JSON請參考以下鏈接:

eval  :https://developer.mozilla.org/En/Core_JavaScript_1.5_Reference/Global_Functions/Eval

JSON:http://www.json.org/

eval函數的工作原理

eval函數會評估一個給定的含有JavaScript代碼的字符串,并且試圖去執行包含在字符串里的表達式或者一系列的合法的JavaScript語句。eval函數將把最后一個表達式或者語句所包含的值或引用作為返回值。

舉例說明

  • eval評估JavaScript表達式
var bar = 'bar';
var
foobar = eval('"foo" + bar');
alert
(foobar);
  • eval評估JavaScript語句
var bar = 'bar';
// if variable bar equals 'bar', foobar is the result of
// last executing statement: bar="foo-bar";
var
foobar = eval('if(bar == "bar") {bar="foo-bar";} else {bar = "bar-foo";}');
alert
(foobar);// change the valuebar = 'foo';
// now our the last executed statement is: bar = "bar-foo";

// therefore the value of variable foobar has been changed

// into 'bar-foo'

foobar = eval('if(bar == "bar") {bar="foo-bar";} else {bar = "bar-foo";}');
alert
(foobar);

JSON的格式

JSON的格式是由大括號和由冒號(:)構成的名值對所組成的。注意JSON格式與對象字面量 (object literals) 的區別:JSON的名字部分嚴格用引號+名字來表示。

舉例說明

  • 對象的字面量
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/"
}
]
}
;

eval和JSON

由于Ajax的興起,JSON這種輕量級的數據格式作為客戶端與服務器之間的傳輸格式逐漸地流行起來,進而出現的問題是如何將服務器端構建好的JSON數據轉化為可用的JavaScript對象。利用eval函數無疑是一種簡單而直接的方法。在轉化的時候需要將JSON字符串的外面包裝一層圓括號:

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

為什么要加括號?

加上圓括號的目的是迫使eval函數在評估JavaScript代碼的時候強制將括號內的表達式(expression)轉化為對象,而不是作為語句(statement)來執行。舉一個例子,例如對象字面量{},如若不加外層的括號,那么eval會將大括號識別為JavaScript代碼塊的開始和結束標記,那么{}將會被認為是執行了一句空語句。所以下面兩個執行結果是不同的:

alert(eval("{}"); // return undefined
alert
(eval("({})");// return object[Object]

JSON格式的名字部分為什么要加引號?

因為eval函數會將{foo:”bar”}解釋成合法的JavaScript語句,而非表達式。但是人們往往想要的是讓eval將這段代碼解釋成一個對象。所以JSON格式會強制你去在名字的外側加上引號再結合圓括號,這樣eval就不會錯誤的將JSON解釋成代碼塊。

舉例說明

  • eval錯誤解析語義
alert(eval('{foo:"bar"}'));   // return "bar", incorrect
  • eval正確解析JSON
alert(eval('({"foo": "bar"})')); // return JSON object, correct

結論

理解eval的工作原理和json的嚴格的限定格式,合理結合eval和json應用JavaScript的數據傳遞和對象轉換。

following this format:

eval('{' + jsonString + ')');

JavaScript技術javascript eval和JSON之間的聯系,轉載需保留來源!

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

主站蜘蛛池模板: 在线观看永久免费 | 福利视频一区青娱 | 九九热亚洲精品综合视频 | 精品新一区二区三区四区 | 玖玖在线资源 | 国产午夜在线视频 | 精品国产一区二区三区国产馆 | 色婷婷成人网 | 69堂国产成人精品视频不卡 | 久久综久久美利坚合众国 | 小处雏一区二区三区精 | 91亚洲视频在线 | 欧美特黄特刺激a一级淫片 欧美特黄特色aaa大片免费看 | 亚洲精品国产国语 | 亚洲福利秒拍一区二区 | 国产免费播放一区二区三区 | 日本精品视频一区 | 国产69页 | 岬奈一区二区中文字幕 | 九九这里只有精品视频 | 性做久久久久 | 91九色视频在线观看 | 欧美成人亚洲综合精品欧美激情 | 国产精品视频第二区第二页 | 91城中村在线精品 | 亚洲图片小说综合 | 久草中文在线视频 | 国产精品久久新婚兰兰 | 日本欧美一区二区三区视频 | 日本不卡一区二区三区在线观看 | 五月婷婷丁香在线 | 美女又胸大又黄的网站 | 黄色小视频在线观看免费 | 五月婷丁香 | 亚洲精品国产啊女成拍色拍 | 日本高清色惰www在线视频 | se97se成人亚洲网站在线观看 | 香蕉免费一区二区三区在线观看 | 中文字幕一区在线播放 | 国产一区二区三区免费看 | 激情婷婷丁香 |