How to redirect a page after an event occurs in NodeJs
In my NodeJs application I want to render a file when a socket IO event occurs.
I am running a distinct socket.io server with python which does some calculation when an event occurs and triggers another return event to NodeJs side. However, redirect operation completes before the return event and page renders without the new data. What I actually want is to apply redirect with the new data 'x' after return event completes.
let x =
app.get("/", function(req, res) {
res.render('home', {'x' : x});
});
app.post("/", function(req, res) {
socket.emit('main event', 'data'); //trigger the main event
res.redirect("/");
})
socket.on('return event', (data) => { //this is the return event
x = data.x;
// I want render to happen after this line
});
Is there any way that I can do the render operation not in express events and maybe in socket.io callback or maybe a blocking call that waits the event to complete?
node.js express socket.io ejs
add a comment |
In my NodeJs application I want to render a file when a socket IO event occurs.
I am running a distinct socket.io server with python which does some calculation when an event occurs and triggers another return event to NodeJs side. However, redirect operation completes before the return event and page renders without the new data. What I actually want is to apply redirect with the new data 'x' after return event completes.
let x =
app.get("/", function(req, res) {
res.render('home', {'x' : x});
});
app.post("/", function(req, res) {
socket.emit('main event', 'data'); //trigger the main event
res.redirect("/");
})
socket.on('return event', (data) => { //this is the return event
x = data.x;
// I want render to happen after this line
});
Is there any way that I can do the render operation not in express events and maybe in socket.io callback or maybe a blocking call that waits the event to complete?
node.js express socket.io ejs
1
Hi, you can for exemple execute a promise in your main action, and only render the view after it's complete....
– Pimento Web
Jan 1 at 22:15
add a comment |
In my NodeJs application I want to render a file when a socket IO event occurs.
I am running a distinct socket.io server with python which does some calculation when an event occurs and triggers another return event to NodeJs side. However, redirect operation completes before the return event and page renders without the new data. What I actually want is to apply redirect with the new data 'x' after return event completes.
let x =
app.get("/", function(req, res) {
res.render('home', {'x' : x});
});
app.post("/", function(req, res) {
socket.emit('main event', 'data'); //trigger the main event
res.redirect("/");
})
socket.on('return event', (data) => { //this is the return event
x = data.x;
// I want render to happen after this line
});
Is there any way that I can do the render operation not in express events and maybe in socket.io callback or maybe a blocking call that waits the event to complete?
node.js express socket.io ejs
In my NodeJs application I want to render a file when a socket IO event occurs.
I am running a distinct socket.io server with python which does some calculation when an event occurs and triggers another return event to NodeJs side. However, redirect operation completes before the return event and page renders without the new data. What I actually want is to apply redirect with the new data 'x' after return event completes.
let x =
app.get("/", function(req, res) {
res.render('home', {'x' : x});
});
app.post("/", function(req, res) {
socket.emit('main event', 'data'); //trigger the main event
res.redirect("/");
})
socket.on('return event', (data) => { //this is the return event
x = data.x;
// I want render to happen after this line
});
Is there any way that I can do the render operation not in express events and maybe in socket.io callback or maybe a blocking call that waits the event to complete?
node.js express socket.io ejs
node.js express socket.io ejs
asked Jan 1 at 21:14
barkın evginbarkın evgin
715
715
1
Hi, you can for exemple execute a promise in your main action, and only render the view after it's complete....
– Pimento Web
Jan 1 at 22:15
add a comment |
1
Hi, you can for exemple execute a promise in your main action, and only render the view after it's complete....
– Pimento Web
Jan 1 at 22:15
1
1
Hi, you can for exemple execute a promise in your main action, and only render the view after it's complete....
– Pimento Web
Jan 1 at 22:15
Hi, you can for exemple execute a promise in your main action, and only render the view after it's complete....
– Pimento Web
Jan 1 at 22:15
add a comment |
2 Answers
2
active
oldest
votes
Add res.redirect
to acknowledgment callback in socket.emit
.
app.post("/", function(req, res) {
socket.emit('main event', 'data', function(err, msg) {
if(err) throw new Error(err);
res.redirect("/");
});
});
add a comment |
Thank you for all your answers. What I actually needed was to put the socket.on event into the app.post like this.
app.post("/", function(req, res) {
socket.on('return event', (data) => {
x = data.x;
res.redirect("/");
});
socket.emit('main event', 'data');
})
Promises was also a good suggestion and thank you for all your answers again
add a comment |
Your Answer
StackExchange.ifUsing("editor", function () {
StackExchange.using("externalEditor", function () {
StackExchange.using("snippets", function () {
StackExchange.snippets.init();
});
});
}, "code-snippets");
StackExchange.ready(function() {
var channelOptions = {
tags: "".split(" "),
id: "1"
};
initTagRenderer("".split(" "), "".split(" "), channelOptions);
StackExchange.using("externalEditor", function() {
// Have to fire editor after snippets, if snippets enabled
if (StackExchange.settings.snippets.snippetsEnabled) {
StackExchange.using("snippets", function() {
createEditor();
});
}
else {
createEditor();
}
});
function createEditor() {
StackExchange.prepareEditor({
heartbeatType: 'answer',
autoActivateHeartbeat: false,
convertImagesToLinks: true,
noModals: true,
showLowRepImageUploadWarning: true,
reputationToPostImages: 10,
bindNavPrevention: true,
postfix: "",
imageUploader: {
brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
allowUrls: true
},
onDemand: true,
discardSelector: ".discard-answer"
,immediatelyShowMarkdownHelp:true
});
}
});
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53998992%2fhow-to-redirect-a-page-after-an-event-occurs-in-nodejs%23new-answer', 'question_page');
}
);
Post as a guest
Required, but never shown
2 Answers
2
active
oldest
votes
2 Answers
2
active
oldest
votes
active
oldest
votes
active
oldest
votes
Add res.redirect
to acknowledgment callback in socket.emit
.
app.post("/", function(req, res) {
socket.emit('main event', 'data', function(err, msg) {
if(err) throw new Error(err);
res.redirect("/");
});
});
add a comment |
Add res.redirect
to acknowledgment callback in socket.emit
.
app.post("/", function(req, res) {
socket.emit('main event', 'data', function(err, msg) {
if(err) throw new Error(err);
res.redirect("/");
});
});
add a comment |
Add res.redirect
to acknowledgment callback in socket.emit
.
app.post("/", function(req, res) {
socket.emit('main event', 'data', function(err, msg) {
if(err) throw new Error(err);
res.redirect("/");
});
});
Add res.redirect
to acknowledgment callback in socket.emit
.
app.post("/", function(req, res) {
socket.emit('main event', 'data', function(err, msg) {
if(err) throw new Error(err);
res.redirect("/");
});
});
answered Jan 2 at 5:45
Rajika ImalRajika Imal
163312
163312
add a comment |
add a comment |
Thank you for all your answers. What I actually needed was to put the socket.on event into the app.post like this.
app.post("/", function(req, res) {
socket.on('return event', (data) => {
x = data.x;
res.redirect("/");
});
socket.emit('main event', 'data');
})
Promises was also a good suggestion and thank you for all your answers again
add a comment |
Thank you for all your answers. What I actually needed was to put the socket.on event into the app.post like this.
app.post("/", function(req, res) {
socket.on('return event', (data) => {
x = data.x;
res.redirect("/");
});
socket.emit('main event', 'data');
})
Promises was also a good suggestion and thank you for all your answers again
add a comment |
Thank you for all your answers. What I actually needed was to put the socket.on event into the app.post like this.
app.post("/", function(req, res) {
socket.on('return event', (data) => {
x = data.x;
res.redirect("/");
});
socket.emit('main event', 'data');
})
Promises was also a good suggestion and thank you for all your answers again
Thank you for all your answers. What I actually needed was to put the socket.on event into the app.post like this.
app.post("/", function(req, res) {
socket.on('return event', (data) => {
x = data.x;
res.redirect("/");
});
socket.emit('main event', 'data');
})
Promises was also a good suggestion and thank you for all your answers again
answered Jan 2 at 15:58
barkın evginbarkın evgin
715
715
add a comment |
add a comment |
Thanks for contributing an answer to Stack Overflow!
- Please be sure to answer the question. Provide details and share your research!
But avoid …
- Asking for help, clarification, or responding to other answers.
- Making statements based on opinion; back them up with references or personal experience.
To learn more, see our tips on writing great answers.
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53998992%2fhow-to-redirect-a-page-after-an-event-occurs-in-nodejs%23new-answer', 'question_page');
}
);
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
1
Hi, you can for exemple execute a promise in your main action, and only render the view after it's complete....
– Pimento Web
Jan 1 at 22:15