广告
返回顶部
首页 > 资讯 > 精选 >vue自定义组件的注册方式有哪些
  • 525
分享到

vue自定义组件的注册方式有哪些

2023-07-04 20:07:41 525人浏览 泡泡鱼
摘要

这篇文章主要介绍“Vue自定义组件的注册方式有哪些”,在日常操作中,相信很多人在vue自定义组件的注册方式有哪些问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”vue自定义组件的注册方式有哪些”的疑惑有所帮助!

这篇文章主要介绍“Vue自定义组件的注册方式有哪些”,在日常操作中,相信很多人在vue自定义组件的注册方式有哪些问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”vue自定义组件的注册方式有哪些”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!

vue自定义组件的注册方式有3种:1、局部注册,在App的components中注册自定义组件。2、全局注册,在“main.js”中注册(挂载)自定义组件。3、在“src/plugin”目录下建一个和组件名称一致的文件夹,然后将自定义组件文件放到这个目录中,接着在这个目录中再建一个“index.js”的文件,通过在这个文件里面写注册代码,将自定义组件注册成插件

创建项目

通过 cmd 执行如下示例命令来初始化我们的 Vue 项目

vue create helloworldcd helloworldcode .npm run serve

命令执行完成后,项目结构如下图所示:

vue自定义组件的注册方式有哪些

接着,我们在 src/components 目录下创建一个自定义的组件 splash.vue,示例代码如下所示:

<template>  <div>    <p>{{ title }}</p>    <p>{{ message }}</p>  </div></template><script>export default {  name: "splash",  props:['title'],  data: function () {    return {      message: "组件启动中...",    };  },};</script>

注册成局部组件

我们知道,通过 Vue-CLI 创建的项目,vue 会自动为我们创建一个 App.vue  的根组件,用于承载整个应用程序,如果我们在 App 的 components 注册我们的自定义组件,那么它也算一个局部组件,只能应用在 App 这样的一个组件内。注册方式如下所示:

<template>  <div id="app">    <img alt="Vue loGo" src="./assets/logo.png" />    <!-- 3.应用自定义组件 -->    <splash title="hello world"></splash>  </div></template><script>// 1.导入组件import Splash from "./components/Splash.vue";export default {  name: "App",  components: {    // 2.注册局部组件    Splash,  },};</script><style>#app {  font-family: Avenir, Helvetica, Arial, sans-serif;  -WEBkit-font-smoothing: antialiased;  -moz-osx-font-smoothing: grayscale;  text-align: center;  color: #2c3e50;  margin-top: 60px;}</style>

执行 npm run serve,会出现如下所示的效果:

vue自定义组件的注册方式有哪些

注册成全局组件

如果想将我们的组件注册成全局组件,共其它所有组件都能使用的话,我们就需要将我们的组件注册成全局组件。同样的,我们需要在 'main.js' 中注册我们的全局组件,示例代码如下所示:

import Vue from 'vue'import App from './App.vue'// 1. 导入自定义组件import Splash from './components/Splash.vue'Vue.config.productionTip = false// 2. 将自定义组件注册成全局组件Vue.component(Splash.name, Splash)new Vue({  render: h => h(App),}).$mount('#app')

修改 HelloWorld.vue,使用上面已经注册的全局组件,示例代码如下所示:

