Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/bkwld/vue-visual
Vue 2 image and video loader supporting lazy loading, background videos, fixed aspect ratios, low rez poster images, transitions, loaders, slotted content and more.
https://github.com/bkwld/vue-visual
intersectionobserver lazy-loading loader srcset video-player vue
Last synced: 4 days ago
JSON representation
Vue 2 image and video loader supporting lazy loading, background videos, fixed aspect ratios, low rez poster images, transitions, loaders, slotted content and more.
- Host: GitHub
- URL: https://github.com/bkwld/vue-visual
- Owner: BKWLD
- License: mit
- Created: 2016-11-26T01:16:48.000Z (about 8 years ago)
- Default Branch: master
- Last Pushed: 2025-01-27T15:50:07.000Z (25 days ago)
- Last Synced: 2025-02-10T19:08:41.858Z (11 days ago)
- Topics: intersectionobserver, lazy-loading, loader, srcset, video-player, vue
- Language: JavaScript
- Homepage: https://bkwld.github.io/vue-visual
- Size: 12.9 MB
- Stars: 60
- Watchers: 6
- Forks: 7
- Open Issues: 6
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Vue Visual [data:image/s3,"s3://crabby-images/3889b/3889b68e4f0e37f0a29de9f5a1cfb1ed961b167e" alt="npm"](https://www.npmjs.com/package/vue-visual)
Vue 2 image and video loader supporting lazy loading. Visual 2.x is a simplification of Version 1.x with a greater reliance on modern browser features (IntersectionObserver, object-fit, srcset, sizes, etc).
**Examples at https://bkwld.github.io/vue-visual.**
## Installation
1. Install the package: `npm install --save vue-visual` or `yarn add vue-visual`
2. Register the component:
```js
import Vue from 'vue'
import Visual from 'vue-visual'
Vue.component('visual', Visual)
import 'vue-visual/index.css'
```
3. These polyfills are recommended for older browsers:
- [IntersectionObserver](https://github.com/w3c/IntersectionObserver/tree/master/polyfill)
- [ObjectFit](https://github.com/constancecchen/object-fit-polyfill)## Usage
See [the Storybook](https://bkwld.github.io/vue-visual).
## Props
A list of the [component properties](http://vuejs.org/v2/guide/components.html#Props) that may be set on the Visual component.
#### Assets
- `image (string)` : The URL of an image to load.
- `srcset (string)` : An `img` [srcset](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/img#attr-srcset), used in addition to the `image`. Both are recommended.
- `webp-srcset (string)` : A `srcset` that will be added to a `source` inside of a `picture` element with a `type` of `image/webp`.
- `video (string|array)` : A video that is loaded after the image is loaded if the device supports video. If a string, should be the URL to a source video. If an array, a list of video URLs that will be added as difference ``s.
#### Size
- `width (number|string)` : This width will be applied to the asset element. If a number, it's assumed to be a px value.
- `height (number|string)` : See `width`
- `max-width (number|string)` : This value will be applied to the asset element as the css `max-width`. If a number, it's assumed to be a px value.
- `sizes (string)` : Specify the `img` `sizes` attribute.
- `aspect (number)` : Force the Visual to a specific aspect ratio. This works by making the asset `position:absolute` and then using an inner div with a `padding-top` set to a percentage.
- `expand (boolean)` : Make the Visual fill it's container via CSS using absolute positioning.
#### Style
- `object-fit (string)` - *Default `cover`.* Like the CSS property.
- `object-position (string)` - *Default `center center`.* Like the CSS property.
- `align (string)` - *Default `center middle`.*. Used in conjunction with slots to position the slot content. May be any combination of one horizontal (`left`, `center`, `right`) and one vertical (`top`, `middle`, `bottom`) choice, space-delimited.
#### Loading
- `preload (boolean)` - Requires Nuxt framework. If `true` will add `` tags to the `` for the image assets.
- `autoload (boolean)` - *Default: `true`.* If `true`, assets are loaded immediately unless `lazyload`.
- `lazyload (boolean)` - Waits until the Visual enters the viewport to trigger loading. Overrides `autoload`.
- `intersection-options (object)` - IntersectionObserver options. Used with `lazyload` and `autopause`.
- `placeholder-color` - Sets a background color behind the assets. Most useful in conjunction with an `aspect` value.
- `transition (string, boolean)` - *Default: `'vv-fade'`.* A [Vue transition](http://vuejs.org/v2/guide/transitions.html) name that is applied when an asset is loaded. Set to an empty string to immediately render assets rather than waiting for loading.
#### Video
- `autoplay (boolean)` - If `true`, begins playing immediately.
- `autopause (boolean)` - If `true`, begins playing when the Visual enters the viewport and stops when it leaves. Overrides `autoplay`.
- `loop (boolean)` - Sets `` `loop`
- `muted (boolean)` - Sets `` `muted`
- `controls (boolean)` - Sets `` `controls`
#### Accessibility
- `alt (string)` - Sets the
`alt` attribute or `aria-label` value, depending on context.
## Slots
- `default`: Markup is added after the assets and before the loader
- `image-source`: Adds `` tags to the `` element.
- `video-source`: Adds `` tags to the `` element.## Methods
- `load()` - Manually initiate loading.
- `play()` - Tell `video` to play.
- `pause()` - Tell `video` to pause.
- `restart()` - Tell `video` to restart playback from beginning.## Events
- `loaded:image` - Image asset has finished loading
- `loaded:video` - Video asset has finished loading
- `loaded` - All assets hvae loaded## Contributing
- Boot up the Storybook with `yarn storybook` and use that as your HMR friendly dev environment
- Use `npm version ...` to build, tag, and update the poblished storybook## Changes from 1.x
- Dropped props:
- `poster`
- `fallback`
- per-asset variants for `load`, etc
- Prop changes
- `background` ➡ `object-fit`
- `background-position` ➡ `object-position`
- `fill` ➡ `expand`
- Not testing for video support on device
- Video playing state not stored in Vue state
- Image and video loaded simultenously, not in series
- Removed `setDefaults` for setting default options. See [custom-defaults](examples/custom-defaults.js) for an example of how to implement this functionality using a functional component.[migrate-1.x.coffee](examples/migrate-1.x.coffee) shows an example of a functional component that migrates the old API to the new API.