How do I access JavaScript variable under Color portion of HTML code?











up vote
1
down vote

favorite












I would like to access the variable "theSkyColour" inside the HTML code below as shown. May I know how do I access it as shown?



The following is the code I have written:






function getSkyColour() {
var theSkyColour = localStorage.getItem('skySet[enter image description here][1]ting');
}

<a-sky id="skyColor" src="#sky" 
material="shader:gradient; topColor: <<I want to access theSkyColor here>>; bottomColor: <<I want to access theSkyColor here>> ; offset:0;"></a-sky>





I have viewed other answers like the one here: Javascript variable access in HTML, however, it did not work for me as I am unable to change the color of the sky in the viewing page.



I've created the following HTML pages.
1. A settings page to adjust the color of the sky saved in a localStorage as "skyColor".
2. A viewing page for the user to view the color of the sky.



The reason why I have an a-sky tag is that I am using aframe.io



Update: After attempting to use JavaScript along with localStorage Sessions:



Javascript Code:



<script>
function getSkyColor() {
var theSkyColor = localStorage.getItem('skySetting');
}
getSkyColour()

var myAttr = "shader:gradient; topColor:"+theSkyColor+";
bottomColor:"+theSkyColor+"; offset:0;"
document.getElementById(‘skyColor’).setAttribute(“material”,myAttr)
</script>


HTML Code:



  <a-sky id="skyColor" src="#sky" material="shader:gradient; offset:0;"></a-sky>


Unfortunately, it still does not work, as the display I get is not what I have expected, which is a night sky under the RGB color: 41 35 71. (See attached screenshot)



Failed display of desired colors RGB 41 35 71



What I want and What I have










share|improve this question
























  • It's not possible to access javascript variable in html.
    – Raja Sekar
    yesterday










  • check this: w3schools.com/js/js_htmldom_css.asp
    – MrAleister
    yesterday






  • 2




    "It did not work for me" how? It is not very descriptive. Please update the snippet I made for you with your attempts - Also please tell us what framework has <a-sky tags
    – mplungjan
    yesterday












  • Tri this: document.getElementById('skyColor').setAttribute('material', document.getElementById('skyColor').getAttribute('style')+'; color: '+getSkyColour());
    – Mohammad Zare Moghadam
    yesterday

















up vote
1
down vote

favorite












I would like to access the variable "theSkyColour" inside the HTML code below as shown. May I know how do I access it as shown?



The following is the code I have written:






function getSkyColour() {
var theSkyColour = localStorage.getItem('skySet[enter image description here][1]ting');
}

<a-sky id="skyColor" src="#sky" 
material="shader:gradient; topColor: <<I want to access theSkyColor here>>; bottomColor: <<I want to access theSkyColor here>> ; offset:0;"></a-sky>





I have viewed other answers like the one here: Javascript variable access in HTML, however, it did not work for me as I am unable to change the color of the sky in the viewing page.



I've created the following HTML pages.
1. A settings page to adjust the color of the sky saved in a localStorage as "skyColor".
2. A viewing page for the user to view the color of the sky.



The reason why I have an a-sky tag is that I am using aframe.io



Update: After attempting to use JavaScript along with localStorage Sessions:



Javascript Code:



<script>
function getSkyColor() {
var theSkyColor = localStorage.getItem('skySetting');
}
getSkyColour()

var myAttr = "shader:gradient; topColor:"+theSkyColor+";
bottomColor:"+theSkyColor+"; offset:0;"
document.getElementById(‘skyColor’).setAttribute(“material”,myAttr)
</script>


HTML Code:



  <a-sky id="skyColor" src="#sky" material="shader:gradient; offset:0;"></a-sky>


Unfortunately, it still does not work, as the display I get is not what I have expected, which is a night sky under the RGB color: 41 35 71. (See attached screenshot)



Failed display of desired colors RGB 41 35 71



What I want and What I have










share|improve this question
























  • It's not possible to access javascript variable in html.
    – Raja Sekar
    yesterday










  • check this: w3schools.com/js/js_htmldom_css.asp
    – MrAleister
    yesterday






  • 2




    "It did not work for me" how? It is not very descriptive. Please update the snippet I made for you with your attempts - Also please tell us what framework has <a-sky tags
    – mplungjan
    yesterday












  • Tri this: document.getElementById('skyColor').setAttribute('material', document.getElementById('skyColor').getAttribute('style')+'; color: '+getSkyColour());
    – Mohammad Zare Moghadam
    yesterday















