'Pass Rails JSON variable to javascript variable
I have a Global JSON variable in my Ruby on Rails controller. It looks like this @rails_side_json = { :name => 'Will', :age => 23 }.to_json
I want this to be assigned to my javascript variable (var javascript_side_json) which resides in my javascript file named custom.js.erb
The value in javascript_side_json variable after the assignment is done should be equivalent to me writing var javascript_side_json = {"name": "Will", "age": 23 };
I am not able to achieve this by writing var javascript_side_json = <%= @rails_side_json %>
How can I achieve this? Do I need to make changes in multiple files?
Solution 1:[1]
You are almost done. Just need to make sure your json is safe html:
var javascript_side_json = <%= @rails_side_json.html_safe %>;
or
var javascript_side_json = <%=raw @rails_side_json %>;
Solution 2:[2]
The JSON will be escaped by default. You can tell the view to use in the code using raw
var javascript_side_json = <%= raw @rails_side_json %>
Solution 3:[3]
The above answers didn't work for me. Therefore I'm posting a solution that is working for me.
# Rails
@server_variable = some_variable.to_json.html_safe
// Javascript
let var = JSON.parse('<%= escape_javascript(@server_variable) %>')
Sources
This article follows the attribution requirements of Stack Overflow and is licensed under CC BY-SA 3.0.
Source: Stack Overflow
| Solution | Source |
|---|---|
| Solution 1 | Muntasim |
| Solution 2 | Zero Fiber |
| Solution 3 |
