Değişken sayıda argüman alan bir işlev oluşturabilirsiniz:
function setAttributes(elem ) {
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%");
Veya öznitelik / değer çiftlerini bir nesneye iletirsiniz:
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%"
});
Ayrıca kendi zincirlenebilir nesne sarmalayıcınızı / yönteminizi de yapabilirsiniz:
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%");
Çalışma örneği: http://jsfiddle.net/jfriend00/qncEz/
Object.assign(), yardımcı bir işlev oluşturmak istemeyenler için bir göz atmaya değer - "tüm numaralandırılabilir ve kendi özellikleri" için çalışır.