2.8 KiB
Advanced Usage
Intro
Through this chapter, you can learn about some advanced usages of Vant.
Component Usage
Component Registration
Vant supports multiple ways to register components:
Global Registration
import { Button } from 'vant';
import { createApp } from 'vue';
const app = createApp();
// Method 1. via app.use
app.use(Button);
// Method 2. Register via app.component
app.component(Button.name, Button);
Local Registration
import { Button } from 'vant';
export default {
components: {
[Button.name]: Button,
},
};
For more information, please refer to Vue.js - Component Registration。
<script setup>
Vant components can be used directly in <script setup>
without component registration.
<script setup>
import { Button } from 'vant';
</script>
<template>
<Button />
</template>
JSX/TSX
Vant components can be used directly in JSX and TSX without component registration.
import { Button } from 'vant';
export default {
render() {
return <Button />;
},
};
Browser adaptation
Viewport Units
Vant uses px
unit by default,you can use tools such as postcss--px-to-viewport to transform px
unit to viewport units (vw, vh, vmin, vmax).
PostCSS Config
PostCSS config example:
// postcss.config.js
module.exports = {
plugins: {
'postcss-px-to-viewport': {
viewportWidth: 375,
},
},
};
Rem Unit
You can use tools such as postcss-pxtorem
to transform px
unit to rem
unit.
PostCSS Config
PostCSS config example:
// postcss.config.js
module.exports = {
plugins: {
'postcss-pxtorem': {
rootValue: 37.5,
propList: ['*'],
},
},
};
Custom rootValue
If the size of the design draft is 750 or other sizes, you can adjust the rootValue
to:
// postcss.config.js
module.exports = {
plugins: {
// postcss-pxtorem version >= 5.0.0
'postcss-pxtorem': {
rootValue({ file }) {
return file.indexOf('vant') !== -1 ? 37.5 : 75;
},
propList: ['*'],
},
},
};
Adapt to PC Browsers
Vant is a mobile-first component library, if you want to use Vant in PC browsers, you can use the @vant/touch-emulator module. This module will automatically convert the mouse events of the PC browser into the touch events of the mobile browser.
# Install
npm i @vant/touch-emulator -S
// Just import this module, then Vant works in PC browser
import '@vant/touch-emulator';