up vote
1
down vote

favorite









up vote
1
down vote

favorite











I would like to access the variable "theSkyColour" inside the HTML code below as shown. May I know how do I access it as shown?



The following is the code I have written:






function getSkyColour() {
var theSkyColour = localStorage.getItem('skySet[enter image description here][1]ting');
}

<a-sky id="skyColor" src="#sky" 
material="shader:gradient; topColor: <<I want to access theSkyColor here>>; bottomColor: <<I want to access theSkyColor here>> ; offset:0;"></a-sky>





I have viewed other answers like the one here: Javascript variable access in HTML, however, it did not work for me as I am unable to change the color of the sky in the viewing page.



I've created the following HTML pages.
1. A settings page to adjust the color of the sky saved in a localStorage as "skyColor".
2. A viewing page for the user to view the color of the sky.



The reason why I have an a-sky tag is that I am using aframe.io



Update: After attempting to use JavaScript along with localStorage Sessions:



Javascript Code:



<script>
function getSkyColor() {
var theSkyColor = localStorage.getItem('skySetting');
}
getSkyColour()

var myAttr = "shader:gradient; topColor:"+theSkyColor+";
bottomColor:"+theSkyColor+"; offset:0;"
document.getElementById(‘skyColor’).setAttribute(“material”,myAttr)
</script>


HTML Code:



  <a-sky id="skyColor" src="#sky" material="shader:gradient; offset:0;"></a-sky>


Unfortunately, it still does not work, as the display I get is not what I have expected, which is a night sky under the RGB color: 41 35 71. (See attached screenshot)



Failed display of desired colors RGB 41 35 71



What I want and What I have










share|improve this question















I would like to access the variable "theSkyColour" inside the HTML code below as shown. May I know how do I access it as shown?



The following is the code I have written:






function getSkyColour() {
var theSkyColour = localStorage.getItem('skySet[enter image description here][1]ting');
}

<a-sky id="skyColor" src="#sky" 
material="shader:gradient; topColor: <<I want to access theSkyColor here>>; bottomColor: <<I want to access theSkyColor here>> ; offset:0;"></a-sky>





I have viewed other answers like the one here: Javascript variable access in HTML, however, it did not work for me as I am unable to change the color of the sky in the viewing page.



I've created the following HTML pages.
1. A settings page to adjust the color of the sky saved in a localStorage as "skyColor".
2. A viewing page for the user to view the color of the sky.



The reason why I have an a-sky tag is that I am using aframe.io



Update: After attempting to use JavaScript along with localStorage Sessions:



Javascript Code:



<script>
function getSkyColor() {
var theSkyColor = localStorage.getItem('skySetting');
}
getSkyColour()

var myAttr = "shader:gradient; topColor:"+theSkyColor+";
bottomColor:"+theSkyColor+"; offset:0;"
document.getElementById(‘skyColor’).setAttribute(“material”,myAttr)
</script>


HTML Code:



  <a-sky id="skyColor" src="#sky" material="shader:gradient; offset:0;"></a-sky>


Unfortunately, it still does not work, as the display I get is not what I have expected, which is a night sky under the RGB color: 41 35 71. (See attached screenshot)



Failed display of desired colors RGB 41 35 71



What I want and What I have






function getSkyColour() {
var theSkyColour = localStorage.getItem('skySet[enter image description here][1]ting');
}

<a-sky id="skyColor" src="#sky" 
material="shader:gradient; topColor: <<I want to access theSkyColor here>>; bottomColor: <<I want to access theSkyColor here>> ; offset:0;"></a-sky>





function getSkyColour() {
var theSkyColour = localStorage.getItem('skySet[enter image description here][1]ting');
}

<a-sky id="skyColor" src="#sky" 
material="shader:gradient; topColor: <<I want to access theSkyColor here>>; bottomColor: <<I want to access theSkyColor here>> ; offset:0;"></a-sky>






javascript html variables web-component aframe






share|improve this question















share|improve this question













share|improve this question




share|improve this question








edited 13 hours ago

























asked yesterday









Jim Ng

64




