Найти все элементы, идентификатор которых начинается с общей строки
У меня есть XSL, который создал несколько элементов с идентификатором "createdOn" плюс $unique-id
Example : createdOnid0xfff5db30
Я хочу найти и сохранить их в переменной с помощью JavaScript. Я пробовал
var dates = document.getElementsById(/createdOn/);
но это не работает.
Ответы
Ответ 1
С помощью jQuery вы можете использовать attr начинается с селектора:
var dates = $('*[id^="createdOnid"]');
Используя современные браузеры, вы можете использовать значение атрибута CSS3 начинается с селектора вместе с querySelectorAll
:
var dates = document.querySelectorAll('*[id^="createdOnID"]');
Но для резервного копирования для старых браузеров (и без jQuery) вам понадобится:
var dateRE = /^createdOnid/;
var dates=[],els=document.getElementsByTagName('*');
for (var i=els.length;i--;) if (dateRE.test(els[i].id]) dates.push(els[i]);
Ответ 2
Поскольку вы не отметили jQuery, и вам, вероятно, это не нужно, мое предложение было бы добавить класс к этим элементам при их создании. Затем используйте функцию getElementsByClassName(), встроенную в большинство браузеров. Для IE вам нужно добавить что-то вроде this:
if (typeof document.getElementsByClassName!='function') {
document.getElementsByClassName = function() {
var elms = document.getElementsByTagName('*');
var ei = new Array();
for (i=0;i<elms.length;i++) {
if (elms[i].getAttribute('class')) {
ecl = elms[i].getAttribute('class').split(' ');
for (j=0;j<ecl.length;j++) {
if (ecl[j].toLowerCase() == arguments[0].toLowerCase()) {
ei.push(elms[i]);
}
}
} else if (elms[i].className) {
ecl = elms[i].className.split(' ');
for (j=0;j<ecl.length;j++) {
if (ecl[j].toLowerCase() == arguments[0].toLowerCase()) {
ei.push(elms[i]);
}
}
}
}
return ei;
}
}
Ответ 3
function idsLike(str){
var nodes= document.body.getElementsByTagName('*'),
L= nodes.length, A= [], temp;
while(L){
temp= nodes[--L].id || '';
if(temp.indexOf(str)== 0) A.push(temp);
}
return A;
}
idsLike('createdOn')
Ответ 4
Попробуйте следующее:
var values = new Array(valueKey_1);
var keys = new Array("nameKey_1");
var form = document.forms[0];
for (var i = 0; i < form.length; i++) {
name = form.elements[i].name;
var startName = name.toLowerCase().substring(0, 18);
if (startName == 'startStringExample') {
values.push(name.value);
keys.push(name);
}
}