2013-04-30 92 views
14

渲染JSON對象在玉和循環當我發送一個JSON字符串到玉文件撕心裂肺,我只能夠通過它的元素打印出字符串在它的全部,但不是。如何打印出特定元素或通過JSON字符串循環?如何通過結果

app.js:

var http = require('http'), 
    express = require('express'), 
    net  = require('net'); 

var app = express(); 

app.set('views', __dirname + '/views'); 
app.set('view engine', 'jade'); 
app.use(express.logger('dev')); 
app.use(express.static(__dirname + '/public')); 

app.get('/', function (req, res) { 
    var json_string = {"action":"date +%s","result":"1367263074"}; 
    res.render('index', { layout : 'layout', json: JSON.stringify(json_string) }); 
}) 
app.listen(3000); 

layout.jade:

!!!5 
html 
head 
    body 
    p !{json} 
    p !{json.result} 
    p --- 
    each val, key in json 
    p #{key}: #{val} 

預期輸出:

{"action":"date +%s","result":"1367263074"} 
1367263074 
--- 
action: date +%s 
result: 1367263074 

實際輸出:

{"action":"date +%s","result":"1367263074"} 

--- 
0: { 
1: " 
2: a 
3: c 
4: t 
5: i 
6: o 
7: n 
8: " 
9: : 
10: " 
11: d 
12: a 
13: t 
14: e 
15: 
16: + 
17: % 
18: s 
19: " 
20: , 
21: " 
22: r 
23: e 
24: s 
25: u 
26: l 
27: t 
28: " 
29: : 
30: " 
31: 1 
32: 3 
33: 6 
34: 7 
35: 2 
36: 6 
37: 3 
38: 0 
39: 7 
40: 4 
41: " 
42: } 

回答

16

你爲什麼要傳遞一個字符串?試試這個:

var ob = { action:"date +%s", result:"1367263074"}; 
res.render('index', { layout : 'layout', json: ob }); 

還是做到這一點:

-var ob = JSON.parse(json) 
-for(var prop in ob) 
p #{prop}: #{ob[prop]} 
7

在此行中:each val, key in json 你先字符串化你的JS對象(服務器端),不字符串化是把它作爲目標。

所以這行:

res.render('index', { layout : 'layout', json: JSON.stringify(json_string) }); 

成爲

res.render('index', { layout : 'layout', json: json_string }); 
2

如果您正在尋找遍歷的行爲和結果的數組,然後使用馬修阿米奧特的建議,加上這段代碼:

each key in json 
    p !{key.action} !{key.result}