Vue|mixin混入

news2024/11/15 7:53:55

目录

  • mixin混入
    • 什么是mixin
    • 代码准备
    • 如何混入?
    • 全局混合

在 Vue 中,混入(Mixins)是一种灵活的分发功能,可以将可复用的代码片段和功能注入到多个组件中。简单来说,混入允许你在多个组件之间共享逻辑,而无需重复代码。

主要特点:

  1. 代码复用:混入可以包含数据、计算属性、方法和生命周期钩子等,可以在多个组件中复用,减少代码冗余。
  2. 合并机制:当组件和混入中存在同名属性或方法时,组件的优先级高于混入。混入的内容会被合并到组件的选项中。
  3. 灵活性:可以在需要的地方选择性地使用混入,而不必在每个组件中都定义相同的逻辑。

mixin混入

什么是mixin

官方解释:混入 (mixin) 提供了一种非常灵活的方式,来分发 Vue 组件中的可复用功能。一个混入对象可以包含任意组件选项。当组件使用混入对象时,所有混入对象的选项将被“混合”进入该组件本身的选项。

代码准备

在components目录下创建两个vue文件,分别为Company.vueStaff.vue。代码块如下:

  • Company.vue
<template>
  <div>
    <h1 ="alertName">公司名称:{{ name }}</h1>
    <h1>地址:{{ address }}</h1>
  </div>
</template>

<script>
export default {
  name: "Company",
  data() {
    return {
      name: "橘猫科技有限公司",
      address: "橘猫街道",
    };
  },
  methods: {
    alertName() {
      alert(this.name);
    },
  },
};
</script>
  • Staff.vue
<template>
  <div>
    <h1 ="alertName">用户名:{{ name }}</h1>
    <h1>性别:{{ sex }}</h1>
  </div>
</template>

<script>
export default {
  name: "Staff",
  data() {
    return {
      name: "摔跤猫子",
      sex: "男",
    };
  },
  methods: {
    alertName() {
      alert(this.name);
    },
  },
};
</script>

两个vue文件分别展示【员工信息】与【公司信息】,当点击员工名称与公司名称时都会将名称进行弹出显示;在App.vue中引入这两个vue文件并通过终端执行命令运行。

  • App.vue
<!-- 结构 -->
<template>
   <StaffVue />
   <CompanyVue />
</template>

<!-- 交互 -->
<script>
import StaffVue from './components/Staff.vue'
import CompanyVue from './components/Company.vue'

export default {
  name: 'App',
  components: {
    StaffVue,
    CompanyVue
  },
}
</script>
<!-- 样式 -->
<style>
#app {
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-align: center;
  color: #2c3e50;
  margin-top: 60px;
}
</style>

控制台出现了报错 10:9 error Component name "Company" should always be multi-word vue/multi-word-component-names,10:9错误组件名称“Company”应始终为多字vue/多字组件名称

在这里插入图片描述

这个报错的原因是在组件命名的时候未按照 ESLint 的官方代码规范进行命名,根据 ESLint 官方代码风格指南,除了根组件(App.vue)以外,其他自定义组件命名要使用大驼峰命名方式或者用“-”连接单词进行命名;解决方案如下:

  • 找到vue.config.js文件
  • 添加 lintOnSave: false配置下,关闭eslint校验
  • 重新启动项目

在这里插入图片描述

项目启动后,页面点击交互效果如下:

在这里插入图片描述

如何混入?

通过对比Staff.vue以及Company.vue发现两个组件中有很多代码是一致的,这时候就可以把这两段代码分别删除,并且创建一个新的文件分别在各自的组件进行引用,这样就达到了混入的效果,所谓的混入就是多个组件共享混用一个配置。

在这里插入图片描述

在src目录下新建一个mixin_alertName.js的文件,这里叫什么名字都可以。

在这里插入图片描述

再把两个vue组件中的methods代码删掉

在这里插入图片描述

在这里插入图片描述

  • mixin_alertName.js中代码如下:
export const mixin_name = {
    methods:{
        alertName(){
            alert(this.name);
        }
    }
};

在需要用到该组件的vue文件中进行引入,form后填写该文件目录位置,mixin_name为混合组件中定义的名称,需保持一致。

在这里插入图片描述

如何应用这个混合呢?这里需要通过一个全新的配置项:mixins,相比mixin来说多了一个s,这里代表可以应用多个混合组件,它的值是一个数组。

在这里插入图片描述

将混合组件名称填入数组,在另外一个vue文件中也按上述步骤引入即可。

在这里插入图片描述

  • 保存文件后刷新页面,检查控制台是否有报错信息,点击用户名称及公司名称,即可发现使用混入组件与每个组件分别的定义效果一致。
    在这里插入图片描述

mixin_alertName.js中定义一个钩子函数,输出hello,我被调用了,可以在控制台中看到输出了两次,可以看出混合就是复用配置。

在这里插入图片描述
在这里插入图片描述

继续在mixin_alertName.js中增加一段,在这里不配置方法,只配置数据,同时在多个vue组件中进行引入。

