JavaScript を使用して特定の CSS にアクセスする方法がわかりません。
言いましょう、
#menu { color: red; }
でアクセスできます
document.getElementById('menu').style.color = "blue";
でもアクセスしたい
#menu li a { height: 10%; }
document.getElementById() を使用してアクセスするにはどうすればよいですか?
JavaScript を使用して特定の CSS にアクセスする方法がわかりません。
言いましょう、
#menu { color: red; }
でアクセスできます
document.getElementById('menu').style.color = "blue";
でもアクセスしたい
#menu li a { height: 10%; }
document.getElementById() を使用してアクセスするにはどうすればよいですか?
getElementById()
その目的は id 属性のクエリのみであるため、この場合は使用できませんが、次getElementsByTagName()
のコンテキストで使用でき#menu
ます。
var m = document.getElementById('menu');
// Get all <li> children of #menu
var lis = m.getElementsByTagName('li');
// Loop over them
for (var i=0; i<lis.length; i++) {
// Get all <a> children of each <li>
var atags = lis[i].getElementsByTagName('a');
for (var a = 0; a<atags.length; a++) {
// And set their color in a loop.
atags[a].style.color = 'blue';
// or change some other property
atags[a].style.height = '25%';
}
}
jQuery を使用できる場合、これは非常に簡単になります。
$('#menu li a').css('color', 'blue');
あなたはそうしない; <a>
その条件に一致するすべてのタグを見つける必要があります。
.getElementById()
関数は、一意の「id」文字列によって要素を取得することです。それ以外の場合に要素を取得する必要がある場合は、他の API を使用できます: .getElementsByTagName()
、.getElementsByClass()
、.querySelectorAll()
など。ブラウザのサポートはさまざまであり、.getElementById()
IE と他のブラウザの間でも異なります。