官术网_书友最值得收藏!

Implementing LogService

Logging is an important ally that you want during the development lifecycle of your app as well as in production. It can help you debug as well as gain important insights into how your app is used. Having a single pathway to run all logging through also provides an opportunity to reroute all the app logs somewhere else with the flip of a switch. For example, you could use a third-party debug tracking service, such as TrackJS (https://trackjs.com), via Segment (https://segment.com). You will want to run a lot of important aspects of your app through logging and it serves as a great place to have a lot of control and flexibility. 

Let's open app/modules/core/services/log.service.ts and get to work. Let's start by defining a static boolean that will serve as a simple flag we can toggle in our AppModule to enable/disable. Let's also add a few helpful methods:

import { Injectable } from '@angular/core';

@Injectable()
export class LogService {

public static ENABLE: boolean = true;

public debug(msg: any, ...formatParams: any[]) {
if (LogService.ENABLE) {
console.log(msg, formatParams);
}
}

public error(msg: any, ...formatParams: any[]) {
if (LogService.ENABLE) {
console.error(msg, formatParams);
}
}

public inspect(obj: any) {
if (LogService.ENABLE) {
console.log(obj);
console.log('typeof: ', typeof obj);
if (obj) {
console.log('constructor: ', obj.constructor.name);
for (let key in obj) {
console.log(`${key}: `, obj[key]);
}
}
}
}
}
  • debug: This will serve as our most commonly used output API for logging.
  • error: When we know a certain condition is an error, this will help identify those spots in our log.
  • inspect: There are times when viewing an object can help find a bug or help us understand the state of our app at any given moment.

With our LogService implemented, we will now use it throughout our app and the rest of this book instead of using the console directly.

主站蜘蛛池模板: 应用必备| 固原市| 富阳市| 屯昌县| 五寨县| 中超| 阆中市| 凤台县| 龙井市| 玉屏| 达孜县| 微山县| 晋宁县| 巢湖市| 华池县| 新乡县| 永昌县| 庆安县| 钦州市| 陇川县| 文化| 象山县| 仙居县| 柳河县| 磴口县| 馆陶县| 五河县| 长葛市| 左云县| 宁晋县| 康保县| 武汉市| 北票市| 安康市| 镇赉县| 大渡口区| 东莞市| 芜湖市| 保靖县| 兰坪| 永吉县|