Skip to content

A simple solution for horizontal scrolling images with lazy loading

License

Notifications You must be signed in to change notification settings

degloman/angular-carousel

 
 

Repository files navigation

to build cd project/angular-responsive-carousel ng build

Carousel for Angular

A simple solution for horizontal scrolling images with lazy loading.

Live demo can be found on home page.

🔬️ Help make IvyCarousel better by answering a few questions.

Installation

Install the npm package.

  npm i angular-responsive-carousel

Import module:

  import {IvyCarouselModule} from 'angular-responsive-carousel';

  @NgModule({
      imports: [IvyCarouselModule]
  })

Usage

Put the contents of your cells in containers with the carousel-cell class.

<carousel>
    <div class="carousel-cell">
        <img src="path_to_image">
    </div>
    <div class="carousel-cell">
        ...
</carousel>

Or prepare an image array for the carousel. If necessary, specify in the settings the sizes of the cells and the carousel container. And also select the method of arranging images inside the cells using the objectFit property.

<carousel
    [images]="images">
</carousel>
images = [
    {path: 'PATH_TO_IMAGE'},
    ...
]

Lazy loading

To use lazy loading, pass the carousel an array of images, as shown in the example above. Images will be uploaded only as needed, this will save you traffic. Using the overflowCellsLimit property, you can specify the number of images that will be loaded outside the visible area, which will allow the images to be loaded before they are displayed.

Properties

name type default description
height number Carousel height.
width number Carousel Width.
cellWidth number, '100%' 200 Cell width.
cellsToShow number The number of cells to display, regardless of the width of the container.
cellsToScroll number 1 The number of carousel cells to scroll per arrow click.
loop boolean false Infinite loop.
lightDOM boolean false Keep a limited number of cells in the DOM tree for an unlimited number of images. As the carousel scrolls, the images will be lazy loaded. This allows you not to overload the browser memory. This mode works only with images passed as an array.
overflowCellsLimit number 3 The number of carousel cells that will be stored for in the DOM tree outside the scope.
freeScroll boolean false The carousel will stop where the touch ended and will not automatically align.
autoplay boolean false Automatically start the carousel after initialization.
autoplayInterval number 5000 The interval between scrolling the carousel. Used together with autoplay.
pauseOnHover boolean true Stops autoplay if the cursor is over the carousel area.
dots boolean false Carousel progress bar.
margin number 10 Cell spacing.
minSwipeDistance number 10 Minimum distance for swipe.
transitionDuration number 300 Animation duration.
transitionTimingFunction 'ease', 'ease-in', 'ease-out', 'ease-in-out', 'linear' 'ease-in-out' Smooth animation function.
counter boolean false Counter.
counterSeparator string " / " Counter separator.
borderRadius number 0 Border radius for carousel cells.
arrows boolean true Arrows for image navigation.
arrowsOutside boolean false Arrows on the outside of the carousel container.
arrowsTheme 'light', 'dark' 'light' Arrow color theme.

The IvyCarousel also has a Pro version, with an extended API.

Author services

Are you interested in this library but lacks features? Write to the author, he can do it for you.

Roadmap

centerMode - center the cells inside the container (Pro version).

fade - fade in and fade out animation.

adaptiveHeight - the height of the container is set based on the height of the tallest cell currently visible.

About

A simple solution for horizontal scrolling images with lazy loading

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • TypeScript 83.7%
  • HTML 7.7%
  • Sass 5.2%
  • JavaScript 3.4%