1e41f4b71Sopenharmony_ci# ConnectOptions 2e41f4b71Sopenharmony_ci 3e41f4b71Sopenharmony_ci**ConnectOptions** can be used as an input parameter to receive status changes during the connection to a background service. For example, it is used as an input parameter of [connectServiceExtensionAbility](js-apis-inner-application-uiAbilityContext.md#uiabilitycontextconnectserviceextensionability) to connect to a ServiceExtensionAbility. 4e41f4b71Sopenharmony_ci 5e41f4b71Sopenharmony_ci> **NOTE** 6e41f4b71Sopenharmony_ci> 7e41f4b71Sopenharmony_ci> The initial APIs of this module are supported since API version 7. 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 { common } from '@kit.AbilityKit'; 13e41f4b71Sopenharmony_ci``` 14e41f4b71Sopenharmony_ci 15e41f4b71Sopenharmony_ci## onConnect 16e41f4b71Sopenharmony_ci 17e41f4b71Sopenharmony_cionConnect(elementName: ElementName, remote: rpc.IRemoteObject): void 18e41f4b71Sopenharmony_ci 19e41f4b71Sopenharmony_ciCallback invoked when a connection is set up. 20e41f4b71Sopenharmony_ci 21e41f4b71Sopenharmony_ci**System capability**: SystemCapability.Ability.AbilityRuntime.Core 22e41f4b71Sopenharmony_ci 23e41f4b71Sopenharmony_ci**Parameters** 24e41f4b71Sopenharmony_ci 25e41f4b71Sopenharmony_ci| Name | Type | Mandatory | Description | 26e41f4b71Sopenharmony_ci| -------- | ---------------------- | ---- | ------------- | 27e41f4b71Sopenharmony_ci| elementName | [ElementName](js-apis-bundleManager-elementName.md) | Yes | Element name of the ability. | 28e41f4b71Sopenharmony_ci| remote | [rpc.IRemoteObject](../apis-ipc-kit/js-apis-rpc.md#iremoteobject) | Yes | **IRemoteObject** instance. | 29e41f4b71Sopenharmony_ci 30e41f4b71Sopenharmony_ci**Example** 31e41f4b71Sopenharmony_ci 32e41f4b71Sopenharmony_ci```ts 33e41f4b71Sopenharmony_ciimport { UIAbility, common, Want, AbilityConstant } from '@kit.AbilityKit'; 34e41f4b71Sopenharmony_ciimport { bundleManager } from '@kit.AbilityKit'; 35e41f4b71Sopenharmony_ciimport { rpc } from '@kit.IPCKit'; 36e41f4b71Sopenharmony_ci 37e41f4b71Sopenharmony_cilet connectWant: Want = { 38e41f4b71Sopenharmony_ci bundleName: 'com.example.myapp', 39e41f4b71Sopenharmony_ci abilityName: 'MyAbility' 40e41f4b71Sopenharmony_ci}; 41e41f4b71Sopenharmony_ci 42e41f4b71Sopenharmony_cilet connectOptions: common.ConnectOptions = { 43e41f4b71Sopenharmony_ci onConnect(elementName: bundleManager.ElementName, remote: rpc.IRemoteObject) { 44e41f4b71Sopenharmony_ci console.log(`onConnect elementName: ${elementName}`); 45e41f4b71Sopenharmony_ci }, 46e41f4b71Sopenharmony_ci onDisconnect(elementName: bundleManager.ElementName) { 47e41f4b71Sopenharmony_ci console.log(`onDisconnect elementName: ${elementName}`); 48e41f4b71Sopenharmony_ci }, 49e41f4b71Sopenharmony_ci onFailed(code: number) { 50e41f4b71Sopenharmony_ci console.error(`onFailed code: ${code}`); 51e41f4b71Sopenharmony_ci } 52e41f4b71Sopenharmony_ci}; 53e41f4b71Sopenharmony_ci 54e41f4b71Sopenharmony_ciclass EntryAbility extends UIAbility { 55e41f4b71Sopenharmony_ci onCreate(want: Want, launchParam: AbilityConstant.LaunchParam) { 56e41f4b71Sopenharmony_ci let connection: number = this.context.connectServiceExtensionAbility(connectWant, connectOptions); 57e41f4b71Sopenharmony_ci } 58e41f4b71Sopenharmony_ci} 59e41f4b71Sopenharmony_ci``` 60e41f4b71Sopenharmony_ci 61e41f4b71Sopenharmony_ci## onDisconnect 62e41f4b71Sopenharmony_ci 63e41f4b71Sopenharmony_cionDisconnect(elementName: ElementName): void 64e41f4b71Sopenharmony_ci 65e41f4b71Sopenharmony_ciCallback invoked when a connection is interrupted. 66e41f4b71Sopenharmony_ci 67e41f4b71Sopenharmony_ci**System capability**: SystemCapability.Ability.AbilityRuntime.Core 68e41f4b71Sopenharmony_ci 69e41f4b71Sopenharmony_ci**Parameters** 70e41f4b71Sopenharmony_ci 71e41f4b71Sopenharmony_ci| Name | Type | Mandatory | Description | 72e41f4b71Sopenharmony_ci| -------- | ---------------------- | ---- | ------------- | 73e41f4b71Sopenharmony_ci| elementName | [ElementName](js-apis-bundleManager-elementName.md) | Yes | Element name of the ability. | 74e41f4b71Sopenharmony_ci 75e41f4b71Sopenharmony_ci**Example** 76e41f4b71Sopenharmony_ci 77e41f4b71Sopenharmony_ci```ts 78e41f4b71Sopenharmony_ciimport { UIAbility, common, Want, AbilityConstant } from '@kit.AbilityKit'; 79e41f4b71Sopenharmony_ciimport { bundleManager } from '@kit.AbilityKit'; 80e41f4b71Sopenharmony_ciimport { rpc } from '@kit.IPCKit'; 81e41f4b71Sopenharmony_ci 82e41f4b71Sopenharmony_cilet connectWant: Want = { 83e41f4b71Sopenharmony_ci bundleName: 'com.example.myapp', 84e41f4b71Sopenharmony_ci abilityName: 'MyAbility' 85e41f4b71Sopenharmony_ci}; 86e41f4b71Sopenharmony_ci 87e41f4b71Sopenharmony_cilet connectOptions: common.ConnectOptions = { 88e41f4b71Sopenharmony_ci onConnect(elementName: bundleManager.ElementName, remote: rpc.IRemoteObject) { 89e41f4b71Sopenharmony_ci console.log(`onConnect elementName: ${elementName}`); 90e41f4b71Sopenharmony_ci }, 91e41f4b71Sopenharmony_ci onDisconnect(elementName: bundleManager.ElementName) { 92e41f4b71Sopenharmony_ci console.log(`onDisconnect elementName: ${elementName}`); 93e41f4b71Sopenharmony_ci }, 94e41f4b71Sopenharmony_ci onFailed(code: number) { 95e41f4b71Sopenharmony_ci console.error(`onFailed code: ${code}`); 96e41f4b71Sopenharmony_ci } 97e41f4b71Sopenharmony_ci}; 98e41f4b71Sopenharmony_ci 99e41f4b71Sopenharmony_ciclass EntryAbility extends UIAbility { 100e41f4b71Sopenharmony_ci onCreate(want: Want, launchParam: AbilityConstant.LaunchParam) { 101e41f4b71Sopenharmony_ci let connection: number = this.context.connectServiceExtensionAbility(connectWant, connectOptions); 102e41f4b71Sopenharmony_ci } 103e41f4b71Sopenharmony_ci} 104e41f4b71Sopenharmony_ci``` 105e41f4b71Sopenharmony_ci 106e41f4b71Sopenharmony_ci## onFailed 107e41f4b71Sopenharmony_ci 108e41f4b71Sopenharmony_cionFailed(code: number): void 109e41f4b71Sopenharmony_ci 110e41f4b71Sopenharmony_ciCallback invoked when a connection fails. 111e41f4b71Sopenharmony_ci 112e41f4b71Sopenharmony_ci**System capability**: SystemCapability.Ability.AbilityRuntime.Core 113e41f4b71Sopenharmony_ci 114e41f4b71Sopenharmony_ci**Parameters** 115e41f4b71Sopenharmony_ci 116e41f4b71Sopenharmony_ci| Name | Type | Mandatory | Description | 117e41f4b71Sopenharmony_ci| -------- | ---------------------- | ---- | ------------- | 118e41f4b71Sopenharmony_ci| code | number | Yes | Result code.<br>The value **0** means that the connection is successful, **-1** means that a parameter is incorrect, and **-2** means that the ability is not found. | 119e41f4b71Sopenharmony_ci 120e41f4b71Sopenharmony_ci**Example** 121e41f4b71Sopenharmony_ci 122e41f4b71Sopenharmony_ci```ts 123e41f4b71Sopenharmony_ciimport { UIAbility, common, Want, AbilityConstant } from '@kit.AbilityKit'; 124e41f4b71Sopenharmony_ciimport { bundleManager } from '@kit.AbilityKit'; 125e41f4b71Sopenharmony_ciimport { rpc } from '@kit.IPCKit'; 126e41f4b71Sopenharmony_ci 127e41f4b71Sopenharmony_cilet connectWant: Want = { 128e41f4b71Sopenharmony_ci bundleName: 'com.example.myapp', 129e41f4b71Sopenharmony_ci abilityName: 'MyAbility' 130e41f4b71Sopenharmony_ci}; 131e41f4b71Sopenharmony_ci 132e41f4b71Sopenharmony_cilet connectOptions: common.ConnectOptions = { 133e41f4b71Sopenharmony_ci onConnect(elementName: bundleManager.ElementName, remote: rpc.IRemoteObject) { 134e41f4b71Sopenharmony_ci console.log(`onConnect elementName: ${elementName}`); 135e41f4b71Sopenharmony_ci }, 136e41f4b71Sopenharmony_ci onDisconnect(elementName: bundleManager.ElementName) { 137e41f4b71Sopenharmony_ci console.log(`onDisconnect elementName: ${elementName}`); 138e41f4b71Sopenharmony_ci }, 139e41f4b71Sopenharmony_ci onFailed(code: number) { 140e41f4b71Sopenharmony_ci console.error(`onFailed code: ${code}`); 141e41f4b71Sopenharmony_ci } 142e41f4b71Sopenharmony_ci}; 143e41f4b71Sopenharmony_ci 144e41f4b71Sopenharmony_ciclass EntryAbility extends UIAbility { 145e41f4b71Sopenharmony_ci onCreate(want: Want, launchParam: AbilityConstant.LaunchParam) { 146e41f4b71Sopenharmony_ci let connection: number = this.context.connectServiceExtensionAbility(connectWant, connectOptions); 147e41f4b71Sopenharmony_ci } 148e41f4b71Sopenharmony_ci} 149e41f4b71Sopenharmony_ci``` 150