简体   繁体   English

将数据从 data.json 文件解析为 index.ejs (expressJS)

[英]Parse data into index.ejs from data.json file (expressJS)

I'm trying to parse data from my data.json file, I want to store all the data for the site in this json file and parse the data to my index.ejs file.我正在尝试从我的 data.json 文件中解析数据,我想将站点的所有数据存储在这个 json 文件中,并将数据解析到我的 index.ejs 文件中。 Below is a snippet of my index.ejs file, my app.js (file used for set up) and my data.json file.下面是我的 index.ejs 文件、我的 app.js(用于设置的文件)和我的 data.json 文件的片段。

HTML Snippet(index.ejs) HTML 片段(index.ejs)

<ul class="menu-list">
    <li><%= data.menu.title %></li>
</ul>

Json file (data.json) JSON 文件 (data.json)

{
 "data": {
    "menu": [
        {
            "title": "Home",
            "link": ""
        },
        {
            "title": "Contact",
            "link": ""
        }
     ]
  }
}

Set up file (app.js)设置文件 (app.js)

  var createError = require('http-errors');
  var express = require('express');
  var path = require('path');
  var cookieParser = require('cookie-parser');
  var logger = require('morgan');
  var sassMiddleware = require('node-sass-middleware');

  var indexRouter = require('./routes/index');
  var usersRouter = require('./routes/users');

  var app = express();

// view engine setup
app.set('views', path.join(__dirname, 'views'));
app.set('view engine', 'ejs');

app.use(logger('dev'));
app.use(express.json());
app.use(express.urlencoded({ extended: false }));
app.use(cookieParser());

// compiling sass files
app.use(sassMiddleware({
 src: path.join(__dirname, 'public/stylesheets/scss'),
 dest: path.join(__dirname, 'public/stylesheets'),
 debug: true,
 outputStyle: 'compressed',
 prefix: '/stylesheets'
}));

app.use('/public', express.static(path.join(__dirname, 'public')));

app.use('/', indexRouter);
app.use('/users', usersRouter);

// catch 404 and forward to error handler
app.use(function(req, res, next) {
 next(createError(404));
});

// error handler
app.use(function(err, req, res, next) {
 // set locals, only providing error in development
 res.locals.message = err.message;
 res.locals.error = req.app.get('env') === 'development' ? err : {};

 // render the error page
 res.status(err.status || 500);
 res.render('error');
});


module.exports = app;

Forgive my indentation- putting it in was weird.原谅我的缩进——把它放进去很奇怪。 All files are on the same level.所有文件都在同一级别。

For your example replace <li><%= data.menu.title %></li> with <li><%= data.menu[0].title %></li> because menu is array not single data Sample Data对于您的示例,将<li><%= data.menu.title %></li>替换为<li><%= data.menu[0].title %></li>因为菜单是数组而不是单个数据样本数据

var data = 
     {"data": {
        "menu": [
            {
                "title": "Home",
                "link": ""
            },
            {
                "title": "Contact",
                "link": ""
            }
         ]
      } };

Ejs Code Ejs代码

 <ul class="menu-list">



<% for(var i=0; i < data.data.menu.length; i++) { %>

    <li><%= data.data.menu[i].title %></li>

<% } %>

  </ul>

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM