Javascript-форум (https://javascript.ru/forum/)
-   Общие вопросы Javascript (https://javascript.ru/forum/misc/)
-   -   Вывести соответствующее сообщение логгера (https://javascript.ru/forum/misc/84141-vyvesti-sootvetstvuyushhee-soobshhenie-loggera.html)

рони 14.06.2022 20:51

NovichokJS,
так логичнее ...
const createLogger = () => {
    let type = '';
    let message = '';
    let dateTime = '';
    let arr = [];

    function warn(messageOfWarn) {
        type = 'warn';
        message = messageOfWarn;
        dateTime = new Date();
        arr.push({type, message, dateTime});
    }

    function error(messageOfError) {
        type = 'error';
        message = messageOfError;
        dateTime = new Date();
        arr.push({type, message, dateTime});
    }

    function log(messageOfLog) {
        type = 'log';
        message = messageOfLog;
         dateTime = new Date();
        arr.push({type, message, dateTime});
    }

    function getRecords(type) {
        return arr.filter(({type : e}) => e == type);
    }
    return {
        warn,
        error,
        log,
        getRecords,
    }
};

// examples
const logger1 = createLogger();
logger1.log('User logged in');
logger1.warn('User is tring to ented restricted page');
logger1.log('User logged out');
logger1.error('Unexpected error on the site');
console.log(logger1.getRecords('log')); // ===> [{ message: 'User logged out', type: 'log', dateTime: Date }, { message: 'User logged in', type: 'log', dateTime: Date }]

voraa 15.06.2022 11:00

Цитата:

Сообщение от рони
так логичнее ...

Еще логичнее классом все это оформить.

class Logger {
    arr = [];
	
	add (type, message) {
        this.arr.push({type, message, dateTime: new Date()});
	}
    warn(message) {this.add ('warn', message)}
 
    error(message) {this.add ('error', message)}
 
    log(message) {this.add ('log', message)}
 
    getRecords(stype) {
        return this.arr.filter(({type}) => stype == type);
    }
};
 
// examples
const logger1 = new Logger();
logger1.log('User logged in');
logger1.warn('User is tring to ented restricted page');
logger1.log('User logged out');
logger1.error('Unexpected error on the site');

console.log(logger1.getRecords('log')); // ===> [{ message: 'User logged out', type: 'log', dateTime: Date }, { message: 'User logged in', type: 'log', dateTime: Date }]

рони 15.06.2022 11:31

voraa,
:thanks:


Часовой пояс GMT +3, время: 16:32.