41

私はjavascriptでこのようなものを書きたいです:

var all_headings = document.getElementsByTagName("h1,h2,h3,h4,h5,h6");

all_headingsh1その場合、 orh2またはh3...であるすべての要素のリストになります。もちろん、ドキュメントに表示される順序で。

どうすればいいのですか?

4

7 に答える 7

74

最新のブラウザを使用すると、次のことができます

document.querySelectorAll("h1, h2, h3, h4, h5, h6")

または、jQueryを使用してブラウザー間の互換性を得ることができます。

$("h1, h2, h3, h4, h5, h6")
于 2011-08-15T13:38:04.103 に答える
19

jQueryを使用している場合は、

$(":header")

jQueryドキュメントの例

<script>$(":header").css({ background:'#CCC', color:'blue' });</script>

ドキュメンテーション

于 2013-02-24T16:54:33.527 に答える
7

クロスブラウザのDOM選択が必要な場合は、jQueryをロードする必要はありません。

代わりにSizzleをロードしてください。これは、jQueryが使用するセレクターエンジンです。

例: http: //jsfiddle.net/77bMG/

var headings = Sizzle('h1,h2,h3');

for( var i = 0; i < headings.length; i++ ) {
    document.write('<br>');
    document.write(i + ' is ' + headings[i].innerHTML);
}

または、ライブラリコードがなくても、DOMをウォークして、見出しを配列にプッシュできます。

例: http: //jsfiddle.net/77bMG/1/

var headings = [];

var tag_names = {
    h1:1,
    h2:1,
    h3:1,
    h4:1,
    h5:1,
    h6:1
};

function walk( root ) {
    if( root.nodeType === 1 && root.nodeName !== 'script' ) {
        if( tag_names.hasOwnProperty(root.nodeName.toLowerCase()) ) {
            headings.push( root );
        } else {
            for( var i = 0; i < root.childNodes.length; i++ ) {
                walk( root.childNodes[i] );
            }
        }
    }
}

walk( document.body );

for( var i = 0; i < headings.length; i++ ) {
    document.write('<br>');
    document.write(i + ' is ' + headings[i].innerHTML);
}
于 2011-08-15T14:07:27.130 に答える
3

単純なものにはjQueryは必要ありません。彼を試してみてください:

var tags = [ "h1","h2","h3" ];
var all_headings = [];

for(var i = 0; i < tags.length; i++)
    all_headings = all_headings.concat(document.getElementsByTagName(tags[i]));
于 2011-08-15T13:42:48.217 に答える
2

QuentinUKは、ライブラリなしでJavaScriptのみを使用するソリューションを提供することで質問に答える、/ only /であるため、ここでの最良の回答です。

for (i=1; i<=6; i++) {
    var headers = document.getElementsByTagName('h'+i);
    for (j=0; j<headers.length; j++) {
        headers[j].className = 'h';
    }
}
var headers = document.getElementsByClassName('h');
for (i=0; i<headers.length; i++) {
    headers[i].innerHTML += ' '+i;
}
于 2016-02-13T06:26:29.690 に答える
2

jQueryとdocument.querySelectorAllのない関数

function get_all_h(document) {
    var arr = [];
    if (!document) return arr;
    var all_el = document.getElementsByTagName('*');
    for (var i = 0, n = all_el.length; i < n; i++) {
        if (/^h\d{1}$/gi.test(all_el[i].nodeName)) {
            arr.push(all_el[i]);
        }
    }
    return arr;
}
于 2017-02-14T07:30:17.293 に答える
0

それらに共通のクラス名を付けてから、getElementsByClassName

于 2011-08-15T13:40:25.333 に答える