64












  • It's not possible to access javascript variable in html.
    – Raja Sekar
    yesterday










  • check this: w3schools.com/js/js_htmldom_css.asp
    – MrAleister
    yesterday






  • 2




    "It did not work for me" how? It is not very descriptive. Please update the snippet I made for you with your attempts - Also please tell us what framework has <a-sky tags
    – mplungjan
    yesterday












  • Tri this: document.getElementById('skyColor').setAttribute('material', document.getElementById('skyColor').getAttribute('style')+'; color: '+getSkyColour());
    – Mohammad Zare Moghadam
    yesterday




















  • It's not possible to access javascript variable in html.
    – Raja Sekar
    yesterday










  • check this: w3schools.com/js/js_htmldom_css.asp
    – MrAleister
    yesterday






  • 2




    "It did not work for me" how? It is not very descriptive. Please update the snippet I made for you with your attempts - Also please tell us what framework has <a-sky tags
    – mplungjan
    yesterday












  • Tri this: document.getElementById('skyColor').setAttribute('material', document.getElementById('skyColor').getAttribute('style')+'; color: '+getSkyColour());
    – Mohammad Zare Moghadam
    yesterday


















It's not possible to access javascript variable in html.
– Raja Sekar
yesterday




It's not possible to access javascript variable in html.
– Raja Sekar
yesterday












check this: w3schools.com/js/js_htmldom_css.asp
– MrAleister
yesterday




check this: w3schools.com/js/js_htmldom_css.asp
– MrAleister
yesterday




2




2




"It did not work for me" how? It is not very descriptive. Please update the snippet I made for you with your attempts - Also please tell us what framework has <a-sky tags
– mplungjan
yesterday






"It did not work for me" how? It is not very descriptive. Please update the snippet I made for you with your attempts - Also please tell us what framework has <a-sky tags
– mplungjan
yesterday














Tri this: document.getElementById('skyColor').setAttribute('material', document.getElementById('skyColor').getAttribute('style')+'; color: '+getSkyColour());
– Mohammad Zare Moghadam
yesterday






Tri this: document.getElementById('skyColor').setAttribute('material', document.getElementById('skyColor').getAttribute('style')+'; color: '+getSkyColour());
– Mohammad Zare Moghadam
yesterday














3 Answers
3






active

oldest

votes

















up vote
0
down vote













You can’t, but you can change the function to update the color of the sky.



document.getElementById("skyColor").material = `defaultStylesInHere topColor:${localStorage.getItem("skyColor")};`;





share|improve this answer










New contributor




DarkHeart Productions is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.














  • 1




    You likely want getAttribute("material") here
    – mplungjan
    yesterday






  • 1




    Please do not use curly quotes - are you updating on a phone?
    – mplungjan
    yesterday






  • 1




    You can add comments as comments, no need to edit the post for that.
    – Luca Kiebel
    yesterday










  • Yes, I am using a phone, it was stated at the bottom of my post
    – DarkHeart Productions
    yesterday






  • 2




    Oh wow, did not see that. :/
    – DarkHeart Productions
    yesterday


















up vote
0
down vote













check out the snippets for getting and setting attributesin an a-frame component. Refer to the following documentation:



https://aframe.io/docs/0.8.0/core/entity.html#getattribute-componentname



It explains very well how to get and how to set values from component properties and sub-properties:



Get Property



enter image description here



Set Property
enter image description here






share|improve this answer





















  • Does this apply in my scenario, considering that I am accessing a local session? I am using some aframe components, however, I am not sure if it works since I am changing a local session on another HTML page. Could you advise if there is an alternative for using local sessions storage?
    – Jim Ng
    yesterday










  • I don't think templating is available for aframe at component sub-properties level, as they're one string. I think you can modify the values right after initialization of the frame. Not sure how it is done yet!
    – Sunny Sharma
    yesterday


















up vote
0
down vote













Unless you are using a framework like Angular or django, it is not possible to access variables in your HTML code, instead you can construct the attribute in your Javascript and add it to the element.



EX:



var myAttr = "shader:gradient; topColor:"+skyColor+"; bottomColor:"+skyColor+"; offset:0;"
$("#skyColor").attr("material",myAttr)


Update: without using jQuery:



<script>
function getSkyColour() {
var theSkyColour = localStorage.getItem('skySetting');
}
getSkyColour()

var myAttr = "shader:gradient; topColor:"+theSkyColour+"; bottomColor:"+theSkyColour+"; offset:0;"
document.getElementById(‘skyColor’).setAttribute(“material”,myAttr)

</script>





