47 lines
		
	
	
		
			2.0 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
		
		
			
		
	
	
			47 lines
		
	
	
		
			2.0 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
| 
								 | 
							
								# Using Web Workers with Angular CLI
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								[Web Workers](https://developer.mozilla.org/en-US/docs/Web/API/Web_Workers_API) allow you to run CPU intensive computations in a background thread, freeing the main thread to update the user interface.
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								If you find your application becomes unresponsive while processing data, using Web Workers can help.
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								## Adding a Web Worker
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								You can add a web worker anywhere in your application. If the file that contains your expensive computation is `src/app/app.component.ts`, you can add a Web Worker using `ng generate web-worker app`.
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								Running this command will:
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								- configure your project to use Web Workers, if it isn't already.
							 | 
						||
| 
								 | 
							
								- add `src/app/app.worker.ts` with scaffolded code to receive messages:
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  ```typescript
							 | 
						||
| 
								 | 
							
								  addEventListener('message', ({ data }) => {
							 | 
						||
| 
								 | 
							
								    const response = `worker response to ${data}`;
							 | 
						||
| 
								 | 
							
								    postMessage(response);
							 | 
						||
| 
								 | 
							
								  });
							 | 
						||
| 
								 | 
							
								  ```
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								- add scaffolded code to `src/app/app.component.ts` to use the worker:
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  ```typescript
							 | 
						||
| 
								 | 
							
								  if (typeof Worker !== 'undefined') {
							 | 
						||
| 
								 | 
							
								    // Create a new
							 | 
						||
| 
								 | 
							
								    const worker = new Worker('./app.worker', { type: 'module' });
							 | 
						||
| 
								 | 
							
								    worker.onmessage = ({ data }) => {
							 | 
						||
| 
								 | 
							
								      console.log('page got message: $\{data\}');
							 | 
						||
| 
								 | 
							
								    };
							 | 
						||
| 
								 | 
							
								    worker.postMessage('hello');
							 | 
						||
| 
								 | 
							
								  } else {
							 | 
						||
| 
								 | 
							
								    // Web Workers are not supported in this environment.
							 | 
						||
| 
								 | 
							
								    // You should add a fallback so that your program still executes correctly.
							 | 
						||
| 
								 | 
							
								  }
							 | 
						||
| 
								 | 
							
								  ```
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								After the initial scaffolding, you will need to refactor your code to use the Web Worker by sending messages to and from.
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								## Caveats
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								There are two important things to keep in mind when using Web Workers in Angular projects:
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								- Some environments or platforms, like `@angular/platform-server` used in [Server-side Rendering](guide/universal), don't support Web Workers. You have to provide a fallback mechanism to perform the computations that the worker would perform to ensure your application will work in these environments.
							 | 
						||
| 
								 | 
							
								- Running Angular itself in a Web Worker via [**@angular/platform-webworker**](api/platform-webworker) is not yet supported in Angular CLI.
							 |