Я пытаюсь создать небольшую Javascript-структуру, которую я могу использовать в своих скриптах greasemonkey. Мне нужны только очень базовые функции, поэтому я решил не использовать mooTools или DOMAssistant. Кроме того, я не собираюсь быть глупым и помещать DOMAssitant в скрипт Greasemonkey размером 20 КБ! Я просто хочу небольшой аккуратный фрагмент кода.
У меня небольшая проблема с кодом ниже. Я думаю, потому что я возвращаю массив в $ (), поэтому я получаю .setStyle не является сообщением об ошибке функции.
var fmini = {
$ : function(a) {
var i=0,obj,d;
var e = [];
while (obj = arguments[i++]) {
d = document.getElementById(obj);
d.setStyle = fmini.setStyle;
d.each = fmini.each;
e.push(d);
}
return e;
},
setStyle : function(style, value) {
if (typeof this.style.cssText !== 'undefined') {
var styleToSet = this.style.cssText;
if (typeof style === 'object') {
for (var i in style)
if (typeof i === 'string') styleToSet += ';' + i + ':' + style[i];
}
else styleToSet += ';' + style + ':' + value;
this.style.cssText = styleToSet;
}
return this;
},
each : function (functionCall) {
for (var i=0, il=this.length; i < il; i++)
functionCall.call(this[i]);
return this;
},
}
window.$ = fmini.$;
Я бы хотел, чтобы это работало, когда я делаю
$('bob','amy').setStyle({
'border' : '5px solid #ff0000',
'background-color' : '#ccc'
});