chst365's blog chst365's blog
首页
  • Git
  • 网络
  • 操作系统
  • 浏览器
  • webpack
  • JavaScript
  • TypeScript
  • 性能
  • 工程化
  • React
  • 编程题
  • React技术揭秘
  • 算法
  • Node
  • 编码解码
  • NodeJS系列
  • Linux系列
  • JavaScript系列
  • HTTP系列
  • GIT系列
  • ES6系列
  • 设计模式系列
  • CSS系列
  • 小程序系列
  • 数据结构与算法系列
  • React系列
  • Vue3系列
  • Vue系列
  • TypeScript系列
  • Webpack系列
  • 分类
  • 标签
  • 归档
GitHub (opens new window)

chst365

DIV工程师
首页
  • Git
  • 网络
  • 操作系统
  • 浏览器
  • webpack
  • JavaScript
  • TypeScript
  • 性能
  • 工程化
  • React
  • 编程题
  • React技术揭秘
  • 算法
  • Node
  • 编码解码
  • NodeJS系列
  • Linux系列
  • JavaScript系列
  • HTTP系列
  • GIT系列
  • ES6系列
  • 设计模式系列
  • CSS系列
  • 小程序系列
  • 数据结构与算法系列
  • React系列
  • Vue3系列
  • Vue系列
  • TypeScript系列
  • Webpack系列
  • 分类
  • 标签
  • 归档
GitHub (opens new window)
  • NodeJS系列

  • Linux系列

  • JavaScript系列

  • HTTP系列

  • GIT系列

  • ES6系列

  • 设计模式系列

  • CSS系列

  • 小程序系列

  • 数据结构与算法系列

  • React系列

  • Vue3系列

  • Vue系列

    • vue项目本地开发完成后部署到服务器后报404是什么原因呢?
    • Vue项目中有封装过axios吗?主要是封装哪方面的?
    • 你了解axios的原理吗?有看过它的源码吗?
    • 双向数据绑定是什么
    • Vue组件之间的通信方式都有哪些?
    • Vue中组件和插件有什么区别?
      • 一、组件是什么
      • 二、插件是什么
      • 三、两者的区别
        • 编写形式
        • 注册形式
        • 使用场景
      • 参考文献
    • Vue项目中你是如何解决跨域的呢?
    • 为什么data属性是一个函数而不是一个对象?
    • 动态给vue的data添加一个新的属性时会发生什么?怎样解决?
    • 你了解vue的diff算法吗?说说看
    • 你有写过自定义指令吗?自定义指令的应用场景有哪些?
    • 你是怎么处理vue项目中的错误的?
    • Vue中的过滤器了解吗?过滤器的应用场景有哪些?
    • SPA首屏加载速度慢的怎么解决?
    • v-if和v-for的优先级是什么?
    • 说说你对keep-alive的理解是什么?
    • 你知道vue中key的原理吗?说说你对它的理解
    • 请描述下你对vue生命周期的理解?在created和mounted这两个生命周期中请求数据有什么区别呢?
    • 说说你对vue的mixin的理解,有什么应用场景?
    • Vue常用的修饰符有哪些有什么应用场景
    • Vue实例挂载的过程
    • Vue中的$nextTick有什么作用?
    • Vue.observable你有了解过吗?说说看
    • vue要做权限管理该怎么做?如果控制到按钮级别的权限怎么做?
    • v-show和v-if有什么区别?使用场景分别是什么?
    • 说说你对slot的理解?slot使用场景有哪些?
    • 你对SPA单页面的理解,它的优缺点分别是什么?如何实现SPA应用呢
    • SSR解决了什么问题?有做过SSR吗?你是怎么做的?
    • 说下你的vue项目的目录结构,如果是大型项目你该怎么划分结构和划分组件呢?
    • 什么是虚拟DOM?如何实现一个虚拟DOM?说说你的思路
    • 有使用过vue吗?说说你对vue的理解
    • vue3有了解过吗?能说说跟vue2的区别吗?
  • TypeScript系列

  • Webpack系列

  • 面试官
  • Vue系列
chst365
2023-06-28
目录

Vue中组件和插件有什么区别?

# 面试官:Vue中组件和插件有什么区别?

image.png

# 一、组件是什么

回顾以前对组件的定义:

组件就是把图形、非图形的各种逻辑均抽象为一个统一的概念(组件)来实现开发的模式,在Vue中每一个.vue文件都可以视为一个组件

