js-apis-telephony-data.md 28.4 KB
Newer Older
Z
zengyawen 已提交
1
# @ohos.telephony.data (蜂窝数据)
2

C
clevercong 已提交
3 4
蜂窝数据提供了移动数据管理能力,包括获取、设置默认移动数据的SIM卡,获取蜂窝数据业务的上下行和分组交换域(PS域)的连接状态,以及检查蜂窝数据业务和漫游是否启用等。

Z
zengyawen 已提交
5
>**说明:**
6 7 8 9 10
>
>本模块首批接口从API version 7开始支持。后续版本的新增接口,采用上角标单独标记接口的起始版本。 

## 导入模块

Z
zengyawen 已提交
11
```js
12 13 14
import data from '@ohos.telephony.data';
```

C
clevercong 已提交
15
## data.getDefaultCellularDataSlotId
16 17 18 19 20 21 22 23 24 25 26 27 28 29 30

getDefaultCellularDataSlotId(callback: AsyncCallback\<number\>): void 

获取默认移动数据的SIM卡,使用callback方式作为异步方法。 

**系统能力**:SystemCapability.Telephony.CellularData

**参数:**

| 参数名   | 类型                    | 必填 | 说明                                       |
| -------- | ----------------------- | ---- | ------------------------------------------ |
| callback | AsyncCallback\<number\> | 是   | 回调函数。<br />0:卡槽1。<br />1:卡槽2。 |

**示例:**

Z
zengyawen 已提交
31
```js
32 33 34 35 36
data.getDefaultCellularDataSlotId((err, data) => {
    console.log(`callback: err->${JSON.stringify(err)}, data->${JSON.stringify(data)}`);
});
```

C
clevercong 已提交
37
## data.getDefaultCellularDataSlotId
38 39 40 41 42 43 44 45 46 47 48 49 50 51 52

getDefaultCellularDataSlotId(): Promise\<number\> 

获取默认移动数据的SIM卡,使用Promise方式作为异步方法。 

**系统能力**:SystemCapability.Telephony.CellularData

**返回值:**

| 类型              | 说明                                                         |
| ----------------- | ------------------------------------------------------------ |
| Promise\<number\> | 以Promise形式返回获取默认移动数据的SIM卡。<br />0:卡槽1。<br />1:卡槽2。 |

**示例:**

Z
zengyawen 已提交
53
```js
54 55
let promise = data.getDefaultCellularDataSlotId();
promise.then((data) => {
Y
YOUR_NAME 已提交
56
    console.log(`getDefaultCellularDataSlotId success, promise: data->${JSON.stringify(data)}`);
57
}).catch((err) => {
Y
YOUR_NAME 已提交
58 59 60 61
    console.error(`getDefaultCellularDataSlotId fail, promise: err->${JSON.stringify(err)}`);
});
```

Y
YOUR_NAME 已提交
62
## data.getDefaultCellularDataSlotIdSync<sup>9+</sup>
D
dingxiaochen 已提交
63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81

getDefaultCellularDataSlotIdSync(): number

获取默认移动数据的SIM卡

**系统能力**:SystemCapability.Telephony.CellularData

**返回值:**

| 类型              | 说明                                                         |
| ------ | -------------------------------------------------- |
| number | 获取默认移动数据的SIM卡。<br />0:卡槽1。<br />1:卡槽2。 |

**示例:**

```js
console.log("Result: "+ data.getDefaultCellularDataSlotIdSync())
```

Y
YOUR_NAME 已提交
82 83
## data.setDefaultCellularDataSlotId

D
dingxiaochen 已提交
84
setDefaultCellularDataSlotId(slotId: number, callback: AsyncCallback\<void\>): void 
Y
YOUR_NAME 已提交
85 86 87

设置默认移动数据的SIM卡,使用callback方式作为异步方法。 

D
dingxiaochen 已提交
88
**系统接口:** 此接口为系统接口。
C
clevercong 已提交
89

Y
YOUR_NAME 已提交
90 91 92 93 94 95 96 97 98
**需要权限**:ohos.permission.SET_TELEPHONY_STATE

**系统能力**:SystemCapability.Telephony.CellularData

**参数:**

| 参数名   | 类型                  | 必填 | 说明                                                         |
| -------- | --------------------- | ---- | ------------------------------------------------------------ |
| slotId   | number                | 是   | SIM卡槽ID。<br/>- 0:卡槽1。<br/>- 1:卡槽2。<br/>- -1:清除默认配置。 |
C
clevercong 已提交
99
| callback | AsyncCallback\<void\> | 是   | 回调函数。                                                   |
Y
YOUR_NAME 已提交
100

