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

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.

主站蜘蛛池模板: 邹城市| 曲阜市| 永康市| 达拉特旗| 静宁县| 五华县| 阳高县| 姜堰市| 韶关市| 台东市| 台州市| 大埔县| 柳江县| 石门县| 玉林市| 绥芬河市| 汪清县| 平舆县| 赤壁市| 望奎县| 阿拉善盟| 蒙城县| 红河县| 马关县| 山东省| 湘乡市| 汝南县| 阿巴嘎旗| 彭水| 象州县| 平山县| 安达市| 三都| 文水县| 岳西县| 丁青县| 许昌县| 东城区| 来宾市| 民勤县| 绍兴县|