[英]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.