Accessing Ejs Variable In Javascript Logic
Solution 1:
You could directly inject the gameState variable into javascript on the page.
<% if (gameState) { %>
<h2>I have a game state!</h2><script>var clientGameState = <%= gameState %>
</script>
<% } %>
Another option might be to make an AJAX call back to the server once the page has already loaded, return the gameState JSON, and set clientGameState to the JSON response.
You may also be interested in this: How can I share code between Node.js and the browser?
Solution 2:
I had the same problem. I needed to use the data not for just rendering the page, but in my js script. Because the page is just string when rendered, you have to turn the data in a string, then parse it again in js. In my case my data was a JSON array, so:
<script>var test = '<%- JSON.stringify(sampleJsonData) %>'; // test is now a valid js object</script>
Single quotes are there to not be mixed with double-quotes of stringify. Also from ejs docs:
"<%- Outputs the unescaped value into the template"
The same can be done for arrays. Just concat the array then split again.
Solution 3:
I feel that the below logic is better and it worked for me.
Assume the variable passed to the ejs page is uid
, you can have the contents of the div
tag or a h
tag with the variable passed. You can access the contents of the div or h
tag in the script and assign it to a variable.
code sample below : (in ejs)
<scripttype="text/javascript">
$(document).ready(function() {
var x = $("#uid").html();
alert(x); // now JS variable 'x' has the uid that's passed from the node backend.
});
</script><h2style="display:none;"id="uid"><%=uid %></h2>
Solution 4:
In the EJS template: ex:- testing.ejs
<html><!-- content --><script>// stringify the data passed from router to ejs (within the EJS template only)var parsed_data = <%- JSON.stringify(data) %>
</script></html>
In the Server side script: ex: Router.js
res.render('/testing', {
data: data// any data to be passed to ejs template
});
In the linked js (or jquery) script file: ex:- script.js In JavaScript:
console.log(parsed_data)
In JQuery:
$(document).ready(function(){
console.log(parsed_data)
});
Note: 1. user - instead of = in <% %> tag 2. you can't declare or use data passed from router to view directly into the linked javascript or jquery script file directly. 3. declare the <% %> in the EJS template only and use it any linked script file.
I'm not sure but I've found it to be the best practice to use passed data from router to view in a script file or script tag.
Solution 5:
This works for me.
// bar chart datavar label = '<%- JSON.stringify(bowlers) %>';
var dataset = '<%- JSON.stringify(data) %>';
var barData = {
labels: JSON.parse(label),
datasets: JSON.parse(dataset)
}
Post a Comment for "Accessing Ejs Variable In Javascript Logic"