medium-zoom
Integrate medium-zoomopen in new window into VuePress, which can provide the ability to zoom images.
This plugin has been integrated into the default theme.
Install
npm i -D @vuepress/plugin-medium-zoom@next
Options
selector
Type:
string
Default:
':not(a) > img'
Details:
Selector for zoomable images.
By default this plugin will make all images zoomable except those inside
<a>
tags.
delay
Type:
number
Default:
500
Details:
Delay in milliseconds.
After navigating to a new page, this plugin will make images zoomable with a delay.
zoomOptions
Type:
Object
Details:
Options for medium-zoom.
Also see:
Styles
You can customize most of the zoom styles via zoomOptions, while this plugin also provides some CSS variables for additional customization:
:root {
--medium-zoom-z-index: 100;
--medium-zoom-bg-color: #ffffff;
--medium-zoom-opacity: 1;
}
2
3
4
5
Composition API
useMediumZoom
Details:
Returns the
Zoom
instance that used by this plugin, so that you can use the instance methodsopen in new window directly.This plugin will make images zoomable after navigating to current page. But if you are going to add new images dynamically, you may need this method to make those new images zoomable, too.
This plugin adds an extra
refresh
method on theZoom
instance, which will callzoom.detach()
thenzoom.attach()
with the selector as the default parameter. It will help you to refresh the zoomable images for current page.Example:
import { nextTick } from 'vue'
import { useMediumZoom } from '@vuepress/plugin-medium-zoom/lib/client'
export default {
setup() {
const zoom = useMediumZoom()
// ... do something to add new images in current page
// then you may need to call `refresh` manually to make those new images zoomable
nextTick(() => {
zoom.refresh()
})
},
}
2
3
4
5
6
7
8
9
10
11
12
13
14
15