D
dingxiaochen 已提交
101 102
**错误码:**

D
dingxiaochen 已提交
103 104
以下错误码的详细介绍请参见[ohos.telephony(电话子系统)错误码](../../reference/errorcodes/errorcode-telephony.md)错误码。

D
dingxiaochen 已提交
105 106 107 108 109 110 111 112 113 114 115
| 错误码ID |                 错误信息                     |
| -------- | -------------------------------------------- |
| 201      | Permission denied.                           |
| 401      | Parameter error.                             |
| 8300001  | Invalid parameter value.                     |
| 8300002  | Operation failed. Cannot connect to service. |
| 8300003  | System internal error.                       |
| 8300004  | Do not have sim card.                        |
| 8300999  | Unknown error code.                          |
| 8301001  | SIM card is not activated.                   |

Y
YOUR_NAME 已提交
116 117 118
**示例:**

```js
D
dingxiaochen 已提交
119 120
data.setDefaultCellularDataSlotId(0, (err) => {
    console.log(`callback: err->${JSON.stringify(err)}.`);
Y
YOUR_NAME 已提交
121 122 123 124 125 126 127 128 129
});
```

## data.setDefaultCellularDataSlotId

setDefaultCellularDataSlotId(slotId: number): Promise\<void\> 

设置默认移动数据的SIM卡,使用Promise方式作为异步方法。 

D
dingxiaochen 已提交
130
**系统接口:** 此接口为系统接口。
C
clevercong 已提交
131

Y
YOUR_NAME 已提交
132 133 134 135 136 137 138 139 140 141 142 143
**需要权限**:ohos.permission.SET_TELEPHONY_STATE

**系统能力**:SystemCapability.Telephony.CellularData

**参数:**

| 参数名 | 类型   | 必填 | 说明                                                         |
| ------ | ------ | ---- | ------------------------------------------------------------ |
| slotId | number | 是   | SIM卡槽ID。<br/>- 0:卡槽1。<br/>- 1:卡槽2。<br/>- -1:清除默认配置。 |

**返回值:**

C
clevercong 已提交
144 145 146
| 类型            | 说明                            |
| --------------- | ------------------------------- |
| Promise\<void\> | 以Promise形式异步返回设置结果。 |
Y
YOUR_NAME 已提交
147

D
dingxiaochen 已提交
148 149
**错误码:**

D
dingxiaochen 已提交
150 151
以下错误码的详细介绍请参见[ohos.telephony(电话子系统)错误码](../../reference/errorcodes/errorcode-telephony.md)错误码。

D
dingxiaochen 已提交
152 153 154 155 156 157 158 159 160 161 162
| 错误码ID |                 错误信息                     |
| -------- | -------------------------------------------- |
| 201      | Permission denied.                           |
| 401      | Parameter error.                             |
| 8300001  | Invalid parameter value.                     |
| 8300002  | Operation failed. Cannot connect to service. |
| 8300003  | System internal error.                       |
| 8300004  | Do not have sim card.                        |
| 8300999  | Unknown error code.                          |
| 8301001  | SIM card is not activated.                   |

Y
YOUR_NAME 已提交
163 164 165 166
**示例:**

```js
let promise = data.setDefaultCellularDataSlotId(0);
D
dingxiaochen 已提交
167 168
promise.then(() => {
    console.log(`setDefaultCellularDataSlotId success.`);
Y
YOUR_NAME 已提交
169 170
}).catch((err) => {
    console.error(`setDefaultCellularDataSlotId fail, promise: err->${JSON.stringify(err)}`);
171 172 173
});
```

C
clevercong 已提交
174
## data.getCellularDataFlowType
175 176 177 178 179 180 181 182 183 184 185

getCellularDataFlowType(callback: AsyncCallback\<DataFlowType\>): void

获取蜂窝数据业务的上下行状态,使用callback方式作为异步方法。

**系统能力**:SystemCapability.Telephony.CellularData

**参数:**