在这里插入图片描述

//增加一个mixin_name2,在此处不配置方法,只配置数据
export const mixin_name2 = {
    data(){
        return{
            height:180,
            balance:100
        }
    }
};
  • Staff.vue文件

在这里插入图片描述

打开浏览器,通过插件查看数据,可以看到在Staff.vue中只写了namesex,但是还是出现了heightbalance,这是因为它将当前组件的数据以及引入组件的数据进行了一个整合,组合在一起展示。

在这里插入图片描述

如果在Staff.vue中也存在heightbalance两个字段的话,则以Staff.vue为主。

在这里插入图片描述

在这里插入图片描述

如果在Staff.vue以及mixin_alertName.js中同时定义mounted钩子函数,这时没有优先级,两者都会保留。

在这里插入图片描述
在这里插入图片描述

全局混合

上述步骤中,在每个组件中单独配置、单独引用的方式数据局部混合,什么页面用到了就得这么来一套。

在这里插入图片描述

这里介绍如何实现全局混合,首先在main.js中引入mixin_alertName.js,在创建Vue应用时,使用app.mixin 方法添加全局混入,此时应与上述步骤中的局部混入效果一致,但是在每个vue组件中,已不再重复单独引用。

  • Staff.vue以及Company.vue

在这里插入图片描述

  • main.js
import { createApp } from 'vue';
import App from './App.vue';
import { mixin_name, mixin_name2 } from './mixin_alertName';

//创建Vue的实例对象->vm
const app = createApp(App);

// 全局混入
app.mixin(mixin_name);
app.mixin(mixin_name2);

app.mount('#app');

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2144393.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

QT<24> Qt和windows中获取CPU序列号号以及主板序列号

前言&#xff1a;在qt中获取CPU和主板唯一序列号&#xff0c;可以在程序构造函数中判断是否与windows中一致&#xff0c;不一致可以直接退出程序&#xff0c;防止程序daoyong。 一、获取电脑CPU唯一序列号 QString MainPage::get_cpu() {QString cmd"wmic cpu get proc…

DNS和ICMP

DNS DNS&#xff08;Domain Name System &#xff09; DNS 是一整套从域名映射到 IP 的系统 关于DNS背景 TCP/IP 中使用 IP 地址和端口号来确定网络上的一台主机的一个程序 . 但是 IP 地址不 方便记忆 . 于是人们发明了一种叫主机名的东西 , 是一个字符串 , 并且…

computed计算属性与watch侦听器

1.computed计算属性的写法有两种&#xff0c;一种是只读的&#xff0c;只负责展示&#xff0c;另一种可以进行修改&#xff0c;利用get来获取值&#xff0c;利用set来进行修改 2.watch侦听器的写法也有两种&#xff0c;可以直接写成函数&#xff0c;也可以写成对象&#xff0c;…

浅显易懂的Git教程

Git概述 SVN与Git的对比 SVN&#xff08;Subversion&#xff09; 类型&#xff1a;集中式版本控制系统 工作流程&#xff1a; 从中央服务器下载最新版本到本地。在本地进行开发。提交更改回中央服务器。 优点&#xff1a; 简单易用&#xff0c;适合小型团队。版本历史清…

【源代码+仿真+原理图+技术文档+演示视频+软件】基于物联网的多功能手环设计与实现

摘 要 随着社会进步和生活水平的提高&#xff0c;人们对健康的重视程度不断增加。为了更好地了解自身的身心健康状况&#xff0c;人们对高精密、便携式医疗监控仪器的需求也越来越大。电子信息技术和医学的发展相互促进&#xff0c;二者的结合可以解决人们在健康问题上的困扰…

单通道低压全桥驱动芯片既可应用在电子锁,医疗器械等产品中也能直接Pin to pin贝岭的BL8123

芯片描述 GC8123 是一款低压 5V 全桥驱动芯片&#xff0c;为摄像机、消费类产品、玩具和其他低压或者电池供电的运动控制类应用提供了集成的电机驱动解决方案。GC8123 能提供高达 1.2A 的持续输出电流。可以工作在 1.2~6V 的电源电压上。GC8123 具有 PWM&#xff08;IN/IN&…

Git使用教程-将idea本地文件配置到gitte上的保姆级别教程

&#x1f939;‍♀️潜意识起点&#xff1a;个人主页 &#x1f399;座右铭&#xff1a;得之坦然&#xff0c;失之淡然。 &#x1f48e;擅长领域&#xff1a;前端 是的&#xff0c;我需要您的&#xff1a; &#x1f9e1;点赞❤️关注&#x1f499;收藏&#x1f49b; 是我持…

Linux配置静态IP详细步骤及联网问题,以及更改主机名问题

一&#xff0c;Linux配置静态IP详细步骤及联网问题 我的Linux操作系统版本是是CentOS7/CentOS8 1.网络适配器&#xff1a;NAT模式点击设置-网络适配器-网络连接 &#xff08;选择NAT模式&#xff09;-点击确定 2.查看网关相关配置点击 编辑-虚拟网络编辑器-选择VMnet8-点击更…

