• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1# Using Worker for Inter-Thread Communication
2
3[Worker](../reference/apis/js-apis-worker.md) is an independent thread running in parallel with the main thread. The thread that creates the worker thread is referred to as the host thread. The script file passed in during worker creation is executed in the worker thread. Generally, time-consuming operations are processed in the worker thread. However, pages cannot be directly updated in the worker thread.
4
5
6To develop the Worker mode, perform the following steps:
7
8
91. Configure the **buildOption** field in the [module-level build-profile.json5](https://developer.harmonyos.com/en/docs/documentation/doc-guides/ohos-building-configuration-0000001218440654#section6887184182020) file of the project.
10
11   ```ts
12     "buildOption": {
13       "sourceOption": {
14         "workers": [
15           "./src/main/ets/workers/worker.ts"
16         ]
17       }
18     }
19   ```
20
212. Create the **worker.ts** file based on the configuration in **build-profile.json5**.
22
23   ```ts
24   import worker from '@ohos.worker';
25
26   let parent = worker.workerPort;
27
28   // Process messages from the main thread.
29   parent.onmessage = function(message) {
30       console.info("onmessage: " + message)
31       // Send a message to the main thread.
32       parent.postMessage("message from worker thread.")
33   }
34   ```
35
363. In the main thread, use the following method to initialize and use the worker thread.
37   - Stage model:
38
39      ```ts
40      import worker from '@ohos.worker';
41
42      let wk = new worker.ThreadWorker("entry/ets/workers/worker.ts");
43
44      // Send a message to the worker thread.
45      wk.postMessage("message from main thread.")
46
47      // Process messages from the worker thread.
48      wk.onmessage = function(message) {
49          console.info("message from worker: " + message)
50
51          // Stop the worker thread based on service requirements.
52          wk.terminate()
53      }
54      ```
55
56   - FA model:
57
58      ```ts
59      import worker from '@ohos.worker';
60
61      let wk = new worker.ThreadWorker("../workers/worker.ts");
62
63      // Send a message to the worker thread.
64      wk.postMessage("message from main thread.")
65
66      // Process messages from the worker thread.
67      wk.onmessage = function(message) {
68          console.info("message from worker: " + message)
69
70          // Stop the worker thread based on service requirements.
71          wk.terminate()
72      }
73      ```
74
75> **NOTE**
76>
77> - If the relative path of **worker.ts** configured in **build-profile.json5** is **./src/main/ets/workers/worker.ts**, pass in the path **entry/ets/workers/worker.ts** when creating a worker thread in the stage model, and pass in the path **../workers/worker.ts** when creating a worker thread in the FA model.
78>
79> - For details about the data types supported between the main thread and worker thread, see [Sequenceable Data Types](../reference/apis/js-apis-worker.md#sequenceable-data-types).
80