vue移动端UI框架——Vant全局引入vs局部引入

54 篇文章 0 订阅
5 篇文章 0 订阅

全局引入

1.在main.js中全局引入全部vant组件
  • 优点:可以在所有vue文件的template中定义所需组件
  • 缺点:打包发布时会增加包的大小,Vue的SPA首屏打开时本来就有些慢,同时不能在js中使用类似Toast功能的组件

代码如下:

// main.js

import Vant from 'vant'
import 'vant/lib/vant-css/index.css'
Vue.use(Vant)
// login.vue

<template>
  <div class="container">
    <van-field
      v-model="user.loginName"
      label="用户名"
      placeholder="请输入用户名"
    />
    <van-field
      v-model="user.password"
      label="密码"
      placeholder="请输入密码"
    />
    <van-button
      block
      hairline
      type="primary"
      @click="login()"
    >登 录</van-button>
  </div>
</template>
2.在main.js全局引入公共组件
  • 优点:公共组件只需要进入一次,所有页面都可调用
  • 缺点: 功能组件多时,在main.js中,vue需要逐个挂载这些组件

代码如下:

// main.js

import { Toast, Loading } from 'vant'
import 'vant/lib/index.css'
Vue.prototype.$toast = Toast
Vue.prototype.$loading = Loading
...

对于挂载在vue实例上的组件,就采用this.属性名的形式进行调用

// login.vue

<template>
	......
</template>
<script>
export default {
  data() {}
  methods: {
	login() {
	  this.$toast('我要登录!')
	}
 }
}
</script>

按需引入/局部引入

这种应用稍微比较繁琐,需要在对应的业务页面引入所需组件
  • 优点:需要什么引入什么,不用加载所有组件
  • 缺点:每个页面都需要操作,操作繁琐

代码如下:

// login.vue

<template>
	......
</template>
<script>
import { Field, Button } from 'vant'
export default {
  name: 'login',
  components: {
    [Field.name]: Field,
    [Button.name]: Button
  }
}
</script>

上述代码已经可以实现组件的引用,亲测有效!
但是网络上的版本都需要进行相关配置,可以也可以参考一下

方法如下:

  1. 安装 babel-plugin-import 插件,babel-plugin-import 是一款 babel 插件,它会在编译过程中将 import 的写法自动转换为按需引入的方式

    npm i babel-plugin-import -D

  2. 在.babelrc文件中配置plugins(插件)
    // .babelrc
    
    "plugins": [
      "transform-vue-jsx", 
      "transform-runtime",
      [
        "import",
        { 
          "libraryName": "vant", 
          "libraryDirectory": "es", 
          "style": true 
        },
        "vant" // 这个配置是依照官网实例而得,和众多网络版本不同
      ]
    ],
    

上述内容全部为日常项目实践中的一点小总结,如有纰漏,还望指正!

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 ]
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值