<template>  <div class="hello">    <h2>{{ msg }}</h2>    <!-- 应用自定义组件 -->    <splash></splash>  </div></template><script>export default {  name: "HelloWorld",  props: {    msg: String,  },};</script><style scoped>.hello {  border: 1px dashed #00f;}</style>

修改 App.vue,使用上面已经注册的全局组件,示例代码如下所示:

<template>  <div id="app">    <img alt="Vue logo" src="./assets/logo.png" />    <splash></splash>    <hello-world msg="我是子组件"></hello-world>  </div></template><script>import HelloWorld from "./components/HelloWorld.vue";export default {  name: "App",  components: {    HelloWorld,  },};</script><style>#app {  font-family: Avenir, Helvetica, Arial, sans-serif;  -webkit-font-smoothing: antialiased;  -moz-osx-font-smoothing: grayscale;  text-align: center;  color: #2c3e50;  margin-top: 60px;}</style>

执行 npm run serve,会出现如下所示的效果:

vue自定义组件的注册方式有哪些

注册成插件

由于插件更具灵活性,所以我们可以自定义组件注册成全局组件。按照 Vue 的约定,我们需要将我们的项目结构做一下调整。

src/plugin 目录下建一个和组件名称一致的文件夹,然后将我们上面定义的 splash.vue 文件放到这个目录下面,然后在这个目录下面再建一个 index.js 的文件,通过在这个文件里面写注册代码,将我们的自定义组件注册成插件。示例代码如下所示:

import Splash from './Splash'export default {    install: function (Vue, options) {        // 1.获取构造函数        const contructor = Vue.extend(Splash)        // 2. 实例化组件对象        const instance = new contructor()        // 3. 创建页面元素        const oDiv = document.createElement('div')        document.body.appendChild(oDiv)        // 4. 将组件挂载到页面元素上        instance.$mount(oDiv)        if (options !== null && options.title !== undefined) {            instance.title = options.title        }        // 添加全局方法        Vue.ToggleSplash = function () {            instance.isshow = !instance.isShow;        }        // 添加实例方法        Vue.prototype.$ToggleSplash = function () {            instance.isShow = !instance.isShow;        }    }}

修改 main.js ,示例代码如下所示:

import Vue from 'vue'import App from './App.vue'// 1. 导入自定义组件import Splash from './plugin/splash/index'Vue.config.productionTip = false// 2. 将自定义组件注册成组件Vue.use(Splash, { title: 'hello world' })new Vue({  render: h => h(App),}).$mount('#app')

接下来,我们就可以在 任何组件中通过调用 Vue 对象的全局方法或实例方法来控制我们的自定义组件,比如,我们可以在 hello-world 这样使用:

<template>  <div class="hello">    <h2>{{ msg }}</h2>    <button @click="toggle1">使用全局方法控制显示或隐藏插件</button>    <button @click="toggle2">使用实例方法控制显示或隐藏插件</button>  </div></template><script>import Vue from "vue";export default {  name: "HelloWorld",  props: {    msg: String,  },  methods: {    toggle1: function () {      // 通过全局方法来访问自定义组件      Vue.ToggleSplash();    },    toggle2: function () {      // 通过实例方法来访问自定义组件      this.$ToggleSplash();    },  },};</script><style scoped>.hello {  border: 1px dashed #00f;}</style>

执行 npm run serve,会出现如下所示的效果:

vue自定义组件的注册方式有哪些

到此,关于“vue自定义组件的注册方式有哪些”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注编程网网站,小编会继续努力为大家带来更多实用的文章!

--结束END--

本文标题: vue自定义组件的注册方式有哪些

本文链接: https://www.lsjlt.com/news/347310.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • vue自定义组件的注册方式有哪些
    这篇文章主要介绍“vue自定义组件的注册方式有哪些”,在日常操作中,相信很多人在vue自定义组件的注册方式有哪些问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”vue自定义组件的注册方式有哪些”的疑惑有所帮助!...
    99+
    2023-07-04
  • vue自定义组件的注册方式有几种
    本教程操作环境:windows7系统、vue3版,DELL G3电脑。创建项目通过 cmd 执行如下示例命令来初始化我们的 Vue 项目vue create helloworld cd helloworld code . npm run s...
    99+
    2023-05-14
    Vue
  • Vue组件注册方式有哪些
    小编给大家分享一下Vue组件注册方式有哪些,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!概述组件化的概念让前端页面开发有了更清晰的结构。Vue 中的组件就是一个 ...
    99+
    2023-06-15
  • Android自定义组件:1、什么是自定义组件、自定义组件的方式、定义自定义属性
    声明:本教程不收取任何费用,欢迎转载,尊重作者劳动成果,不得用于商业用途,侵权必究!!! 目录 一、前言 二、什么是自定义组件 三、自定义组件的方式 1、组合现有组件 2、在某...
    99+
    2022-06-06
    属性 自定义属性 Android
  • python元组的定义方式有哪些
    Python元组的定义方式有以下几种: 使用逗号分隔的值: tuple1 = 1, 2, 3 使用圆括号括起来的值: tup...
    99+
    2023-10-23
    python
  • php定义数组的方式有哪些
    这篇文章将为大家详细讲解有关php定义数组的方式有哪些,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。定义数组的方法:1、使用“array(值1,值e2...)”语句;2、使用“array(key1=>...
    99+
    2023-06-15
  • vue自定义指令的方法有哪些
    在vue中自定义指令的方法有:语法:Vue.directive(id, definition);1.自定义全局指令;2.自定义私有指令;在vue中自定义指令的方法有以下两种vue自定义指令语法:Vue.directive(id, ...
    99+
    2022-10-22
  • vue自定义翻页组件的方法
    本文实例为大家分享了vue自定义翻页组件的具体代码,供大家参考,具体内容如下 效果图如下: 1、在components建立page.vue文件 <template>  ...
    99+
    2022-11-13
  • Vue实现自定义组件的方式引入图标
    这篇文章主要讲解了“Vue实现自定义组件的方式引入图标”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Vue实现自定义组件的方式引入图标”吧!前言在项目开发中,使用图标的方式有很多种,可以在i...
    99+
    2023-06-20
  • web面试vue自定义组件及调用方式
    引入: 由于项目需求, 部分相同的代码我们会封装成组件, 在需要使用的地方导入, 并以标签的形式书写在中, 但是在"vant"组件库中, "Dialog 弹出框"组件有2中使用方式 ...
    99+
    2022-11-12
  • vue组件传值的方式有哪些
    这篇文章主要介绍vue组件传值的方式有哪些,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完! 组件传值方式:1、通过路由进行传值;2、通过在父组件中让子组件标...
    99+
    2022-10-19
  • C语言数组定义的方式有哪些
    C语言数组定义的方式有以下几种:1. 一维数组的定义:```ctype arrayName[arraySize];```例如:```...
    99+
    2023-08-09
    C语言
  • vue组件传值方式有哪些
    vue组件传值的方法:1、使用props传递数据,父组件通过HTML属性的方式将数据传递给子组件,子组件通过props来接收传递过来的数据;2、使用$emit触发事件传递数据,子组件使用$emit触发自定义事件,父组件通过v-on来监听子组...
    99+
    2023-07-10
  • vue引入组件有哪些方式
    在vue中引入组件的方式有:1.使用import方法导入;2.使用require方法导入;在vue中引入组件的方式有以下两种使用import方法导入组件import Vue from 'vue'...
    99+
    2022-10-23
  • vue组件通信方式有哪些
    vue中实现组件通信的方式有:1.通过props传递实现组件通信;2.使用ref设置父子组件实现组件通信;3.使用parent创建兄弟组件通信侨联实现组件通信;4.使用provide与inject定义祖后代组件实现组件通信;vue中实现组件...
    99+
    2022-10-17
  • vue事件绑定方式有哪些
    在vue中实现事件绑定的方式有:1.通过v-on指令绑定;2.使用methods方法绑定;3.通过v-show指令绑定;在vue中实现事件绑定的方式有以下几种通过v-on指令绑定事件window.onload = fun...
    99+
    2022-10-17
  • 基于Vue实现自定义组件的方式引入图标
    前言 在项目开发中,使用图标的方式有很多种,可以在iconfont上面找到合适的图标,通过http或者直接下载使用,这里我分享一种通过实现自定义组件的方式引入图标。 搭建环境 这里...
    99+
    2022-11-12
  • Vue组件间的通讯方式有哪些
    本篇内容主要讲解“Vue组件间的通讯方式有哪些”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Vue组件间的通讯方式有哪些”吧!前言Vue 提供了各种各样的通讯,其中包括兄弟间的通讯和非兄弟间的通...
    99+
    2023-06-27
  • Vue中的组件通信方式有哪些
    Vue中的组件通信方式有哪些,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。vue组件中关系说明:如上图所示, A与B、A与C、...
    99+
    2022-10-19
  • 免费的Bootstrap5自定义组件生成器有哪些
    本篇内容介绍了“免费的Bootstrap5自定义组件生成器有哪些”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所...
    99+
    2022-10-19
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作