/vue3-compare-image

A Simple Vue 3 component to compare two images with a slider, supports vertical and horizontal modes, and Keyboard for accessibility.

Primary LanguageVueMIT LicenseMIT

vue3-compare-image

A Vue 3 component to compare and slide between two images, supports vertical and horizontal modes, and Keyboard for accessibility.

NOTE: This project is a fork of vue-compare-image with Vue 3 support and with all functionalities of react-compare-image plus Keyboard navigation for accessibility.

img

Features

  • Documentation
  • Simple
  • Accessibility
  • Fully Typescript
  • Responsive (fit to the parent width)
  • Size difference between two images handled correctly. Element size determined by following two factors:
    • width of the parent
    • right image's aspect ratio
  • Horizontal & Vertical comparison
  • Keyboard navigation

How to use

In the shell:

yarn add vue3-compare-image

// or

npm install --save vue3-compare-image

Globally:

import VueCompareImage from 'vue3-compare-image'

const app = createApp(App)
app.use(VueCompareImage)

app.mount('#app')

If Installed globaly, reference type in tsconfig or .d.ts file to get props autocompletion

eg in .d.ts

/// <reference types="vue3-compare-image/client" />

In your component file:

import { VueCompareImage } from 'vue3-compare-image'

export default {
  name: 'app',
  components: { VueCompareImage },
}
<template>
  <VueCompareImage leftImage="image1.jpg" rightImage="image2.jpg" />;
</template>

Props

Prop (* required) type default description
leftImage * string null left image's url
rightImage * string null right image's url
vertical boolean false Compare images vertically or horizontally
keyboard boolean true Allow Keyboard navigation for accessibility
keyboardStep number 0.01 By what percentage should the slider move on keyboard press. between 0 and 1
aspectRatio 'taller' or 'wider' 'taller' Which to choose if the aspect ratios of the images are different
handle element null Custom handle element. Just pass and empty <div /> if you want to remove the handle.
handleSize number (px) 40 diameter of slider handle (by pixel)
hover boolean false Whether to slide at hover
slideOnClick boolean true Whether to slide on click and drag or just drag.
leftImageAlt string '' alt props for left image
leftImageCss object {} Additional css for left image
leftImageLabel string null Label for the image (e.g. before)
onSliderPositionChange function null Callback function called each time the slider changes. The position (0 to 1) of the slider is passed as arg
rightImageAlt string '' alt props for right image
rightImageCss object {} Additional css for right image
rightImageLabel string null Label for the image (e.g. after)
skeleton element null Element displayed while image is loading
sliderLineColor string '#ffffff' line color of slider
sliderLineWidth number (px) 2 line width of slider (by pixel). set 0 to hide slider line.
sliderPositionPercentage number (float) 0.5 Default slider line position (from 0 to 1)

Events

Name Description
slideStart When sliding has starts
slideEnd When sliding ends
isSliding true when sliding