全局引入

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

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

Logo

前往低代码交流专区

更多推荐