美文网首页
自定义vue全局组件(Loading为例)

自定义vue全局组件(Loading为例)

作者: 帅帅哒主公 | 来源:发表于2019-05-21 16:24 被阅读0次

首先创建一个项目

vue init webpack-simple define-demo //define-demo 项目名称
cd define-demo     
npm install //安装本次所有需要的模块
npm run dev  //自动打开网页,验证项目创建成功

定义组件文件夹

在项目src目录下新建文件夹components用于存放所有的自定义组件,接着在components下新建loading文件夹,用于存放Loading组件,之所以创建loading文件夹是因为,你的Loading组件可能还需要依赖一些其他的文件时可放在loading文件夹中。最后在loading文件夹下新建index.js 和 Loading.vue 两个文件。

loading:组件文件夹
index.js:组件人口加载文件
Loading.vue:组件模板

在main.js中引入并Vue.use()

webpack首先会加载main.js,所以我们在main.js里面引入

// 引入自定义组件。index.js是组件的默认入口
import Loading from './components/loading/'
Vue.use(Loading)

在Loading.vue里面定义自己的组件模板

这里简单定义一下

<template>
  <div>
    loading...loading...
  </div>
</template>

在index.js文件里面添加install方法,定义Vue.use()并且export Loading

import LoadingComponent from './Loading.vue'
const Loading = {
  install:function (Vue) {
    Vue.component('Loading',LoadingComponent)
  }
};
// 导出组件
export default Loading

在任意地方使用全局组件

比如在App.Vue里面使用组件,此时Loading组件已经在main.js定义加载了

<template>
  <div id="app">
    <h3>welcome loading</h3>
    <Loading></Loading>
  </div>
</template>

刷新npm run dev打开的页面即可看到效果

相关文章

  • Vue组件全局注册

    1. 编写loading组件(components/Loading/index.vue) 2.注册为全局组件 (c...

  • 自定义vue全局组件(Loading为例)

    首先创建一个项目 定义组件文件夹 在项目src目录下新建文件夹components用于存放所有的自定义组件,接着在...

  • vue 自定义组件(一)全局、局部组件

    vue自定义组件分为局部组件和全局组件 全局组件 全局组件格式template 是模板props 是自定义组件用到...

  • 盘点VUE的全局组件有哪些使用姿势

    在学习全局组件之前,我们先撸个实例了解下:import Loading from './Loading.vue'/...

  • vue自定义组件

    vue自定义组件 1.vue全局组件 Vue.component("组件名",{obj});obj跟vue实例一样...

  • vue07

    vue08 自定义组件 loading目录下定义loading.vue(正常定义) 同样目录下定义index.js...

  • Vue第三方插件使用

    1.加载数据loading组件 vue-infinite-loading2.loading动画组件 vue-spi...

  • 2017.11.15

    Vue.prototypevue——自定义全局方法,在组件里面使用 Vue.prototype 不是全局变量,而...

  • Vue组件(compoent)

    自定义组件有两种方式1.全局组件,2.局部组件 全局组件:我们可以这样理解,一个vue组件就是一个vue实例 组件...

  • vue自定义全局loading加载组件

    1.实现效果 2.实现原理 Vue.extend:extend 创建的是 Vue 构造器,可通过 new Prof...

网友评论

      本文标题:自定义vue全局组件(Loading为例)

      本文链接:https://www.haomeiwen.com/subject/fhujzqtx.html