组件的优势

  • 降低整个系统的耦合度,在保持接口不变的情况下,我们可以替换不同的组件快速完成需求,例如输入框,可以替换为日历、时间、范围等组件作具体的实现

  • 调试方便,由于整个系统是通过组件组合起来的,在出现问题的时候,可以用排除法直接移除组件,或者根据报错的组件快速定位问题,之所以能够快速定位,是因为每个组件之间低耦合,职责单一,所以逻辑会比分析整个系统要简单

  • 提高可维护性,由于每个组件的职责单一,并且组件在系统中是被复用的,所以对代码进行优化可获得系统的整体升级

# 二、插件是什么

插件通常用来为 Vue 添加全局功能。插件的功能范围没有严格的限制——一般有下面几种:

  • 添加全局方法或者属性。如: vue-custom-element
  • 添加全局资源:指令/过滤器/过渡等。如 vue-touch
  • 通过全局混入来添加一些组件选项。如vue-router
  • 添加 Vue 实例方法,通过把它们添加到 Vue.prototype 上实现。
  • 一个库,提供自己的 API,同时提供上面提到的一个或多个功能。如vue-router

# 三、两者的区别

两者的区别主要表现在以下几个方面:

  • 编写形式
  • 注册形式
  • 使用场景

# 编写形式

# 编写组件

编写一个组件,可以有很多方式,我们最常见的就是vue单文件的这种格式,每一个.vue文件我们都可以看成是一个组件

vue文件标准格式

<template>
</template>
<script>
export default{ 
    ...
}
</script>
<style>
</style>
1
2
3
4
5
6
7
8
9

我们还可以通过template属性来编写一个组件,如果组件内容多,我们可以在外部定义template组件内容,如果组件内容并不多,我们可直接写在template属性上

<template id="testComponent">     // 组件显示的内容
    <div>component!</div>   
</template>

Vue.component('componentA',{ 
    template: '#testComponent'  
    template: `<div>component</div>`  // 组件内容少可以通过这种形式
})
1
2
3
4
5
6
7
8

# 编写插件

vue插件的实现应该暴露一个 install 方法。这个方法的第一个参数是 Vue 构造器,第二个参数是一个可选的选项对象

MyPlugin.install = function (Vue, options) {
  // 1. 添加全局方法或 property
  Vue.myGlobalMethod = function () {
    // 逻辑...
  }

  // 2. 添加全局资源
  Vue.directive('my-directive', {
    bind (el, binding, vnode, oldVnode) {
      // 逻辑...
    }
    ...
  })

  // 3. 注入组件选项
  Vue.mixin({
    created: function () {
      // 逻辑...
    }
    ...
  })

  // 4. 添加实例方法
  Vue.prototype.$myMethod = function (methodOptions) {
    // 逻辑...
  }
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27

# 注册形式

# 组件注册

vue组件注册主要分为全局注册与局部注册

全局注册通过Vue.component方法,第一个参数为组件的名称,第二个参数为传入的配置项

Vue.component('my-component-name', { /* ... */ })
1

局部注册只需在用到的地方通过components属性注册一个组件

const component1 = {...} // 定义一个组件

export default {
	components:{
		component1   // 局部注册
	}
}
1
2
3
4
5
6
7

# 插件注册

插件的注册通过Vue.use()的方式进行注册(安装),第一个参数为插件的名字,第二个参数是可选择的配置项

Vue.use(插件名字,{ /* ... */} )
1

注意的是:

注册插件的时候,需要在调用 new Vue() 启动应用之前完成

Vue.use会自动阻止多次注册相同插件,只会注册一次

# 使用场景

具体的其实在插件是什么章节已经表述了,这里在总结一下

组件 (Component) 是用来构成你的 App 的业务模块,它的目标是 App.vue

插件 (Plugin) 是用来增强你的技术栈的功能模块,它的目标是 Vue 本身

简单来说,插件就是指对Vue的功能的增强或补充

# 参考文献

  • https://vue3js.cn/docs/zh
#面试官
上次更新: 2025/04/11, 17:57:53
Vue组件之间的通信方式都有哪些?
Vue项目中你是如何解决跨域的呢?

← Vue组件之间的通信方式都有哪些? Vue项目中你是如何解决跨域的呢?→

最近更新
01
面试官
03-27
02
this&指针&作用域&闭包
03-27
03
前端
03-27
更多文章>
Theme by Vdoing | Copyright © 2019-2025 chst365 | 豫ICP备17031889号-1
  • 跟随系统
  • 浅色模式
  • 深色模式
  • 阅读模式