share|improve this answer























  • For the second line "$("#skyColor").attr("material",myAttr)" , may I know where should I place this line of code? Is this a PHP code? How do I use it?
    – Jim Ng
    yesterday










  • This is a jQuery code, you need to have jQuery library in your application to use it. If you do not have jQuey library, I will suggest an alternative to it in pure JavaScript
    – Suhas NM
    yesterday










  • I would like to use pure Javascript as well. However, like I mentioned in the original post, there is a problem of being unable to call it inside the HTML code with Javascript. So I'm confused. What should I do here if I would like to use pure Javascript?
    – Jim Ng
    yesterday










  • Basically, any JavaScript you use goes inside “<script> your JavaScript </script>”
    – Suhas NM
    yesterday










  • I will update my answer to your requirement
    – Suhas NM
    yesterday











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',
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
});


}
});














 

draft saved


draft discarded


















StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53372122%2fhow-do-i-access-javascript-variable-under-color-portion-of-html-code%23new-answer', 'question_page');
}
);

Post as a guest















Required, but never shown

























3 Answers
3






active

oldest

votes








3 Answers
3






active

oldest

votes









active

oldest

votes






active

oldest

votes








up vote
0
down vote













You can’t, but you can change the function to update the color of the sky.



document.getElementById("skyColor").material = `defaultStylesInHere topColor:${localStorage.getItem("skyColor")};`;





share|improve this answer










New contributor




DarkHeart Productions is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.














  • 1




    You likely want getAttribute("material") here
    – mplungjan
    yesterday






  • 1




    Please do not use curly quotes - are you updating on a phone?
    – mplungjan
    yesterday






  • 1




    You can add comments as comments, no need to edit the post for that.
    – Luca Kiebel
    yesterday










  • Yes, I am using a phone, it was stated at the bottom of my post
    – DarkHeart Productions
    yesterday






  • 2




    Oh wow, did not see that. :/
    – DarkHeart Productions
    yesterday















up vote
0
down vote













You can’t, but you can change the function to update the color of the sky.



document.getElementById("skyColor").material = `defaultStylesInHere topColor:${localStorage.getItem("skyColor")};`;





share|improve this answer










New contributor




DarkHeart Productions is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.














  • 1




    You likely want getAttribute("material") here
    – mplungjan
    yesterday






  • 1




    Please do not use curly quotes - are you updating on a phone?
    – mplungjan
    yesterday






  • 1




    You can add comments as comments, no need to edit the post for that.
    – Luca Kiebel
    yesterday










  • Yes, I am using a phone, it was stated at the bottom of my post
    – DarkHeart Productions
    yesterday






  • 2




    Oh wow, did not see that. :/
    – DarkHeart Productions
    yesterday













up vote
0
down vote










up vote
0
down vote









You can’t, but you can change the function to update the color of the sky.



document.getElementById("skyColor").material = `defaultStylesInHere topColor:${localStorage.getItem("skyColor")};`;





share|improve this answer










New contributor




DarkHeart Productions is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.









You can’t, but you can change the function to update the color of the sky.



document.getElementById("skyColor").material = `defaultStylesInHere topColor:${localStorage.getItem("skyColor")};`;






share|improve this answer










New contributor




DarkHeart Productions is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.









share|improve this answer



share|improve this answer








edited yesterday





















New contributor




DarkHeart Productions is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.









answered yesterday









DarkHeart Productions

563




563




New contributor




DarkHeart Productions is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.





New contributor





DarkHeart Productions is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.






DarkHeart Productions is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.








  • 1




    You likely want getAttribute("material") here
    – mplungjan
    yesterday






  • 1




    Please do not use curly quotes - are you updating on a phone?
    – mplungjan
    yesterday






  • 1




    You can add comments as comments, no need to edit the post for that.
    – Luca Kiebel
    yesterday










  • Yes, I am using a phone, it was stated at the bottom of my post
    – DarkHeart Productions
    yesterday






  • 2




    Oh wow, did not see that. :/
    – DarkHeart Productions
    yesterday














  • 1




    You likely want getAttribute("material") here
    – mplungjan
    yesterday






  • 1




    Please do not use curly quotes - are you updating on a phone?
    – mplungjan
    yesterday






  • 1




    You can add comments as comments, no need to edit the post for that.
    – Luca Kiebel
    yesterday










  • Yes, I am using a phone, it was stated at the bottom of my post
    – DarkHeart Productions
    yesterday






  • 2




    Oh wow, did not see that. :/
    – DarkHeart Productions
    yesterday








