Which property of a FormControl instance would you check to determine if the user has interacted with a particular form control?

  • dirty
  • pristine
  • touched
  • untouched
To determine if the user has interacted with a particular form control in Angular Reactive Forms, you would check the touched property of the FormControl instance. It becomes true when the user has focused and blurred the form control, indicating interaction. The dirty property indicates if the value has changed.

How can you set default headers for every request made by HttpClient in your application?

  • By adding headers to each HttpClient request manually
  • By configuring HttpHeaders globally
  • By modifying the HttpClient constructor
  • By using an interceptor
You can set default headers for all HttpClient requests by using an interceptor. Interceptors allow you to intercept outgoing requests and modify them, including adding default headers, before they are sent.

Which of the following is the primary building block of an Angular application?

  • Component
  • Directive
  • Module
  • Service
In Angular, a component controls a patch of the screen called a view. Components are the main way to build and specify elements and logic on the page, making them the primary building block of an Angular application.

How can you set default values for form controls in a template-driven form?

  • Use the defaultValue attribute.
  • Assign values directly in the template.
  • Set values programmatically in the component.
  • Use the ngDefaultControl directive.
In template-driven forms, default values for form controls are typically set programmatically in the component by initializing the corresponding form control variables with the desired default values. While you can assign values directly in the template, this doesn't allow for dynamic default values or interaction with the component logic. The other options mentioned are not common practices for setting default values in template-driven forms.

What does the map operator in RxJS primarily do?

  • Combines multiple Observables
  • Filters data emitted by an Observable
  • Subscribes to an Observable
  • Transforms data emitted by an Observable
The map operator in RxJS primarily transforms data emitted by an Observable. It allows you to apply a function to each item emitted by the source Observable and returns a new Observable with the transformed values.

You are working on a large application where you need to display complex modal dialogs based on user interactions. How can dynamic components assist in this scenario?

  • Dynamic components allow you to add styling to elements.
  • Dynamic components can only be used in AngularJS.
  • Dynamic components enable lazy loading of modules.
  • Dynamic components can be created and rendered at runtime.
Dynamic components in Angular allow you to create and render components at runtime. This is particularly useful for displaying complex modal dialogs based on user interactions. You can dynamically load the modal component when needed, keeping the main application bundle smaller and improving performance. The other options do not accurately describe the capabilities of dynamic components.

What potential issue can arise when using Lazy Loading without properly planning the module structure?

  • Circular dependencies
  • Decreased maintainability
  • Difficulty in routing configuration
  • Increased initial loading time
When using Lazy Loading without proper planning, circular dependencies can arise. This occurs when two or more modules depend on each other, causing issues with module resolution and potentially leading to runtime errors. It's essential to structure modules carefully to avoid this problem.

Which method would you use in HttpInterceptor to catch and handle HTTP errors?

  • catchError
  • handleError
  • handleError and catchError
  • intercept
In an HttpInterceptor, you would use the intercept method to catch and handle HTTP errors. This method intercepts outgoing HTTP requests and incoming responses, giving you the opportunity to handle errors and modify requests before they are sent.

To mock a service in Angular tests, you often replace the real service with a ______ service.

  • Mock
  • Spy
  • Stub
  • TestBed
In Angular testing, you typically replace the real service with a "Spy" service. A spy allows you to track calls to service methods, set up return values, and perform other testing-related tasks while avoiding actual service execution.

Which tag is used for multi-slot content projection in Angular?

The tag used for multi-slot content projection in Angular is . It allows you to project content into named slots within a component's template, providing a way to customize the rendering of components from their parent components. is used for defining templates, while and are not standard Angular tags for this purpose.