- NativeScript for Angular Mobile Development
- Nathan Walker Nathanael J. Anderson
- 313字
- 2021-07-02 18:41:48
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.
- Mastering OpenLayers 3
- Node.js+Webpack開發(fā)實戰(zhàn)
- Building a RESTful Web Service with Spring
- 深入淺出WPF
- 從0到1:HTML+CSS快速上手
- Android Wear Projects
- 智能搜索和推薦系統(tǒng):原理、算法與應用
- Hadoop 2.X HDFS源碼剖析
- Building Dynamics CRM 2015 Dashboards with Power BI
- 3ds Max印象 電視欄目包裝動畫與特效制作
- Mastering Elixir
- Data Science Algorithms in a Week
- LabVIEW入門與實戰(zhàn)開發(fā)100例(第4版)
- Extending Docker
- C語言程序設計