1




1




You likely want getAttribute("material") here
– mplungjan
yesterday




You likely want getAttribute("material") here
– mplungjan
yesterday




1




1




Please do not use curly quotes - are you updating on a phone?
– mplungjan
yesterday




Please do not use curly quotes - are you updating on a phone?
– mplungjan
yesterday




1




1




You can add comments as comments, no need to edit the post for that.
– Luca Kiebel
yesterday




You can add comments as comments, no need to edit the post for that.
– Luca Kiebel
yesterday












Yes, I am using a phone, it was stated at the bottom of my post
– DarkHeart Productions
yesterday




Yes, I am using a phone, it was stated at the bottom of my post
– DarkHeart Productions
yesterday




2




2




Oh wow, did not see that. :/
– DarkHeart Productions
yesterday




Oh wow, did not see that. :/
– DarkHeart Productions
yesterday












up vote
0
down vote













check out the snippets for getting and setting attributesin an a-frame component. Refer to the following documentation:



https://aframe.io/docs/0.8.0/core/entity.html#getattribute-componentname



It explains very well how to get and how to set values from component properties and sub-properties:



Get Property



enter image description here



Set Property
enter image description here






share|improve this answer





















  • Does this apply in my scenario, considering that I am accessing a local session? I am using some aframe components, however, I am not sure if it works since I am changing a local session on another HTML page. Could you advise if there is an alternative for using local sessions storage?
    – Jim Ng
    yesterday










  • I don't think templating is available for aframe at component sub-properties level, as they're one string. I think you can modify the values right after initialization of the frame. Not sure how it is done yet!
    – Sunny Sharma
    yesterday















up vote
0
down vote













check out the snippets for getting and setting attributesin an a-frame component. Refer to the following documentation:



https://aframe.io/docs/0.8.0/core/entity.html#getattribute-componentname



It explains very well how to get and how to set values from component properties and sub-properties:



Get Property



enter image description here



Set Property
enter image description here






share|improve this answer





















  • Does this apply in my scenario, considering that I am accessing a local session? I am using some aframe components, however, I am not sure if it works since I am changing a local session on another HTML page. Could you advise if there is an alternative for using local sessions storage?
    – Jim Ng
    yesterday










  • I don't think templating is available for aframe at component sub-properties level, as they're one string. I think you can modify the values right after initialization of the frame. Not sure how it is done yet!
    – Sunny Sharma
    yesterday













up vote
0
down vote










up vote
0
down vote









check out the snippets for getting and setting attributesin an a-frame component. Refer to the following documentation:



https://aframe.io/docs/0.8.0/core/entity.html#getattribute-componentname



It explains very well how to get and how to set values from component properties and sub-properties:



Get Property



enter image description here



Set Property
enter image description here






share|improve this answer












check out the snippets for getting and setting attributesin an a-frame component. Refer to the following documentation:



https://aframe.io/docs/0.8.0/core/entity.html#getattribute-componentname



It explains very well how to get and how to set values from component properties and sub-properties:



Get Property



enter image description here



Set Property
enter image description here







share|improve this answer












share|improve this answer



share|improve this answer










answered yesterday









Sunny Sharma

2,60641950




2,60641950












  • Does this apply in my scenario, considering that I am accessing a local session? I am using some aframe components, however, I am not sure if it works since I am changing a local session on another HTML page. Could you advise if there is an alternative for using local sessions storage?
    – Jim Ng
    yesterday










  • I don't think templating is available for aframe at component sub-properties level, as they're one string. I think you can modify the values right after initialization of the frame. Not sure how it is done yet!
    – Sunny Sharma
    yesterday


















  • Does this apply in my scenario, considering that I am accessing a local session? I am using some aframe components, however, I am not sure if it works since I am changing a local session on another HTML page. Could you advise if there is an alternative for using local sessions storage?
    – Jim Ng
    yesterday










  • I don't think templating is available for aframe at component sub-properties level, as they're one string. I think you can modify the values right after initialization of the frame. Not sure how it is done yet!
    – Sunny Sharma
    yesterday
















Does this apply in my scenario, considering that I am accessing a local session? I am using some aframe components, however, I am not sure if it works since I am changing a local session on another HTML page. Could you advise if there is an alternative for using local sessions storage?
– Jim Ng
yesterday




