≡
  • 网络编程
  • 数据库
  • CMS技巧
  • 软件编程
  • PHP笔记
  • JavaScript
  • MySQL
位置:首页 > 网络编程 > vue.js

Vue 自定义动态组件实例分析

人气:403 时间:2019-04-10

这篇文章主要为大家详细介绍了Vue 自定义动态组件实例分析,具有一定的参考价值,可以用来参考一下。

感兴趣的小伙伴,下面一起跟随四海网的小编两巴掌来看看吧!

现在基于vue的UI组件库有很多,比如iview,element-ui等。但有时候这些组件库满足不了我们的开发需求,这时候我们就需要自己写一个插件。

 

举第一个栗子

 

用vue-cli搭建好项目目录之后,在src/components下面新建一个文件夹放我们要写的插件,如图所示:

 

 
【图片暂缺】

 

index.vue里写我们的组件,代码如下:

 

 
【图片暂缺】

 

index.js里面写index.vue的install方法,并用Vue.component注册组件,代码如下:

 

 
【图片暂缺】

 

接下来我们要在默认的main.js里将刚刚写的index.js文件导入,并通过Vue.use来使用它,代码如下:

 

 
【图片暂缺】

 

大功告成,接下来在app.vue里直接使用就可以啦,可以看到页面已经显示相应的组件了,如图:

 

 
【图片暂缺】

 

这时候我们还可以自定义click事件,并通过参数的方式传递给我们的插件,插件可以通过props属性获取到该事件,如图:

 

 
【图片暂缺】

 

可以看到页面已经生效了:

 

 
【图片暂缺】

 

Vue.component(id, [definition])用于注册或获取组件。

Vue.use(plugin)用于安装 Vue.js 插件。如果插件是一个对象,必须提供 install 方法。如果插件是一个函数,它会被作为 install 方法。install 方法调用时,会将 Vue 作为参数传入。当 install 方法被同一个插件多次调用,插件将只会被安装一次。

 

举第二个栗子

 

我们再建一个文件夹,如图:

 

 
【图片暂缺】

 

我们要写一个组件,能够显示外部传进来的内容,并在3秒后自动消失,代码如下:

 

 
【图片暂缺】

 

接下来我们要在index.js里使用构造器来创建它,如图:

 

 
【图片暂缺】

 

依旧在默认的main.js里引用刚刚的js文件,并加入到Vue实例上,这样我们就可以直接通过this.$seconddemo()来调用了,代码如下:

代码如下:


import SecondDemo from './components/global/seconddemo/index'Vue.prototype.$seconddemo = SecondDemo

在app.vue里使用它,发现插件加载成功了,如图:

 

 
【图片暂缺】

 

Vue.extend(options)是 Vue 的构造器,用于创建一个“子类”。

 

统一管理自定义组件

 

当组件数量很多时,我们可以通过提供一个统一的出口文件来管理这些自定义组件,首先在global文件夹下新建一个index.js文件,代码如图:

 

 
【图片暂缺】

 

index.js文件帮我们把所有自定义的组件都通过Vue.component注册了,最后export一个包含install方法的对象给Vue.use()使用。

这时候我们不需要在main.js里逐个添加动态组件了,只需要导入统一的index.js文件,并用Vue.use它就ok了。

本文来自:http://www.q1010.com/184/5048-0.html

注:关于Vue 自定义动态组件实例分析的内容就先介绍到这里,更多相关文章的可以留意四海网的其他信息。

关键词:vue.js

您可能感兴趣的文章

  • Vue中computed与methods的区别分析
  • vue数据控制视图源码解析
  • vue渲染时闪烁{{}}的问题及解决方法
  • vue-cli脚手架-bulid下的配置文件
  • vue2中使用less简易教程
  • 关于vuejs中v-if和v-show的区别及v-show不起作用问题
  • Vue自定义过滤器格式化数字三位加一逗号实现代码
  • Vue 项目中遇到的跨域问题及解决方法(后台php)
  • vue 开发一个按钮组件的示例代码
  • vue页面加载闪烁问题的解决方法
上一篇:Vue.js实现可配置的登录表单代码分析
下一篇:vue渲染时闪烁{{}}的问题及解决方法
热门文章
  • Vue 报错TypeError: this.$set is not a function 的解决方法
  • vue实现动态添加数据滚动条自动滚动到底部的示例代码
  • vue项目设置scrollTop不起作用(总结)
  • vue项目中使用vue-i18n报错的解决方法
  • iview实现select tree树形下拉框的示例代码
  • 分析关于element级联选择器数据回显问题
  • vue项目打包后打开页面空白解决办法
  • 解决element ui select下拉框不回显数据问题的解决
  • element-ui table span-method(行合并)的实现代码
  • element-ui 设置菜单栏展开的方法
  • 最新文章
    • 理解vue ssr原理并自己搭建简单的ssr框架
    • vue favicon设置以及动态修改favicon的方法
    • vue-router启用history模式下的开发及非根目录部署方法
    • 从零开始在NPM上发布一个Vue组件的方法步骤
    • Element input树型下拉框的实现代码
    • Vue 报错TypeError: this.$set is not a function 的解决方法
    • Vue.js组件高级特性实例分析
    • 浅谈VueJS SSR 后端绘制内存泄漏的相关解决经验
    • 分析Vue.js自定义tipOnce指令用法实例
    • 浅谈vuex actions和mutation的异曲同工

四海网收集整理一些常用的php代码,JS代码,数据库mysql等技术文章。