+ 1
code not working??
<div id="test"> <p style="color: red; font-size: 200px;">Sample</p> <p style="color: red; font-size: 200px;">Sample2</p> </div> var arr = document.getElementById("test"); var c = arr.childNodes; for(var x = 0; x < c.length; x++) { c[x].style.color = "grey""; }
14 Answers
+ 7
https://code.sololearn.com/W6cA8Me8XcGk/?ref=app
it can works even without "onload" method
+ 6
inattention generates problems😌
+ 6
@Naveen inattention(2.0) ☺
+ 5
Yeah basically there are 3 issues with the code.
1.) The DOM may not have been created prior to attempting to access its elements 'test', hence the onload function or placing in a script at the bottom of the body etc.
2.) The use of childNodes here instead of children resulting in undefined being returned.
3.) The syntax error of the additional double quote.
+ 5
@Mohammed we cannot change elements with childnodes property, it is used only for reading elements, not changing them
+ 4
window.onload = function() {
var arr = document.getElementById("test");
var c = arr.children; // Use children instead of childNodes
for(var x = 0; x < c.length; x++) {
c[x].style.color = "grey"; // You also had an extra quote here
}
};
+ 3
What about the " mistake! in c[x].style.color = "grey"";
+ 3
@01ejka Yeah!
+ 2
LOL Ooops sorry forgot to change childNodes to children! Then it should work. Code edited.
+ 2
@01ejka To further prove what I am saying please view the code below
@Mohamed Kalith This may better answer your question.
It's not that you aren't getting the P elements, but that they are not accessible in the way you are attempting due to the use of childNodes vs children which results in an error.
childNodes will return a list (array) of ALL of the nodes that are a child of the object
while children will return a list (array) of all of the elements that are a child of the object.
window.onload = function() {
var arr = document.getElementById("test");
var a = arr.childNodes;
alert(a[0].nodeName);
alert(a[0].parentElement); // 'test'
a[0].nodeValue = "HELLO";
// ^^ this is inserted like so:
// <div id="test">"HELLO"<p style="color: red; font-size: 200px;">Sample</p>
var c = arr.children;
alert(c[0].nodeName);
alert(a[1].nodeName); // This is equal to the above line
a[1].style.color = "grey";
// You should also not the difference in the length property
alert(a.length);
// VS
alert(c.length);
for(var x = 0; x < a.length; x++) {
a[x].style.color = "grey"; // Trying to change a non-existent property on an text node object
alert("is this output?... NOPE"); // Because of above error this code is never reached
// a[1] which is one of the objects you're after is never reached so its color isn't changed
}
};
+ 1
@ChaoticDawg still not working??
+ 1
@ChaoticDawg why childNodes not working in this case?
+ 1
@01ejka I don't believe that is an accurate statement. childNodes returns a list of nodes. An element is also a node. Properties and attributes etc can be changed from the returned list of nodes by accessing the lists individual elements.
The similarities and differences between children and childNodes can be quite confusing and I often need to test my code to find which one to use. So I would advise you do some research on the 2 and when writing your code be prepared to test for both use cases.
In this case childNodes[0] will return the first #text node while children[0] will return the first P element.
Try running the code below to see the difference between the node names.
window.onload = function() {
var arr = document.getElementById("test");
var a = arr.childNodes;
alert(a[0].nodeName);
var c = arr.children;
alert(c[0].nodeName);
};
+ 1
Ahmed Raza Chandio
Answer
True