1e41f4b71Sopenharmony_ci# ErrorObserver
2e41f4b71Sopenharmony_ci
3e41f4b71Sopenharmony_ciThe ErrorObserver module defines an observer to listen for application errors. It can be used as an input parameter in [ErrorManager.on](js-apis-app-ability-errorManager.md#errormanageronerror) to listen for errors that occur in the current application.
4e41f4b71Sopenharmony_ci
5e41f4b71Sopenharmony_ci> **NOTE**
6e41f4b71Sopenharmony_ci> 
7e41f4b71Sopenharmony_ci> The initial APIs of this module are supported since API version 9. Newly added APIs will be marked with a superscript to indicate their earliest API version.
8e41f4b71Sopenharmony_ci
9e41f4b71Sopenharmony_ci## Modules to Import
10e41f4b71Sopenharmony_ci
11e41f4b71Sopenharmony_ci```ts
12e41f4b71Sopenharmony_ciimport { errorManager } from '@kit.AbilityKit';
13e41f4b71Sopenharmony_ci```
14e41f4b71Sopenharmony_ci
15e41f4b71Sopenharmony_ci## ErrorObserver.onUnhandledException
16e41f4b71Sopenharmony_ci
17e41f4b71Sopenharmony_cionUnhandledException(errMsg: string): void;
18e41f4b71Sopenharmony_ci
19e41f4b71Sopenharmony_ciCalled when an unhandled exception occurs in the JS runtime.
20e41f4b71Sopenharmony_ci
21e41f4b71Sopenharmony_ci**Atomic service API**: This API can be used in atomic services since API version 11.
22e41f4b71Sopenharmony_ci
23e41f4b71Sopenharmony_ci**System capability**: SystemCapability.Ability.AbilityRuntime.Core
24e41f4b71Sopenharmony_ci
25e41f4b71Sopenharmony_ci**Parameters**
26e41f4b71Sopenharmony_ci
27e41f4b71Sopenharmony_ci| Name| Type| Mandatory| Description|
28e41f4b71Sopenharmony_ci| -------- | -------- | -------- | -------- |
29e41f4b71Sopenharmony_ci| errMsg | string | Yes| Message and error stack trace about the exception.|
30e41f4b71Sopenharmony_ci
31e41f4b71Sopenharmony_ci**Example**
32e41f4b71Sopenharmony_ci
33e41f4b71Sopenharmony_ci```ts
34e41f4b71Sopenharmony_ciimport { errorManager } from '@kit.AbilityKit';
35e41f4b71Sopenharmony_ciimport { BusinessError } from '@kit.BasicServicesKit';
36e41f4b71Sopenharmony_ci
37e41f4b71Sopenharmony_cilet observer: errorManager.ErrorObserver = {
38e41f4b71Sopenharmony_ci  onUnhandledException(errorMsg) {
39e41f4b71Sopenharmony_ci    console.error('onUnhandledException, errorMsg: ', errorMsg);
40e41f4b71Sopenharmony_ci  }
41e41f4b71Sopenharmony_ci};
42e41f4b71Sopenharmony_ci
43e41f4b71Sopenharmony_citry {
44e41f4b71Sopenharmony_ci  errorManager.on('error', observer);
45e41f4b71Sopenharmony_ci} catch (error) {
46e41f4b71Sopenharmony_ci  console.error(`registerErrorObserver failed, error.code: ${(error as BusinessError).code}, error.message: ${(error as BusinessError).message}`);
47e41f4b71Sopenharmony_ci}
48e41f4b71Sopenharmony_ci```
49e41f4b71Sopenharmony_ci
50e41f4b71Sopenharmony_ci## ErrorObserver.onException<sup>10+</sup>
51e41f4b71Sopenharmony_ci
52e41f4b71Sopenharmony_cionException?(errObject: Error): void;
53e41f4b71Sopenharmony_ci
54e41f4b71Sopenharmony_ciCalled when an exception occurs during the application running.
55e41f4b71Sopenharmony_ci
56e41f4b71Sopenharmony_ci**Atomic service API**: This API can be used in atomic services since API version 11.
57e41f4b71Sopenharmony_ci
58e41f4b71Sopenharmony_ci**System capability**: SystemCapability.Ability.AbilityRuntime.Core
59e41f4b71Sopenharmony_ci
60e41f4b71Sopenharmony_ci**Parameters**
61e41f4b71Sopenharmony_ci
62e41f4b71Sopenharmony_ci| Name| Type| Mandatory| Description|
63e41f4b71Sopenharmony_ci| -------- | -------- | -------- | -------- |
64e41f4b71Sopenharmony_ci| errObject | Error | Yes| Event name, message, and error stack of the exception.|
65e41f4b71Sopenharmony_ci
66e41f4b71Sopenharmony_ci**Example**
67e41f4b71Sopenharmony_ci
68e41f4b71Sopenharmony_ci```ts
69e41f4b71Sopenharmony_ciimport { errorManager } from '@kit.AbilityKit';
70e41f4b71Sopenharmony_ciimport { BusinessError } from '@kit.BasicServicesKit';
71e41f4b71Sopenharmony_ci
72e41f4b71Sopenharmony_cilet observer: errorManager.ErrorObserver = {
73e41f4b71Sopenharmony_ci  onUnhandledException(errorMsg) {
74e41f4b71Sopenharmony_ci    console.error('onUnhandledException, errorMsg: ', errorMsg);
75e41f4b71Sopenharmony_ci  },
76e41f4b71Sopenharmony_ci  onException(errorObj) {
77e41f4b71Sopenharmony_ci    console.log('onException, name: ', errorObj.name);
78e41f4b71Sopenharmony_ci    console.log('onException, message: ', errorObj.message);
79e41f4b71Sopenharmony_ci    if (typeof (errorObj.stack) === 'string') {
80e41f4b71Sopenharmony_ci      console.log('onException, stack: ', errorObj.stack);
81e41f4b71Sopenharmony_ci    }
82e41f4b71Sopenharmony_ci  }
83e41f4b71Sopenharmony_ci};
84e41f4b71Sopenharmony_ci
85e41f4b71Sopenharmony_citry {
86e41f4b71Sopenharmony_ci  errorManager.on('error', observer);
87e41f4b71Sopenharmony_ci} catch (error) {
88e41f4b71Sopenharmony_ci  console.error(`registerErrorObserver failed, error.code: ${(error as BusinessError).code}, error.message: ${(error as BusinessError).message}`);
89e41f4b71Sopenharmony_ci}
90e41f4b71Sopenharmony_ci```
91