Does this apply in my scenario, considering that I am accessing a local session? I am using some aframe components, however, I am not sure if it works since I am changing a local session on another HTML page. Could you advise if there is an alternative for using local sessions storage?
– Jim Ng
yesterday












I don't think templating is available for aframe at component sub-properties level, as they're one string. I think you can modify the values right after initialization of the frame. Not sure how it is done yet!
– Sunny Sharma
yesterday




I don't think templating is available for aframe at component sub-properties level, as they're one string. I think you can modify the values right after initialization of the frame. Not sure how it is done yet!
– Sunny Sharma
yesterday










up vote
0
down vote













Unless you are using a framework like Angular or django, it is not possible to access variables in your HTML code, instead you can construct the attribute in your Javascript and add it to the element.



EX:



var myAttr = "shader:gradient; topColor:"+skyColor+"; bottomColor:"+skyColor+"; offset:0;"
$("#skyColor").attr("material",myAttr)


Update: without using jQuery:



<script>
function getSkyColour() {
var theSkyColour = localStorage.getItem('skySetting');
}
getSkyColour()

var myAttr = "shader:gradient; topColor:"+theSkyColour+"; bottomColor:"+theSkyColour+"; offset:0;"
document.getElementById(‘skyColor’).setAttribute(“material”,myAttr)

</script>





share|improve this answer























  • For the second line "$("#skyColor").attr("material",myAttr)" , may I know where should I place this line of code? Is this a PHP code? How do I use it?
    – Jim Ng
    yesterday










  • This is a jQuery code, you need to have jQuery library in your application to use it. If you do not have jQuey library, I will suggest an alternative to it in pure JavaScript
    – Suhas NM
    yesterday










  • I would like to use pure Javascript as well. However, like I mentioned in the original post, there is a problem of being unable to call it inside the HTML code with Javascript. So I'm confused. What should I do here if I would like to use pure Javascript?
    – Jim Ng
    yesterday










  • Basically, any JavaScript you use goes inside “<script> your JavaScript </script>”
    – Suhas NM
    yesterday










  • I will update my answer to your requirement
    – Suhas NM
    yesterday















up vote
0
down vote













Unless you are using a framework like Angular or django, it is not possible to access variables in your HTML code, instead you can construct the attribute in your Javascript and add it to the element.



EX:



var myAttr = "shader:gradient; topColor:"+skyColor+"; bottomColor:"+skyColor+"; offset:0;"
$("#skyColor").attr("material",myAttr)


Update: without using jQuery:



<script>
function getSkyColour() {
var theSkyColour = localStorage.getItem('skySetting');
}
getSkyColour()

var myAttr = "shader:gradient; topColor:"+theSkyColour+"; bottomColor:"+theSkyColour+"; offset:0;"
document.getElementById(‘skyColor’).setAttribute(“material”,myAttr)

</script>





share|improve this answer























  • For the second line "$("#skyColor").attr("material",myAttr)" , may I know where should I place this line of code? Is this a PHP code? How do I use it?
    – Jim Ng
    yesterday










  • This is a jQuery code, you need to have jQuery library in your application to use it. If you do not have jQuey library, I will suggest an alternative to it in pure JavaScript
    – Suhas NM
    yesterday










  • I would like to use pure Javascript as well. However, like I mentioned in the original post, there is a problem of being unable to call it inside the HTML code with Javascript. So I'm confused. What should I do here if I would like to use pure Javascript?
    – Jim Ng
    yesterday










  • Basically, any JavaScript you use goes inside “<script> your JavaScript </script>”
    – Suhas NM
    yesterday










  • I will update my answer to your requirement
    – Suhas NM
    yesterday













up vote
0
down vote










up vote
0
down vote









Unless you are using a framework like Angular or django, it is not possible to access variables in your HTML code, instead you can construct the attribute in your Javascript and add it to the element.



EX:



var myAttr = "shader:gradient; topColor:"+skyColor+"; bottomColor:"+skyColor+"; offset:0;"
$("#skyColor").attr("material",myAttr)


Update: without using jQuery:



<script>
function getSkyColour() {
var theSkyColour = localStorage.getItem('skySetting');
}
getSkyColour()

