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

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.

主站蜘蛛池模板: 左云县| 南汇区| 定安县| 蒲城县| 韩城市| 衡阳市| 金堂县| 桂阳县| 林州市| 甘孜| 博客| 伊吾县| 自贡市| 四平市| 平乐县| 霍邱县| 习水县| 崇左市| 安远县| 工布江达县| 汉中市| 抚远县| 江华| 武穴市| 象山县| 郁南县| 时尚| 内乡县| 龙胜| 马龙县| 西乌| 永年县| 额济纳旗| 黔西| 长宁县| 屯昌县| 宁陵县| 新巴尔虎右旗| 厦门市| 航空| 明水县|