vue2混入声明组件、交互流程

2024-02-05 09:44

本文主要是介绍vue2混入声明组件、交互流程,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

vue2中可以使用混入,在当前页面中将混入中声明的组件进行注入

写法

父组件声明混入文件:

import mixComponent from "@/mixins/mixComponent"
export default {mixins:[mixComponent]
}

mixComponent文件定义方式,类似于一个vue文件的script区域
我的场景是这样的,在父组件使用混入,混入了一个文件,这个混入内又引用了两个组件,GenerateComponent组件是一个按钮,点击按钮后,生成文件,传给组件:FileListComponent让文件列表展示出来,其中涉及到混入文件中如何跟引入的组件进行交互:组件内使用value接收混入混入文件内传递的数据

const mixins = {data() {generateParams: {taskId: Number},FileListObj: {FileList: [],}},// 此处声明了两个属性,第一个属性是一个按钮组件,第二个属性是一个文件列表的组件,用于展示点击按钮后生成的文件列表computed: {generateBtn() {const generateBtn = {column: [{prop: 'generateProp',component: 'GenerateComponent',display: true,span: 2},{prop: 'fileListProp',component: 'FileListComponent',label: '文件',display: true,span: 24}]}return courtAuthChangeBtn;}},watch: {'form.taskId'(newVal, oldVal) {console.log("监听到taskId发生变动")this.generateParams.taskId = newVal;}},	methods: {updateFileList(newFileList) {console.log("此方法用来改变文件列表组件的value值,达到动态展示文件列表的目的")this.FileListObj.fileList = newFileListthis.form.fileListProp = this.FileListObj}}}
export default mixins;

组件GenerateComponent定义如下:

<template><div><el-button class="btn-class" :disabled="displayFlag" type="text" size="medium" @click="generateFile">生成文件</el-button></div>
</template>
<script>
// 这是后台接口
import {generateFile} from "@/api/tasks/opencourt";
export default {name: "GenerateComponent",props: {value: {taskId: Number}},data() {return {displayFlag: false}},methods: {generateFile() {// 生成文件generateFile(this.value).then(res => {console.log("文件返回: ", res)// 重要:这里这行是关键,是此组件的文件列表展示到文件列表组件上this.$root.updateFileList(res.data.data)})},calDisplay() {// 计算按钮是否可点击}}
}</script>

组件FileListComponent如下:

<template>
<div><avue-crud :option="fileListOption":data="value.fileList"><template slot='filename' slot-scope="{row,index}"><span v-if="row!==undefined && row.url  && row.url.length>=1"><a style="color: #409EFF;cursor: pointer" @click="filePreview(row.url)">{{ row.filename }}</a></span></template></avue-crud>
</div>
</template>export default {name: "FileListComponent",props: {value: {fileList: []},},}

这里的FileListComponent主要用来展示文件列表;

这里主要表达了,混入文件引入两个组件,如何让这两个组件进行交互,可以在混入文件中定义影响组件数据的方法,然后在组件中使用this.$root.updateFileList(res.data.data) 来调用混入文件中定义的这个方法达到数据交互目的

这篇关于vue2混入声明组件、交互流程的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/680523

相关文章

Spring Security中用户名和密码的验证完整流程

《SpringSecurity中用户名和密码的验证完整流程》本文给大家介绍SpringSecurity中用户名和密码的验证完整流程,本文结合实例代码给大家介绍的非常详细,对大家的学习或工作具有一定... 首先创建了一个UsernamePasswordAuthenticationTChina编程oken对象,这是S

前端如何通过nginx访问本地端口

《前端如何通过nginx访问本地端口》:本文主要介绍前端如何通过nginx访问本地端口的问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、nginx安装1、下载(1)下载地址(2)系统选择(3)版本选择2、安装部署(1)解压(2)配置文件修改(3)启动(4)

HTML中meta标签的常见使用案例(示例详解)

《HTML中meta标签的常见使用案例(示例详解)》HTMLmeta标签用于提供文档元数据,涵盖字符编码、SEO优化、社交媒体集成、移动设备适配、浏览器控制及安全隐私设置,优化页面显示与搜索引擎索引... 目录html中meta标签的常见使用案例一、基础功能二、搜索引擎优化(seo)三、社交媒体集成四、移动

HTML input 标签示例详解

《HTMLinput标签示例详解》input标签主要用于接收用户的输入,随type属性值的不同,变换其具体功能,本文通过实例图文并茂的形式给大家介绍HTMLinput标签,感兴趣的朋友一... 目录通用属性输入框单行文本输入框 text密码输入框 password数字输入框 number电子邮件输入编程框

HTML img标签和超链接标签详细介绍

《HTMLimg标签和超链接标签详细介绍》:本文主要介绍了HTML中img标签的使用,包括src属性(指定图片路径)、相对/绝对路径区别、alt替代文本、title提示、宽高控制及边框设置等,详细内容请阅读本文,希望能对你有所帮助... 目录img 标签src 属性alt 属性title 属性width/h

CSS3打造的现代交互式登录界面详细实现过程

《CSS3打造的现代交互式登录界面详细实现过程》本文介绍CSS3和jQuery在登录界面设计中的应用,涵盖动画、选择器、自定义字体及盒模型技术,提升界面美观与交互性,同时优化性能和可访问性,感兴趣的朋... 目录1. css3用户登录界面设计概述1.1 用户界面设计的重要性1.2 CSS3的新特性与优势1.

Android ViewBinding使用流程

《AndroidViewBinding使用流程》AndroidViewBinding是Jetpack组件,替代findViewById,提供类型安全、空安全和编译时检查,代码简洁且性能优化,相比Da... 目录一、核心概念二、ViewBinding优点三、使用流程1. 启用 ViewBinding (模块级

HTML5 中的<button>标签用法和特征

《HTML5中的<button>标签用法和特征》在HTML5中,button标签用于定义一个可点击的按钮,它是创建交互式网页的重要元素之一,本文将深入解析HTML5中的button标签,详细介绍其属... 目录引言<button> 标签的基本用法<button> 标签的属性typevaluedisabled

HTML5实现的移动端购物车自动结算功能示例代码

《HTML5实现的移动端购物车自动结算功能示例代码》本文介绍HTML5实现移动端购物车自动结算,通过WebStorage、事件监听、DOM操作等技术,确保实时更新与数据同步,优化性能及无障碍性,提升用... 目录1. 移动端购物车自动结算概述2. 数据存储与状态保存机制2.1 浏览器端的数据存储方式2.1.

基于 HTML5 Canvas 实现图片旋转与下载功能(完整代码展示)

《基于HTML5Canvas实现图片旋转与下载功能(完整代码展示)》本文将深入剖析一段基于HTML5Canvas的代码,该代码实现了图片的旋转(90度和180度)以及旋转后图片的下载... 目录一、引言二、html 结构分析三、css 样式分析四、JavaScript 功能实现一、引言在 Web 开发中,