#javascript #node.js #for-loop
#javascript #node.js #for-цикл
Вопрос:
Я использовал библиотеку обработки объектов, созданную на заказ (для экзаменов нельзя использовать вещи, которые я не программирую лично, т. Е. JS.class ), который имеет тенденцию нарушать область действия функций.
Файл base.js
/**
* Module internals
*/
function _add() {
var obj_out = arguments[0];
for (var i=1; i < arguments.length; i ) { var arg = arguments[i];
for(prop in arg) { obj_out[prop] = arg[prop]; }
};
return obj_out;
}
function _merge() {
var obj_out = {};
for (var i=1; i < arguments.length; i ) { var arg = arguments[i];
for(prop in arg) { obj_out[prop] = arg[prop]; }
};
return obj_out;
}
function _args(args) {
return Array.prototype.slice.call(args, 0);
}
function _filterProps(items, re) {
console.log("Items: ", items);
var obj_out = {};
console.log("Before: ", obj_out);
var keys = [];
for(var key in items) {
keys.push(key);
}
console.log("Keys: ", keys);
for (var i=0; i < keys.length; i ) { var key = keys[i];
if(!re.test(key)){
obj_out[key] = items[key];
console.log("Step: ", obj_out);
}
}
console.log("After: ", obj_out);
return obj_out;
}
/**
* Class declaration
* Usage:
{
$extends: <classe parente>
$include: [<modules>]
$new: <constructeur>
$static: <methodes statiques>
$methods: <methodes>
}
*/
exports.Class = function(items) {
var base = !items["$extends"] ? Object.prototype : items["$extends"].prototype;
var incs = !items["$include"]? [] : items["$include"];
var stat = !items["$static"] ? {} : items["$static"];
var meth = !items["$methods"] ? {} : items["$methods"];
var cons = !items["$new"] ? function(){} : items["$new"];
var left = _filterProps(items, /^$/);
var cls = function() {
console.log("Constructor");
console.log(arguments);
cons.apply(this, _args(arguments));
};
cls = _add(cls, stat);
cls.prototype = base;
for (var i=0; i < incs.length; i ) {
_add(cls.prototype, incs[i]);
};
_add(cls.prototype, left);
_add(cls.prototype, meth);
return cls;
}
Файл test.js
Base = require('./base');
var SomeClass = Base.Class({
$new: function() { console.log("new"); },
foo: function() { console.log("foo"); },
});
var OtherClass = Base.Class({
$new: function() { console.log("new"); },
bar: function() { console.log("bar"); }
});
console.log("SomeClass: ", SomeClass.prototype);
console.log("OtherClass: ", OtherClass.prototype);
Вывод «узла test.js «
Items: { '$new': [Function], foo: [Function] }
Before: {}
Keys: [ '$new', 'foo' ]
Step: { foo: [Function] }
After: { foo: [Function] }
Items: { '$new': [Function], bar: [Function] }
Before: {}
Keys: [ '$new', 'bar', 'foo' ]
Step: { bar: [Function] }
Step: { bar: [Function], foo: [Function] }
After: { bar: [Function], foo: [Function] }
SomeClass: { foo: [Function], bar: [Function] }
OtherClass: { foo: [Function], bar: [Function] }
Функция _filterProps имеет тенденцию сохранять некоторые значения в своем «for..in » петля, и я не могу сказать, почему. И я немного растерялся, потому что javascript не моя сильная сторона.
Моя версия узла — v0.5.8-pre на максимальной OSX 10.6
Редактировать
Что ж, благодаря Заку Блуму и его способности видеть скрытые ошибки, я обнаружил, что забыл скопировать объект «Object.prototype», чтобы он ссылался на него.
Спасибо, JD
Комментарии:
1. Вы, кажется, злоупотребляете OO. Выполнение OO в JS
Ответ №1:
Похоже, вы расширяете Object.prototype, который изменит все объекты.
base = Object.prototype
cls.prototype = base
_add(cls.prototype, ...)
Комментарии:
1. Ну, ФФФФФФУУУУУУУУ, я забыл скопировать объект, как глупо с моей стороны. собираюсь попробовать это прямо сейчас!
Ответ №2:
Даже в инструкции цикла вы должны объявлять переменные, которые вы используете, иначе они станут глобальными. Например. измените такие вещи, как
for(prop in arg) { obj_out[prop] = arg[prop]; }
к чему-то вроде
for(var prop in arg) { obj_out[prop] = arg[prop]; }
Редактировать: на самом деле, ваша проблема в другом, но это все еще проблема в вашем коде.