0
problem with getAttribute method in JS
the question is asked inside the comments of the code below. please read it there https://code.sololearn.com/Wa6a13A18a8A
3 Respostas
+ 2
When you do
`x.getAttributeNode("src").value = ...`
You're changing the value property of the node returned by x.getAttributeNode(). It is a valid expression for the left-hand-side of the '=' operator.
On the other hand, let's assume x has the attribute 'src' with value "hello"
`x.getAttribute("src") = ...`
Now, x.getAttribute("src") will return "hello". So this is the same as doing
`"hello" = ....`
"hello" is not a valid left-hand-side for the operator '=', and hence the whole expression is invalid.
To set the attribute of an element, use the .setAttribute() method instead. So line 10 and 11 should be replaced with
`x.setAttribute("src", "htt.....")`
Element.setAttribute():
https://developer.mozilla.org/en-US/docs/Web/API/Element/setAttribute
+ 2
salar vahidi First of all, you need to figure out whether you want to get the attribute value (see it) or set it (change it). It looks like you're trying to set the src value. In that case, you don't need to get it. All you need to do is use setAttribute("src", "new value you want").
getAttributeNode().value and getAttribute() both get you the value but but you can't use the = operator with the latter because you're just working with a simple value, not an object. So you can't set the value property. That's why setAttribute exists.
+ 2
src: http://www.javascriptkit.com/dhtmltutors/domattribute.shtml
function myFunction() {
var x = document.getElementsByTagName("IMG")[0];
x.setAttribute("src", "https://cdn.pixabay.com/photo/2021/04/13/09/46/river-6175173_1280.jpg");
}