var myAttr = "shader:gradient; topColor:"+theSkyColour+"; bottomColor:"+theSkyColour+"; offset:0;"
document.getElementById(‘skyColor’).setAttribute(“material”,myAttr)

</script>





share|improve this answer














Unless you are using a framework like Angular or django, it is not possible to access variables in your HTML code, instead you can construct the attribute in your Javascript and add it to the element.



EX:



var myAttr = "shader:gradient; topColor:"+skyColor+"; bottomColor:"+skyColor+"; offset:0;"
$("#skyColor").attr("material",myAttr)


Update: without using jQuery:



<script>
function getSkyColour() {
var theSkyColour = localStorage.getItem('skySetting');
}
getSkyColour()

var myAttr = "shader:gradient; topColor:"+theSkyColour+"; bottomColor:"+theSkyColour+"; offset:0;"
document.getElementById(‘skyColor’).setAttribute(“material”,myAttr)

</script>






share|improve this answer














share|improve this answer



share|improve this answer








edited yesterday

























answered yesterday









Suhas NM

725




725












  • For the second line "$("#skyColor").attr("material",myAttr)" , may I know where should I place this line of code? Is this a PHP code? How do I use it?
    – Jim Ng
    yesterday










  • This is a jQuery code, you need to have jQuery library in your application to use it. If you do not have jQuey library, I will suggest an alternative to it in pure JavaScript
    – Suhas NM
    yesterday










  • I would like to use pure Javascript as well. However, like I mentioned in the original post, there is a problem of being unable to call it inside the HTML code with Javascript. So I'm confused. What should I do here if I would like to use pure Javascript?
    – Jim Ng
    yesterday










  • Basically, any JavaScript you use goes inside “<script> your JavaScript </script>”
    – Suhas NM
    yesterday










  • I will update my answer to your requirement
    – Suhas NM
    yesterday


















  • For the second line "$("#skyColor").attr("material",myAttr)" , may I know where should I place this line of code? Is this a PHP code? How do I use it?
    – Jim Ng
    yesterday










  • This is a jQuery code, you need to have jQuery library in your application to use it. If you do not have jQuey library, I will suggest an alternative to it in pure JavaScript
    – Suhas NM
    yesterday










  • I would like to use pure Javascript as well. However, like I mentioned in the original post, there is a problem of being unable to call it inside the HTML code with Javascript. So I'm confused. What should I do here if I would like to use pure Javascript?
    – Jim Ng
    yesterday










  • Basically, any JavaScript you use goes inside “<script> your JavaScript </script>”
    – Suhas NM
    yesterday










  • I will update my answer to your requirement
    – Suhas NM
    yesterday
















For the second line "$("#skyColor").attr("material",myAttr)" , may I know where should I place this line of code? Is this a PHP code? How do I use it?
– Jim Ng
yesterday




For the second line "$("#skyColor").attr("material",myAttr)" , may I know where should I place this line of code? Is this a PHP code? How do I use it?
– Jim Ng
yesterday












This is a jQuery code, you need to have jQuery library in your application to use it. If you do not have jQuey library, I will suggest an alternative to it in pure JavaScript
– Suhas NM
yesterday




This is a jQuery code, you need to have jQuery library in your application to use it. If you do not have jQuey library, I will suggest an alternative to it in pure JavaScript
– Suhas NM
yesterday












I would like to use pure Javascript as well. However, like I mentioned in the original post, there is a problem of being unable to call it inside the HTML code with Javascript. So I'm confused. What should I do here if I would like to use pure Javascript?
– Jim Ng
yesterday




I would like to use pure Javascript as well. However, like I mentioned in the original post, there is a problem of being unable to call it inside the HTML code with Javascript. So I'm confused. What should I do here if I would like to use pure Javascript?
– Jim Ng
yesterday












Basically, any JavaScript you use goes inside “<script> your JavaScript </script>”
– Suhas NM
yesterday




Basically, any JavaScript you use goes inside “<script> your JavaScript </script>”
– Suhas NM
yesterday












I will update my answer to your requirement
– Suhas NM
yesterday




I will update my answer to your requirement
– Suhas NM
yesterday


















 

draft saved


draft discarded



















































 


draft saved


draft discarded














StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53372122%2fhow-do-i-access-javascript-variable-under-color-portion-of-html-code%23new-answer', 'question_page');
}
);

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







Popular posts from this blog

Volksrepublik China

How to test boost logger output in unit testing?

Write to the output between two pipeline