【问题标题】:passing an array from express to jade client side javascript将数组从express传递到jade客户端javascript
【发布时间】:2013-10-02 03:21:19
【问题描述】:

我有这个玉模板:

html
  head
    script(type="text/javascript" src="https://www.google.com/jsapi")
    script(type='text/javascript')
      google.load("visualization", "1", {packages:["corechart"]});
      google.setOnLoadCallback(drawChart);
      function drawChart() {
      var data = google.visualization.arrayToDataTable([
      ['Date', 'Tin_A' ],

       - each datapoint in myData
            "[" + datapoint.date + "," + datapoint.value + "],"

      ]);
      var options = {
      title: 'bla'
      };
      var chart = new google.visualization.LineChart(document.getElementById('chart_line'));
      chart.draw(data, options);
      }


  body
    h1= title
    #chart_line

我正在使用这个调用来渲染 express/node.js 中的翡翠模板:

app.get('/', function(req, res){
  sensors.findSensorAllData(2, 2, function (error,emps){
        console.log(emps);
        res.render('tmp', {
            title : 'Temperatures in a row',
            myData : emps
        });
    });
});

console.log(emps) 的输出是:

[ { _id: 524b8642028e167fb0e3661d,
    sensor_id: 2,
    value: 49,
    date: Tue Oct 01 2013 20:34:40 GMT-0600 (CST) },
  { _id: 524b863d028e167fb0e3661c,
    sensor_id: 2,
    value: 19,
    date: Tue Oct 01 2013 20:34:35 GMT-0600 (CST) } ]

在渲染发生后,我希望jade 模板中的javascrip 中有值...但是它不起作用。我在纯文本中只得到相同的行,好像- each datapoing in myData 行没有意义......我做错了什么?谢谢

--- 编辑: 如果我更换线路,一切正常

- each datapoint in myData
            "[" + datapoint.date + "," + datapoint.value + "],"

  ['2004',  20],
  ['2005',  30],
  ['2006',  40]

【问题讨论】:

    标签: javascript node.js express pug


    【解决方案1】:

    我认为您可能会因为括号中的引号而意外注入了字符串而不是数组:

    - each datapoint in myData
            "[" + datapoint.date + "," + datapoint.value + "],"
    

    我对 Jade 不是很熟悉,但我认为您可能想要执行以下操作:

    - each datapoint in myData
            [#{datapoint.date}, #{datapoint.value}],
    

    此外,在您提供的有效示例数据中,您仅使用日期的年份部分,但 datapoint.date 属性的内容可能是完整的日期对象,我不确定这是否是什么你想要这个用途。

    【讨论】:

      【解决方案2】:

      请参阅此问题的选择答案,了解您尝试执行的操作为何不起作用。 (JADE + EXPRESS: Iterating over object in inline JS code (client-side)?)

      基本上,只要你点击脚本标签,你就告诉 Jade 解析器以原始形式处理事物,并且不会进行进一步的处理。您真正想要做的是为您的代码重做脚本标记,如下所示:

      - if (typeof(pins) != "object")
      != "<script type='text/javascript'>"
      !=   "google.load('visualization', '1', {packages:['corechart']});
      !=   "google.setOnLoadCallback(drawChart);
      !=   "function drawChart() {
      !=   "var data = google.visualization.arrayToDataTable([
      !=   "['Date', 'Tin_A' ],"
      - forEach datapoint in myData
        !=   "[" + datapoint.date + "," + datapoint.value + "],"
      
      !=   "]);"
      !=   "var options = {"
      !=   "title: 'bla'"
      !=   "};"
      !=   "var chart = new google.visualization.LineChart(document.getElementById('chart_line'));"
      !=   "chart.draw(data, options);"
      !=   "}"
      

      试试这个,但我很确定它应该可以工作。

      PS:上面的链接也(我相信)清楚地说明了为什么前面的答案应该是不正确的,因为你不能在 Jade 脚本标签中使用那种模板占位符插值。

      【讨论】:

      • 感谢您的回答。很高兴得知翡翠在脚本标签中采用原始形式。我将使用这些信息来寻找解决方案。另一件事,您的示例中的!= 是什么意思?
      • @otmezger 查看Jade language reference,在“缓冲代码”/“无缓冲代码”部分下 - 您会看到解释/代码 sn-ps 显示这些运算符的操作。
      【解决方案3】:

      丑陋的警报:

      script
        ...
        var data = google.visualization.arrayToDataTable(['Date', 'Tin_A' ].concat(!{JSON.stringify(myData.map(function(i) { return [ i.date, i.value ] })) }));
      

      【讨论】:

        猜你喜欢
        • 2015-03-03
        • 1970-01-01
        • 2016-06-17
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 2018-06-18
        • 2017-08-26
        • 2018-11-02
        相关资源
        最近更新 更多