Vant在vue项目中的使用(全局引入、按需引入,)

通过npm安装

注:(vue2的项目下载vant2的,vue3下载vant3的)

# Vue 2 项目,安装 Vant 2:
npm i vant@latest-v2 -S

# Vue 3 项目,安装 Vant 3:
npm i vant -S

引入组件

方式一、按需引入组件

下载插件babel-plugin-import,在在编译过程中会将import写法转换为按需引入

##安装插件babel-plugin-import
npm i babel-plugin-import -D
# 在.babelrc 中添加配置
 注意:webpack 1 无需设置 libraryDirectory

{
  "plugins": [
    ["import", {
      "libraryName": "vant",
      "libraryDirectory": "es",
      "style": true
    }]
  ]
}

// 对于使用 babel7 的用户,可以在 babel.config.js 中配置

module.exports = {
  plugins: [
    ['import', {
      libraryName: 'vant',
      libraryDirectory: 'es',
      style: true
    }, 'vant']
  ]
};

#在main.js中

import {Button} from 'vant'
Vue.use(Button)
// 引入的多的话
import { Button, Row, Col } from 'vant'
Vue.use(Button).use(Row).use(Col)

方式二、手动按需引入组件也就是局部注册

在当前vue页面单独使用引入

import { Button } from 'vant';

export default {
  components: {
    [Button.name]: Button,
  },
};

方式三、全局注册(配置按需引入后将不允许导入所有组件)

// main.js进行全局引入
import Vant from 'vant'
import 'vant/lib/index.css';
Vue.use(Vant)

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Vue全局引入vant组件可以通过在main.js使用Vue.use()方法来实现。例如,可以使用以下代码将vant的Button组件全局引入: ```javascript import { Button } from 'vant' Vue.use(Button) ``` 如果引入多个vant组件,可以使用链式调用的方式: ```javascript import { Button, Row, Col } from 'vant' Vue.use(Button).use(Row).use(Col) ``` 另外,如果要在Vue实例使用vant的Toast和Loading组件,可以在main.js进行全局引入,并将其挂载到Vue的原型上,以便在其他组件使用: ```javascript import { Toast, Loading } from 'vant' import 'vant/lib/index.css' Vue.prototype.$toast = Toast Vue.prototype.$loading = Loading ``` 全局引入vant组件的优点是可以在所有的Vue文件的template直接使用的组件。然而,缺点是在打包发布时会增加包的大小,可能会导致首屏加载速度变慢。此外,全局引入的组件无法在js使用类似Toast功能的组件。 #### 引用[.reference_title] - *1* [在vue项目使用vant(全局引入,按引入,页面引入)](https://blog.csdn.net/haoxinqing222/article/details/108236351)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* *3* [vue移动端UI框架——Vant全局引入vs局部引入](https://blog.csdn.net/u013205165/article/details/99645847)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值