Jak mogę ustawić wiele atrybutów jednocześnie za pomocą JavaScript? Niestety nie jestem w stanie użyć frameworka takiego jak jQuery w tym projekcie. Oto, co mam teraz:
var elem = document.createElement("img");
elem.setAttribute("src", "http://example.com/something.jpeg");
elem.setAttribute("height", "100%");
elem.setAttribute("width", "100%");
javascript
JP Silvashy
źródło
źródło
Object.assign()
jest warta poszukania dla tych, którzy nie chcą tworzyć funkcji pomocniczej - działa dla „wszystkich wyliczalnych i własnych właściwości”.Odpowiedzi:
Możesz zrobić funkcję pomocniczą:
function setAttributes(el, attrs) { for(var key in attrs) { el.setAttribute(key, attrs[key]); } }
Nazwij to tak:
setAttributes(elem, {"src": "http://example.com/something.jpeg", "height": "100%", ...});
źródło
elem.setAttribute()
wiele razy.Możesz użyć,
Object.assign(...)
aby zastosować swoje właściwości do utworzonego elementu. Dodatkowe informacje można znaleźć w komentarzach.Pamiętaj, że atrybuty
height
iwidth
są definiowane w pikselach , a nie w procentach. Będziesz musiał użyć CSS, aby uczynić go płynnym.var elem = document.createElement('img') Object.assign(elem, { className: 'my-image-class', src: 'https://dummyimage.com/320x240/ccc/fff.jpg', height: 120, // pixels width: 160, // pixels onclick: function () { alert('Clicked!') } }) document.body.appendChild(elem) // One-liner: // document.body.appendChild(Object.assign(document.createElement(...), {...}))
.my-image-class { height: 100%; width: 100%; border: solid 5px transparent; box-sizing: border-box } .my-image-class:hover { cursor: pointer; border-color: red } body { margin:0 }
źródło
Jeśli chcesz mieć składnię framework-esq ( Uwaga: tylko obsługa IE 8+), możesz rozszerzyć
Element
prototyp i dodać własnąsetAttributes
funkcję:Element.prototype.setAttributes = function (attrs) { for (var idx in attrs) { if ((idx === 'styles' || idx === 'style') && typeof attrs[idx] === 'object') { for (var prop in attrs[idx]){this.style[prop] = attrs[idx][prop];} } else if (idx === 'html') { this.innerHTML = attrs[idx]; } else { this.setAttribute(idx, attrs[idx]); } } };
Pozwala to na użycie następującej składni:
var d = document.createElement('div'); d.setAttributes({ 'id':'my_div', 'class':'my_class', 'styles':{ 'backgroundColor':'blue', 'color':'red' }, 'html':'lol' });
Wypróbuj: http://jsfiddle.net/ywrXX/1/
Jeśli nie lubisz rozszerzać obiektu hosta ( niektórzy są przeciwni ) lub potrzebujesz obsługi IE7-, po prostu użyj go jako funkcji
Zauważ, że
setAttribute
nie będzie działaćstyle
w IE ani w obsłudze zdarzeń (i tak nie powinieneś). Powyższy kod obsługujestyle
, ale nie zdarzenia.Dokumentacja
setAttribute
na MDN - https://developer.mozilla.org/en-US/docs/DOM/element.setAttributeźródło
'Element' is undefined
document.createElement
idocument.getElementById
podkręcić ... lub po prostu zawinąć funkcjonalność w funkcję. Zredagowana odpowiedź, aby uwzględnić tę notatkęMożesz utworzyć funkcję, która przyjmuje zmienną liczbę argumentów:
function setAttributes(elem /* attribute, value pairs go here */) { for (var i = 1; i < arguments.length; i+=2) { elem.setAttribute(arguments[i], arguments[i+1]); } } setAttributes(elem, "src", "http://example.com/something.jpeg", "height", "100%", "width", "100%");
Lub przekazujesz pary atrybut / wartość w obiekcie:
function setAttributes(elem, obj) { for (var prop in obj) { if (obj.hasOwnProperty(prop)) { elem[prop] = obj[prop]; } } } setAttributes(elem, { src: "http://example.com/something.jpeg", height: "100%", width: "100%" });
Możesz także stworzyć własne opakowanie / metodę obiektu z możliwością łączenia w łańcuch:
function $$(elem) { return(new $$.init(elem)); } $$.init = function(elem) { if (typeof elem === "string") { elem = document.getElementById(elem); } this.elem = elem; } $$.init.prototype = { set: function(prop, value) { this.elem[prop] = value; return(this); } }; $$(elem).set("src", "http://example.com/something.jpeg").set("height", "100%").set("width", "100%");
Przykład roboczy: http://jsfiddle.net/jfriend00/qncEz/
źródło
Możesz zakodować funkcję pomocniczą ES5.1:
function setAttributes(el, attrs) { Object.keys(attrs).forEach(key => el.setAttribute(key, attrs[key])); }
Nazwij to tak:
setAttributes(elem, { src: 'http://example.com/something.jpeg', height: '100%' });
źródło
const setAttributes = (el, attrs) => Object.entries(attrs) .forEach(args => el.setAttribute(...args))
źródło
Lub utwórz funkcję, która tworzy element zawierający atrybuty na podstawie parametrów
function elemCreate(elType){ var element = document.createElement(elType); if (arguments.length>1){ var props = [].slice.call(arguments,1), key = props.shift(); while (key){ element.setAttribute(key,props.shift()); key = props.shift(); } } return element; } // usage var img = elemCreate('img', 'width','100', 'height','100', 'src','http://example.com/something.jpeg');
FYI:
height/width='100%'
nie działa przy użyciu atrybutów. Dla wysokości / szerokości 100% potrzebujesz elementówstyle.height/style.width
źródło
clone
preferowane byłoby użycie tej metody. Nie ma potrzeby tworzenia całego węzła od podstaw. W każdym razie priorytetem jest zminimalizowanie dostępu do DOM, najczęstszego przypadku użycia.Spróbuj tego
function setAttribs(elm, ob) { //var r = []; //var i = 0; for (var z in ob) { if (ob.hasOwnProperty(z)) { try { elm[z] = ob[z]; } catch (er) { elm.setAttribute(z, ob[z]); } } } return elm; }
DEMO: TUTAJ
źródło
użyj tej funkcji do tworzenia i ustawiania atrybutów w tym samym czasie
function createNode(node, attributes){ const el = document.createElement(node); for(let key in attributes){ el.setAttribute(key, attributes[key]); } return el; }
używaj go w ten sposób
const input = createNode('input', { name: 'test', type: 'text', placeholder: 'Test' }); document.body.appendChild(input);
źródło
Myślę, że to najlepszy sposób na jednoczesne ustawienie atrybutów dla dowolnego elementu w tej klasie.
function SetAtt(elements, attributes) { for (var element = 0; element < elements.length; element++) { for (var attribute = 0; attribute < attributes.length; attribute += 2) { elements[element].setAttribute(attributes[attribute], attributes[attribute + 1]); } } } var Class = document.getElementsByClassName("ClassName"); // class array list var Data = ['att1', 'val1', 'att2', 'val2', 'att3', 'val3']; //attributes array list SetAtt(Class, Data);
źródło
możesz po prostu dodać metodę (setAttributes, z „s” na końcu) do prototypu „Element”, na przykład:
Element.prototype.setAttributes = function(obj){ for(var prop in obj) { this.setAttribute(prop, obj[prop]) } }
możesz to zdefiniować w jednej linii:
Element.prototype.setAttributes = function(obj){ for(var prop in obj) this.setAttribute(prop, obj[prop]) }
i możesz to wywołać normalnie, tak jak wywołujesz inne metody. Atrybuty podane są jako obiekt:
elem.setAttributes({"src": "http://example.com/something.jpeg", "height": "100%", "width": "100%"})
możesz dodać instrukcję if, aby zgłosić błąd, jeśli dany argument nie jest obiektem.
źródło