当底层数据模型发生变化时,我想要重新加载浏览器页面:
var request = require('request');
var express = require('express');
var app = express();
var bodyParser = require('body-parser');
app.set('view engine', 'ejs');
app.use(bodyParser.urlencoded({ extended: false }));
var requests;
app.get('/', function(req, res) {
res.render('index', {
requests: requests
});
});
app.listen(3000);
...以及当请求数据模型发生变化时:
request.get('localhost:3000/', function(error, response, body) {
console.log(body);
});
但是我的浏览器页面不会自动刷新,除非我手动用鼠标点击刷新按钮。我错过了什么吗?
编辑:这是我的index.ejs代码:
<!DOCTYPE html>
<html>
<ul>
<% requests.forEach(function(match) { %>
<form action="/acceptRequest" method="post" enctype="application/x-www-form-urlencoded">
<input type="text" name="id" value="<%= match.id %>">
<input type="text" name="fighter1" value="<%= match.fighter1 %>"> vs.
<input type="text" name="fighter2" value="<%= match.fighter2 %>"> on
<input type="text" name="fightdate" value="<%= match.date %>"> in
<input type="text" name="rounds" value="">
<input type="submit" value="Submit">
</form>
<br>
<% }); %>
</ul>
</html>
request.get()
请求了一个页面,但没有对内容做任何处理。如果你想让浏览器重新加载当前页面,可以直接使用window.reload()
。或者你可以通过 Ajax 获取更新的内容,然后自己将内容插入到 DOM 中。 - jfriend00/acceptRequest
提交表单吗?还是在某个地方进行Ajax调用?或者其他什么? - jfriend00