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" // 这个配置是依照官网实例而得,和众多网络版本不同
      ]
    ],
    

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

  • 6
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值