4.11.1 • Published 1 month ago

@ng-web-apis/resize-observer v4.11.1

Weekly downloads
643
License
Apache-2.0
Repository
github
Last release
1 month ago

ng-web-apis logo Resize Observer API for Angular

npm version npm bundle size codecov

This is a library for declarative use of Resize Observer API with Angular.

Install

If you do not have @ng-web-apis/common:

npm i @ng-web-apis/common

Now install the package:

npm i @ng-web-apis/resize-observer

Usage

  1. Import ResizeObserverModule to the module where you plan to use it.
  2. Use waResizeObserver directive to observe an element:
<section>
  <h1
    waResizeBox="content-box"
    (waResizeObserver)="onResize($event)"
  >
    I'm being observed
  </h1>
</section>

Use waResizeBox to configure ResizeObserver options

NOTE: Keep in mind these are used one time in constructor so you cannot use binding, only strings.

Service

Alternatively you can use Observable-based ResizeObserverService and provide token RESIZE_OPTION_BOX manually:

@Component({
  selector: 'my-component',
  providers: [
    ResizeObserverService,
    {
      provide: RESIZE_OPTION_BOX,
      useValue: 'border-box',
    },
  ],
})
export class Example {
  constructor(@Inject(ResizeObserverService) entries$: ResizeObserverService) {
    entries$.subscribe((entries) => {
      // This will trigger when the component resizes
      // Don't forget to unsubscribe
      console.log(entries);
    });
  }
}

Browser support

79+69+64+13.1+13.4+

You can use polyfill to support older browsers

Demo

You can try online demo here

See also

Other Web APIs for Angular by @ng-web-apis

4.11.0

1 month ago

4.11.1

1 month ago

4.9.0

1 month ago

4.8.0

1 month ago

4.6.5

2 months ago

4.7.0

1 month ago

4.10.1

1 month ago

4.10.2

1 month ago

4.10.0

1 month ago

4.6.4

2 months ago

4.6.3

2 months ago

4.6.2

2 months ago

4.6.1

2 months ago

4.6.0

2 months ago

4.5.1

2 months ago

4.5.0

2 months ago

4.3.0

2 months ago

3.2.2

4 months ago

3.2.1

5 months ago

3.2.3

3 months ago

4.1.3

4 months ago

4.1.0

5 months ago

4.0.1

5 months ago

4.0.0

5 months ago

4.2.1

3 months ago

4.1.2

5 months ago

4.2.0

4 months ago

4.1.1

5 months ago

3.0.3

1 year ago

3.0.2

1 year ago

3.0.6

1 year ago

3.0.5

1 year ago

3.0.1

1 year ago

3.0.0

1 year ago

2.1.0

1 year ago

2.0.0

2 years ago

1.0.3

4 years ago

1.0.2

4 years ago

1.0.1

5 years ago

1.0.0

5 years ago