python 环境问题

日常环境问题记录 1、pycharm 终端禁止运行脚本1.1 问题描述1.2 以管理员身份运行powershell1.3 修改权限 1、pycharm 终端禁止运行脚本 1.1 问题描述 当我在pycharm终端执行脚本&#xff0c;比如 activate激活虚拟环境时&#xff0c;会报错不让执行 这类问题的出现原因是没…

操作系统相关

操作系统 1. 操作系统主要功能 进程管理 功能&#xff1a;创建、调度、终止进程&#xff0c;管理进程的执行。目的&#xff1a;确保多个进程能够有效地共享处理器资源&#xff0c;并进行合理的调度和管理。 内存管理 功能&#xff1a;分配和管理系统内存&#xff0c;包括虚拟…

02 基于STM32的按键控制继电器驱动电机

本专栏所有源资料都免费获取&#xff0c;没有任何隐形消费。 注意事项&#xff1a;STM32仿真会存在各种各样BUG&#xff0c;且尽量按照同样仿真版本使用。本专栏所有的仿真都采用PROTEUS8.15。 本文已经配置好STM32F103C8T6系列&#xff0c;在PROTUES仿真里&#xff0c;32单片…

系统编程-初识MCU

初识MCU 目录 初识MCU 一、什么是mcu&#xff1f; 二、MCU 的组成与作用 三、常见的MCU 四、家用空气质量检测仪项目分析 1、项目市场调研 2、项目需求分析&#xff08;重要&#xff09; 3、产品的硬件设计 五、常用元器件以及对应电路介绍(重点) 1、电阻 2、电容 …

怎么使用Chrome与C++实现高效自动化测试

在软件开发过程中&#xff0c;自动化测试是确保代码质量和稳定性的关键步骤。谷歌浏览器&#xff08;Chrome&#xff09;提供了强大的开发者工具和丰富的API&#xff0c;结合C的强大功能&#xff0c;可以实现高效的自动化测试。本文将介绍如何使用Chrome和C来实现这一目标。&am…

路径规划算法-蚁群算法

一、蚁群算法&#xff08;ACO&#xff09;基本原理 winter老哥链接 蚁群路径规划算法&#xff08;Ant Colony Optimization, ACO&#xff09;是一种模拟蚂蚁觅食行为的启发式优化算法&#xff0c;它通过模拟蚂蚁在寻找食物过程中的路径选择和信息素交流来解决路径规划问题。以下…

图片文字翻译怎么快速翻译?5个软件教你快速进行图片文字翻译

图片文字翻译怎么快速翻译&#xff1f;5个软件教你快速进行图片文字翻译 图片文字翻译是日常工作和生活中常见的需求&#xff0c;尤其是在处理外文资料或旅游时。以下5款优秀的软件可以帮助你轻松、快速地将图片中的文字进行翻译&#xff0c;让你不再依赖手动输入和繁琐操作。…

linux概述与安装虚拟机

linux 1.Linux 概述 Linux 是一个极具影响力和广泛应用的操作系统。 它起源于芬兰人林纳斯・托瓦兹在大学期间编写的开源内核。Linux 作为一个整体&#xff0c;是免费供用户使用的&#xff0c;具备多用户、多任务、支持多线程的强大特性。 Linux 内核是其核心部分&#xff…

JAVA基础:线程优先级和精灵线程

目录 前言 线程优先级 精灵线程 前言 线程存在的目的是为了提升代码的效率&#xff0c;以前的程序只有主线程自己执行是串行的&#xff0c;这样的代码效率低 &#xff0c;多线程执行的代码是并行的&#xff0c;多个线程同时执行代码&#xff0c;这样的效率高&#xff0c;但是…

Verdin AM62 引脚复用配置

By Toradex 胡珊逢 简介 Verdin AM62 是 Toradex 基于 TI AM623/AM625 SoC 的 Arm 计算机模块。它最多提供 4 个 A53 和 1 个 M4F 处理器。这是 TI 基于其 K3 平台的处理器&#xff0c;虽然和 NXP 的 iMX8M Mini/Plus 都使用 A53 核心&#xff0c;但是由于架构不同&#xff0…

智能优化算法-遗传算法(GA)(附源码)

目录 1.内容介绍 2.部分代码 3.实验结果 4.内容获取 1.内容介绍 遗传算法 (Genetic Algorithm, GA) 是一种基于自然选择和遗传学原理的元启发式优化算法&#xff0c;它模仿了生物进化过程中的选择、交叉和变异操作来搜索最优解。 GA的工作机制主要包括&#xff1a; 选择&am…

1652AM任意波形发生器

1652AM 任意波形发生器 1652AM任意波形发生器是一款多通道、多功能的任意波形发生器。它在兼顾了输出信号高质量的同时&#xff0c;实现了高通道密度。它可与其它通用或专用模块化测试仪器构成综合测试系统或平台&#xff0c;支持众多解决方案&#xff0c;包括先进计算机调…