| 参数名   | 类型                                           | 必填 | 说明       |
| -------- | ---------------------------------------------- | ---- | ---------- |
C
clevercong 已提交
186
| callback | AsyncCallback\<[DataFlowType](#dataflowtype)\> | 是   | 回调函数。 |
187 188 189

**示例:**

Z
zengyawen 已提交
190
```js
191 192 193 194 195
data.getCellularDataFlowType((err, data) => {
    console.log(`callback: err->${JSON.stringify(err)}, data->${JSON.stringify(data)}`);
});
```

C
clevercong 已提交
196
## data.getCellularDataFlowType
197 198 199 200 201 202 203 204 205 206 207

getCellularDataFlowType(): Promise\<DataFlowType\>

获取蜂窝数据业务的上下行状态,使用Promise方式作为异步方法。

**系统能力**:SystemCapability.Telephony.CellularData

**返回值:**

| 类型                                     | 说明                                            |
| ---------------------------------------- | ----------------------------------------------- |
C
clevercong 已提交
208
| Promise\<[DataFlowType](#dataflowtype)\> | 以Promise形式返回获取蜂窝数据业务的上下行状态。 |
209 210 211

**示例:**

Z
zengyawen 已提交
212
```js
213 214 215 216 217 218 219 220
let promise = data.getCellularDataFlowType();
promise.then((data) => {
    console.log(`test success, promise: data->${JSON.stringify(data)}`);
}).catch((err) => {
    console.error(`test fail, promise: err->${JSON.stringify(err)}`);
});
```

C
clevercong 已提交
221
## data.getCellularDataState
222 223 224 225 226 227 228 229 230 231 232

getCellularDataState(callback: AsyncCallback\<DataConnectState\>): void

获取分组交换域(PS域)的连接状态,使用callback方式作为异步方法。

**系统能力**:SystemCapability.Telephony.CellularData

**参数:**

| 参数名   | 类型                                                   | 必填 | 说明       |
| -------- | ------------------------------------------------------ | ---- | ---------- |
C
clevercong 已提交
233
| callback | AsyncCallback\<[DataConnectState](#dataconnectstate)\> | 是   | 回调函数。 |
234 235 236

**示例:**

Z
zengyawen 已提交
237
```js
238 239 240 241 242
data.getCellularDataState((err, data) => {
    console.log(`callback: err->${JSON.stringify(err)}, data->${JSON.stringify(data)}`);
});
```

C
clevercong 已提交
243
## data.getCellularDataState
244 245 246 247 248 249 250 251 252 253 254

getCellularDataState(): Promise\<DataConnectState\>

获取分组交换域(PS域)的连接状态,使用Promise方式作为异步方法。

**系统能力**:SystemCapability.Telephony.CellularData

**返回值:**

| 类型                                             | 说明                                  |
| ------------------------------------------------ | ------------------------------------- |
C
clevercong 已提交
255
| Promise\<[DataConnectState](#dataconnectstate)\> | 以Promise形式返回获取PS域的连接状态。 |
256 257 258

**示例:**

Z
zengyawen 已提交
259
```js
260 261 262 263 264 265 266 267
let promise = data.getCellularDataState();
promise.then((data) => {
    console.log(`test success, promise: data->${JSON.stringify(data)}`);
}).catch((err) => {
    console.error(`test fail, promise: err->${JSON.stringify(err)}`);
});
```

C
clevercong 已提交
268
## data.isCellularDataEnabled
269 270 271 272 273 274 275 276 277 278 279 280 281 282 283

isCellularDataEnabled(callback: AsyncCallback\<boolean\>): void

检查蜂窝数据业务是否启用,使用callback方式作为异步方法。

**需要权限**:ohos.permission.GET_NETWORK_INFO

**系统能力**:SystemCapability.Telephony.CellularData

**参数:**

| 参数名   | 类型                     | 必填 | 说明                                                         |
| -------- | ------------------------ | ---- | ------------------------------------------------------------ |
| callback | AsyncCallback\<boolean\> | 是   | 回调函数。<br />true:蜂窝数据业务已启用。<br />false:蜂窝数据业务已禁用。 |

D
dingxiaochen 已提交
284 285
**错误码:**

D
dingxiaochen 已提交
286 287
以下错误码的详细介绍请参见[ohos.telephony(电话子系统)错误码](../../reference/errorcodes/errorcode-telephony.md)错误码。

D
dingxiaochen 已提交
288 289 290 291 292 293 294 295 296
| 错误码ID |                 错误信息                     |
| -------- | -------------------------------------------- |
| 201      | Permission denied.                           |
| 401      | Parameter error.                             |
| 8300001  | Invalid parameter value.                     |
| 8300002  | Operation failed. Cannot connect to service. |
| 8300003  | System internal error.                       |
| 8300999  | Unknown error code.                          |

297 298
**示例:**

Z
zengyawen 已提交
299
```js
300 301 302 303 304
data.isCellularDataEnabled((err, data) => {
    console.log(`callback: err->${JSON.stringify(err)}, data->${JSON.stringify(data)}`);
});
```

C
clevercong 已提交
305
## data.isCellularDataEnabled
306 307 308 309 310 311 312 313 314 315 316 317 318 319 320

isCellularDataEnabled(): Promise\<boolean\>

检查蜂窝数据业务是否启用,使用Promise方式作为异步方法。

**需要权限**:ohos.permission.GET_NETWORK_INFO

**系统能力**:SystemCapability.Telephony.CellularData

**返回值:**

| 类型               | 说明                                                         |
| ------------------ | ------------------------------------------------------------ |
| Promise\<boolean\> | 以Promise形式返回检查蜂窝数据业务是否启用。<br />true:蜂窝数据业务已启用。<br />false:蜂窝数据业务已禁用。 |

D
dingxiaochen 已提交
321 322
**错误码:**

D
dingxiaochen 已提交
323 324
以下错误码的详细介绍请参见[ohos.telephony(电话子系统)错误码](../../reference/errorcodes/errorcode-telephony.md)错误码。

D
dingxiaochen 已提交
325 326 327 328 329 330 331 332 333
| 错误码ID |                 错误信息                     |
| -------- | -------------------------------------------- |
| 201      | Permission denied.                           |
| 401      | Parameter error.                             |
| 8300001  | Invalid parameter value.                     |
| 8300002  | Operation failed. Cannot connect to service. |
| 8300003  | System internal error.                       |
| 8300999  | Unknown error code.                          |

334 335
**示例:**

Z
zengyawen 已提交
336
```js
337 338 339 340 341 342 343 344
let promise = data.isCellularDataEnabled();
promise.then((data) => {
    console.log(`test success, promise: data->${JSON.stringify(data)}`);
}).catch((err) => {
    console.error(`test fail, promise: err->${JSON.stringify(err)}`);
});
```

C
clevercong 已提交
345
## data.isCellularDataRoamingEnabled
346 347 348 349 350 351 352 353 354 355 356 357 358 359 360 361

isCellularDataRoamingEnabled(slotId: number, callback: AsyncCallback\<boolean\>): void

检查蜂窝数据业务是否启用漫游,使用callback方式作为异步方法。

**需要权限**:ohos.permission.GET_NETWORK_INFO

**系统能力**:SystemCapability.Telephony.CellularData

**参数:**

| 参数名   | 类型                     | 必填 | 说明                                                         |
| -------- | ------------------------ | ---- | ------------------------------------------------------------ |
| slotId   | number                   | 是   | 卡槽ID。<br />0:卡槽1。<br />1:卡槽2。                     |
| callback | AsyncCallback\<boolean\> | 是   | 回调函数。<br />true:蜂窝数据业务已启用漫游。<br />false:蜂窝数据业务已禁用漫游。 |

D
dingxiaochen 已提交
362 363
**错误码:**

D
dingxiaochen 已提交
364 365
以下错误码的详细介绍请参见[ohos.telephony(电话子系统)错误码](../../reference/errorcodes/errorcode-telephony.md)错误码。

D
dingxiaochen 已提交
366 367 368 369 370 371 372 373 374
| 错误码ID |                  错误信息                    |
| -------- | -------------------------------------------- |
| 201      | Permission denied.                           |
| 401      | Parameter error.                             |
| 8300001  | Invalid parameter value.                     |
| 8300002  | Operation failed. Cannot connect to service. |
| 8300003  | System internal error.                       |
| 8300999  | Unknown error code.                          |

375 376
**示例:**

Z
zengyawen 已提交
377
```js
D
dingxiaochen 已提交
378
data.isCellularDataRoamingEnabled(0, (err, data) => {
379 380 381 382
    console.log(`callback: err->${JSON.stringify(err)}, data->${JSON.stringify(data)}`);
});
```

C
clevercong 已提交
383
## data.isCellularDataRoamingEnabled
384 385 386 387 388 389 390 391 392 393 394 395 396 397 398 399 400 401 402 403 404

isCellularDataRoamingEnabled(slotId: number): Promise\<boolean\>

检查蜂窝数据业务是否启用漫游,使用Promise方式作为异步方法。

**需要权限**:ohos.permission.GET_NETWORK_INFO

**系统能力**:SystemCapability.Telephony.CellularData

**参数:**

| 参数名 | 类型   | 必填 | 说明                                     |
| ------ | ------ | ---- | ---------------------------------------- |
| slotId | number | 是   | 卡槽ID。<br />0:卡槽1。<br />1:卡槽2。 |

**返回值:**

| 类型               | 说明                                                         |
| ------------------ | ------------------------------------------------------------ |
| Promise\<boolean\> | 以Promise形式返回检查蜂窝数据业务是否启用漫游。<br />true:蜂窝数据业务已启用漫游。<br />false:蜂窝数据业务已禁用漫游。 |

D
dingxiaochen 已提交
405 406
**错误码:**

D
dingxiaochen 已提交
407 408
以下错误码的详细介绍请参见[ohos.telephony(电话子系统)错误码](../../reference/errorcodes/errorcode-telephony.md)错误码。

D
dingxiaochen 已提交
409 410 411 412 413 414 415 416 417
| 错误码ID |                  错误信息                    |
| -------- | -------------------------------------------- |
| 201      | Permission denied.                           |
| 401      | Parameter error.                             |
| 8300001  | Invalid parameter value.                     |
| 8300002  | Operation failed. Cannot connect to service. |
| 8300003  | System internal error.                       |
| 8300999  | Unknown error code.                          |

418 419
**示例:**

Z
zengyawen 已提交
420
```js
421 422 423 424 425 426 427 428
let promise = data.isCellularDataRoamingEnabled(0);
promise.then((data) => {
    console.log(`test success, promise: data->${JSON.stringify(data)}`);
}).catch((err) => {
    console.error(`test fail, promise: err->${JSON.stringify(err)}`);
});
```

C
clevercong 已提交
429 430 431 432 433 434
## data.enableCellularData

enableCellularData(callback: AsyncCallback<void\>): void

启用蜂窝数据服务,使用callback方式作为异步方法。

D
dingxiaochen 已提交
435
**系统接口:** 此接口为系统接口。
C
clevercong 已提交
436 437 438 439 440 441 442 443 444 445 446

**需要权限**:ohos.permission.SET_TELEPHONY_STATE

**系统能力**:SystemCapability.Telephony.CellularData

**参数:**

| 参数名   | 类型                  | 必填 | 说明       |
| -------- | --------------------- | ---- | ---------- |
| callback | AsyncCallback\<void\> | 是   | 回调函数。 |

D
dingxiaochen 已提交
447 448
**错误码:**

D
dingxiaochen 已提交
449 450
以下错误码的详细介绍请参见[ohos.telephony(电话子系统)错误码](../../reference/errorcodes/errorcode-telephony.md)错误码。

D
dingxiaochen 已提交
451 452 453 454 455 456 457 458 459
| 错误码ID |                  错误信息                    |
| -------- | -------------------------------------------- |
| 201      | Permission denied.                           |
| 401      | Parameter error.                             |
| 8300001  | Invalid parameter value.                     |
| 8300002  | Operation failed. Cannot connect to service. |
| 8300003  | System internal error.                       |
| 8300999  | Unknown error code.                          |

C
clevercong 已提交
460 461 462
**示例:**

```js
D
dingxiaochen 已提交
463 464
data.enableCellularData((err) => {
    console.log(`callback: err->${JSON.stringify(err)}`);
C
clevercong 已提交
465 466 467 468 469 470 471 472 473
});
```

## data.enableCellularData

enableCellularData(): Promise<void\>

启用蜂窝数据服务,使用Promise方式作为异步方法。

D
dingxiaochen 已提交
474
**系统接口:** 此接口为系统接口。
C
clevercong 已提交
475 476 477 478 479 480 481 482 483 484 485

**需要权限**:ohos.permission.SET_TELEPHONY_STATE

**系统能力**:SystemCapability.Telephony.CellularData

**返回值:**

| 类型            | 说明                    |
| --------------- | ----------------------- |
| Promise\<void\> | 以Promise形式返回结果。 |

D
dingxiaochen 已提交
486 487
**错误码:**

D
dingxiaochen 已提交
488 489
以下错误码的详细介绍请参见[ohos.telephony(电话子系统)错误码](../../reference/errorcodes/errorcode-telephony.md)错误码。

D
dingxiaochen 已提交
490 491 492 493 494 495 496 497 498
| 错误码ID |                  错误信息                    |
| -------- | -------------------------------------------- |
| 201      | Permission denied.                           |
| 401      | Parameter error.                             |
| 8300001  | Invalid parameter value.                     |
| 8300002  | Operation failed. Cannot connect to service. |
| 8300003  | System internal error.                       |
| 8300999  | Unknown error code.                          |

C
clevercong 已提交
499 500 501 502
**示例:**

```js
let promise = data.enableCellularData();
D
dingxiaochen 已提交
503 504
promise.then(() => {
    console.log(`enableCellularData success.`);
C
clevercong 已提交
505 506 507 508 509 510 511 512 513 514 515
}).catch((err) => {
    console.error(`enableCellularData fail, promise: err->${JSON.stringify(err)}`);
});
```

## data.disableCellularData

disableCellularData(callback: AsyncCallback<void\>): void

禁用蜂窝数据服务,使用callback方式作为异步方法。

D
dingxiaochen 已提交
516
**系统接口:** 此接口为系统接口。
C
clevercong 已提交
517 518 519 520 521 522 523 524 525 526 527

**需要权限**:ohos.permission.SET_TELEPHONY_STATE

**系统能力**:SystemCapability.Telephony.CellularData

**参数:**

| 参数名   | 类型                  | 必填 | 说明       |
| -------- | --------------------- | ---- | ---------- |
| callback | AsyncCallback\<void\> | 是   | 回调函数。 |

D
dingxiaochen 已提交
528 529
**错误码:**

D
dingxiaochen 已提交
530 531
以下错误码的详细介绍请参见[ohos.telephony(电话子系统)错误码](../../reference/errorcodes/errorcode-telephony.md)错误码。

D
dingxiaochen 已提交
532 533 534 535 536 537 538 539 540
| 错误码ID |                  错误信息                    |
| -------- | -------------------------------------------- |
| 201      | Permission denied.                           |
| 401      | Parameter error.                             |
| 8300001  | Invalid parameter value.                     |
| 8300002  | Operation failed. Cannot connect to service. |
| 8300003  | System internal error.                       |
| 8300999  | Unknown error code.                          |

C
clevercong 已提交
541 542 543
**示例:**

```js
D
dingxiaochen 已提交
544 545
data.disableCellularData((err) => {
    console.log(`callback: err->${JSON.stringify(err)}`);
C
clevercong 已提交
546 547 548 549 550 551 552 553 554
});
```

## data.disableCellularData

disableCellularData(): Promise<void\>

禁用蜂窝数据服务,使用Promise方式作为异步方法。

D
dingxiaochen 已提交
555
**系统接口:** 此接口为系统接口。
C
clevercong 已提交
556 557 558 559 560 561 562 563 564 565 566

**需要权限**:ohos.permission.SET_TELEPHONY_STATE

**系统能力**:SystemCapability.Telephony.CellularData

**返回值:**

| 类型            | 说明                        |
| --------------- | --------------------------- |
| Promise\<void\> | 以Promise形式返回禁用结果。 |

D
dingxiaochen 已提交
567 568
**错误码:**

D
dingxiaochen 已提交
569 570
以下错误码的详细介绍请参见[ohos.telephony(电话子系统)错误码](../../reference/errorcodes/errorcode-telephony.md)错误码。

D
dingxiaochen 已提交
571 572 573 574 575 576 577 578 579
| 错误码ID |                  错误信息                    |
| -------- | -------------------------------------------- |
| 201      | Permission denied.                           |
| 401      | Parameter error.                             |
| 8300001  | Invalid parameter value.                     |
| 8300002  | Operation failed. Cannot connect to service. |
| 8300003  | System internal error.                       |
| 8300999  | Unknown error code.                          |

C
clevercong 已提交
580 581 582 583
**示例:**

```js
let promise = data.disableCellularData();
D
dingxiaochen 已提交
584 585
promise.then(() => {
    console.log(`disableCellularData success.`);
C
clevercong 已提交
586 587 588 589 590 591 592 593 594 595 596
}).catch((err) => {
    console.error(`disableCellularData fail, promise: err->${JSON.stringify(err)}`);
});
```

## data.enableCellularDataRoaming

enableCellularDataRoaming(slotId: number, callback: AsyncCallback<void\>): void

启用蜂窝数据漫游,使用callback方式作为异步方法。

D
dingxiaochen 已提交
597
**系统接口:** 此接口为系统接口。
C
clevercong 已提交
598 599 600 601 602 603 604 605 606 607 608 609

**需要权限**:ohos.permission.SET_TELEPHONY_STATE

**系统能力**:SystemCapability.Telephony.CellularData

**参数:**

| 参数名   | 类型                  | 必填 | 说明                                     |
| -------- | --------------------- | ---- | ---------------------------------------- |
| slotId   | number                | 是   | 卡槽ID。<br />0:卡槽1。<br />1:卡槽2。 |
| callback | AsyncCallback\<void\> | 是   | 回调函数。                               |

D
dingxiaochen 已提交
610 611
**错误码:**

D
dingxiaochen 已提交
612 613
以下错误码的详细介绍请参见[ohos.telephony(电话子系统)错误码](../../reference/errorcodes/errorcode-telephony.md)错误码。

D
dingxiaochen 已提交
614 615 616 617 618 619 620 621 622
| 错误码ID |                  错误信息                    |
| -------- | -------------------------------------------- |
| 201      | Permission denied.                           |
| 401      | Parameter error.                             |
| 8300001  | Invalid parameter value.                     |
| 8300002  | Operation failed. Cannot connect to service. |
| 8300003  | System internal error.                       |
| 8300999  | Unknown error code.                          |

C
clevercong 已提交
623 624 625
**示例:**

```js
D
dingxiaochen 已提交
626 627
data.enableCellularDataRoaming(0, (err) => {
    console.log(`callback: err->${JSON.stringify(err)}`);
C
clevercong 已提交
628 629 630 631 632 633 634 635 636
});
```

## data.enableCellularDataRoaming

enableCellularDataRoaming(slotId: number): Promise<void\>

启用蜂窝数据漫游,使用Promise方式作为异步方法。

D
dingxiaochen 已提交
637
**系统接口:** 此接口为系统接口。
C
clevercong 已提交
638 639 640 641 642 643 644 645 646 647 648 649 650 651 652 653 654

**需要权限**:ohos.permission.SET_TELEPHONY_STATE

**系统能力**:SystemCapability.Telephony.CellularData

**参数:**

| 参数名 | 类型   | 必填 | 说明                                     |
| ------ | ------ | ---- | ---------------------------------------- |
| slotId | number | 是   | 卡槽ID。<br />0:卡槽1。<br />1:卡槽2。 |

**返回值:**

| 类型            | 说明                      |
| --------------- | ------------------------- |
| Promise\<void\> | 以Promise形式返回启用结果 |

D
dingxiaochen 已提交
655 656
**错误码:**

D
dingxiaochen 已提交
657 658
以下错误码的详细介绍请参见[ohos.telephony(电话子系统)错误码](../../reference/errorcodes/errorcode-telephony.md)错误码。

D
dingxiaochen 已提交
659 660 661 662 663 664 665 666 667
| 错误码ID |                  错误信息                    |
| -------- | -------------------------------------------- |
| 201      | Permission denied.                           |
| 401      | Parameter error.                             |
| 8300001  | Invalid parameter value.                     |
| 8300002  | Operation failed. Cannot connect to service. |
| 8300003  | System internal error.                       |
| 8300999  | Unknown error code.                          |

C
clevercong 已提交
668 669 670 671
**示例:**

```js
let promise = data.enableCellularDataRoaming(0);
D
dingxiaochen 已提交
672 673
promise.then(() => {
    console.log(`enableCellularDataRoaming success.`);
C
clevercong 已提交
674 675 676 677 678 679 680 681 682 683 684
}).catch((err) => {
    console.error(`enableCellularDataRoaming fail, promise: err->${JSON.stringify(err)}`);
});
```

## data.disableCellularDataRoaming

disableCellularDataRoaming(slotId: number, callback: AsyncCallback<void\>): void

禁用蜂窝数据漫游,使用callback方式作为异步方法。

D
dingxiaochen 已提交
685
**系统接口:** 此接口为系统接口。
C
clevercong 已提交
686 687 688 689 690 691 692 693 694 695 696 697

**需要权限**:ohos.permission.SET_TELEPHONY_STATE

**系统能力**:SystemCapability.Telephony.CellularData

**参数:**

| 参数名   | 类型                  | 必填 | 说明                                     |
| -------- | --------------------- | ---- | ---------------------------------------- |
| slotId   | number                | 是   | 卡槽ID。<br />0:卡槽1。<br />1:卡槽2。 |
| callback | AsyncCallback\<void\> | 是   | 回调函数。                               |

D
dingxiaochen 已提交
698 699
**错误码:**

D
dingxiaochen 已提交
700 701
以下错误码的详细介绍请参见[ohos.telephony(电话子系统)错误码](../../reference/errorcodes/errorcode-telephony.md)错误码。

D
dingxiaochen 已提交
702 703 704 705 706 707 708 709 710
| 错误码ID |                  错误信息                    |
| -------- | -------------------------------------------- |
| 201      | Permission denied.                           |
| 401      | Parameter error.                             |
| 8300001  | Invalid parameter value.                     |
| 8300002  | Operation failed. Cannot connect to service. |
| 8300003  | System internal error.                       |
| 8300999  | Unknown error code.                          |

C
clevercong 已提交
711 712 713
**示例:**

```js
D
dingxiaochen 已提交
714 715
data.disableCellularDataRoaming(0, (err) => {
    console.log(`callback: err->${JSON.stringify(err)}`);
C
clevercong 已提交
716 717 718 719 720 721 722 723 724
});
```

## data.disableCellularDataRoaming

disableCellularDataRoaming(slotId: number): Promise<void\>

禁用蜂窝数据漫游,使用Promise方式作为异步方法。

D
dingxiaochen 已提交
725
**系统接口:** 此接口为系统接口。
C
clevercong 已提交
726 727 728 729 730 731 732 733 734 735 736 737 738 739 740 741 742

**需要权限**:ohos.permission.SET_TELEPHONY_STATE

**系统能力**:SystemCapability.Telephony.CellularData

**参数:**

| 参数名 | 类型   | 必填 | 说明                                     |
| ------ | ------ | ---- | ---------------------------------------- |
| slotId | number | 是   | 卡槽ID。<br />0:卡槽1。<br />1:卡槽2。 |

**返回值:**

| 类型            | 说明                      |
| --------------- | ------------------------- |
| Promise\<void\> | 以Promise形式返回禁用结果 |

D
dingxiaochen 已提交
743 744
**错误码:**

D
dingxiaochen 已提交
745 746
以下错误码的详细介绍请参见[ohos.telephony(电话子系统)错误码](../../reference/errorcodes/errorcode-telephony.md)错误码。

D
dingxiaochen 已提交
747 748 749 750 751 752 753 754 755
| 错误码ID |                  错误信息                    |
| -------- | -------------------------------------------- |
| 201      | Permission denied.                           |
| 401      | Parameter error.                             |
| 8300001  | Invalid parameter value.                     |
| 8300002  | Operation failed. Cannot connect to service. |
| 8300003  | System internal error.                       |
| 8300999  | Unknown error code.                          |

C
clevercong 已提交
756 757 758 759
**示例:**

```js
let promise = data.disableCellularDataRoaming(0);
D
dingxiaochen 已提交
760 761
promise.then(() => {
    console.log(`disableCellularDataRoaming success.`);
C
clevercong 已提交
762 763 764 765 766
}).catch((err) => {
    console.error(`disableCellularDataRoaming fail, promise: err->${JSON.stringify(err)}`);
});
```

C
clevercong 已提交
767
## DataFlowType
768

C
clevercong 已提交
769
描述蜂窝数据流类型。 
770

Z
zengyawen 已提交
771
**系统能力**:SystemCapability.Telephony.CellularData
772

C
clevercong 已提交
773
| 名称                   | 值   | 说明                                       |
C
clevercong 已提交
774 775 776 777 778 779
| ---------------------- | ---- | ------------------------------------------ |
| DATA_FLOW_TYPE_NONE    | 0    | 表示没有上行或下行数据。                   |
| DATA_FLOW_TYPE_DOWN    | 1    | 表示只有下行数据。                         |
| DATA_FLOW_TYPE_UP      | 2    | 表示只有上行数据。                         |
| DATA_FLOW_TYPE_UP_DOWN | 3    | 表示有上下行数据。                         |
| DATA_FLOW_TYPE_DORMANT | 4    | 表示没有上下行数据,底层链路处于休眠状态。 |
780

C
clevercong 已提交
781
## DataConnectState
782

C
clevercong 已提交
783 784
描述蜂窝数据链路连接状态。 

Z
zengyawen 已提交
785
**系统能力**:SystemCapability.Telephony.CellularData
C
clevercong 已提交
786

C
clevercong 已提交
787
| 名称                    | 值   | 说明                       |
C
clevercong 已提交
788 789 790 791 792
| ----------------------- | ---- | -------------------------- |
| DATA_STATE_UNKNOWN      | -1   | 表示蜂窝数据链路未知。     |
| DATA_STATE_DISCONNECTED | 0    | 表示蜂窝数据链路断开。     |
| DATA_STATE_CONNECTING   | 1    | 表示正在连接蜂窝数据链路。 |
| DATA_STATE_CONNECTED    | 2    | 表示蜂窝数据链路已连接。   |
C
clevercong 已提交
793
| DATA_STATE_SUSPENDED    | 3    | 表示蜂窝数据链路被挂起。   |