Como posso definir vários atributos de uma vez com JavaScript? Infelizmente, não consigo usar uma estrutura como a jQuery neste projeto. Aqui está o que tenho agora:
var elem = document.createElement("img");
elem.setAttribute("src", "http://example.com/something.jpeg");
elem.setAttribute("height", "100%");
elem.setAttribute("width", "100%");
javascript
JP Silvashy
fonte
fonte
Object.assign()
vale uma olhada para aqueles que não querem criar uma função helper - funciona para "todas as propriedades enumeráveis e próprias ".Respostas:
Você pode fazer uma função auxiliar:
function setAttributes(el, attrs) { for(var key in attrs) { el.setAttribute(key, attrs[key]); } }
Chame assim:
setAttributes(elem, {"src": "http://example.com/something.jpeg", "height": "100%", ...});
fonte
elem.setAttribute()
várias vezes.Você pode usar
Object.assign(...)
para aplicar suas propriedades ao elemento criado. Veja comentários para detalhes adicionais.Lembre-se de que os atributos
height
ewidth
são definidos em pixels , não em porcentagens. Você terá que usar CSS para torná-lo fluido.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 }
fonte
Se você quisesse uma sintaxe framework-esq ( Observação: suporte para IE 8+ apenas), você poderia estender o
Element
protótipo e adicionar sua própriasetAttributes
função: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]); } } };
Isso permite que você use uma sintaxe como esta:
var d = document.createElement('div'); d.setAttributes({ 'id':'my_div', 'class':'my_class', 'styles':{ 'backgroundColor':'blue', 'color':'red' }, 'html':'lol' });
Tente: http://jsfiddle.net/ywrXX/1/
Se você não gosta de estender um objeto host ( alguns se opõem ) ou precisa oferecer suporte ao IE7-, basta usá-lo como uma função
Observe que
setAttribute
isso não funcionarástyle
no IE ou em manipuladores de eventos (de qualquer maneira, você não deveria). O código acima tratastyle
, mas não eventos.Documentação
setAttribute
no MDN - https://developer.mozilla.org/en-US/docs/DOM/element.setAttributefonte
'Element' is undefined
document.createElement
edocument.getElementById
corrigir isso .... ou apenas envolver a funcionalidade em uma função. Resposta editada para incluir essa notaVocê pode criar uma função que leva um número variável de argumentos:
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%");
Ou você passa os pares atributo / valor em um objeto:
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%" });
Você também pode fazer seu próprio wrapper / método de objeto encadeado:
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%");
Exemplo de trabalho: http://jsfiddle.net/jfriend00/qncEz/
fonte
Você pode codificar uma função auxiliar ES5.1:
function setAttributes(el, attrs) { Object.keys(attrs).forEach(key => el.setAttribute(key, attrs[key])); }
Chame assim:
setAttributes(elem, { src: 'http://example.com/something.jpeg', height: '100%' });
fonte
const setAttributes = (el, attrs) => Object.entries(attrs) .forEach(args => el.setAttribute(...args))
fonte
Ou crie uma função que crie um elemento incluindo atributos de parâmetros
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%'
não funcionaria usando atributos. Para uma altura / largura de 100% você precisa dos elementosstyle.height/style.width
fonte
clone
método seria preferível. Não há necessidade de criar o nó inteiro do zero. De qualquer forma, é prioridade minimizar o acesso ao DOM, o caso de uso mais comum.Tente isto
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: AQUI
fonte
use esta função para criar e definir atributos ao mesmo tempo
function createNode(node, attributes){ const el = document.createElement(node); for(let key in attributes){ el.setAttribute(key, attributes[key]); } return el; }
use assim
const input = createNode('input', { name: 'test', type: 'text', placeholder: 'Test' }); document.body.appendChild(input);
fonte
Eu acho que é a melhor maneira de definir atributos de uma vez para qualquer elemento desta classe.
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);
fonte
você pode simplesmente adicionar um método (setAttributes, com "s" no final) ao protótipo de "Elemento" como:
Element.prototype.setAttributes = function(obj){ for(var prop in obj) { this.setAttribute(prop, obj[prop]) } }
você pode defini-lo em uma linha:
Element.prototype.setAttributes = function(obj){ for(var prop in obj) this.setAttribute(prop, obj[prop]) }
e você pode chamá-lo normalmente como chama os outros métodos. Os atributos são fornecidos como um objeto:
elem.setAttributes({"src": "http://example.com/something.jpeg", "height": "100%", "width": "100%"})
você pode adicionar uma instrução if para lançar um erro se o argumento fornecido não for um objeto.
fonte