0
document.querySelectorAll("table[id^='Table']");

このコードは、IDが。のすべてのテーブルを選択しますTable。しかし、idがTable2 OR Table7(または他の番号)のテーブルを選択したいと思います。正規表現でこれを行う方法は?

編集:私の場合、jQueryは適用できません。

4

1 に答える 1

2
function getTables(tableNumbers) { // Usage: getTables([2, 7]) will return the tables with the ID 'Table2' and 'Table7'. (You can add more numbers; [2,7,3,6])
    var allTables = document.querySelectorAll("table[id^='Table']");
    var tablesWeWant = [];
    for (var i = 0; i < allTables.length; i++) {
        if (allTables[i].id.match(/Table[0-9]/)) {
            tablesWeWant.push(allTables[i]);
        }
    }
    for (var i = 0; i < tablesWeWant.length; i++) {
        if (!tableNumbers.contains(tablesWeWant[i].id.substr(id.length - 1))) {
            tableNumbers.splice(i, 1);
        }
    }
    return tablesWeWant;
}

これにより、正規表現に一致/Table[0-9]/し、変数に含まれる数字で終わるIDを持つすべてのテーブルが返されますtableNumbders

免責事項:私は正規表現の専門家ではありません。

編集:
数回編集した後、上記のコードが少し長くなりすぎたので、次のように書き直しました:

function getTables(tableNumbers) {
    var tablesWeWant = [];
    for (var i = 0; i < tableNumbers.length; i++) {
        tablesWeWant.push(document.querySelector("#Table" + tableNumbers[i]));
    }
    return tablesWeWant;
}

2番目のアプローチは機能します:http://jsfiddle.net/qQ7VT/1/

于 2013-03-14T14:04:08.640 に答える