浅谈如何解决公共组件父子组件依赖调用和子组件校验父组件条件的问题

本文探讨如何解决前端公共组件在不同页面中的接口调用问题和子组件对父组件条件的校验。通过动态注入依赖的尝试与分析,最终采取暴露组件方法给父组件,实现接口依赖的解耦。同时,介绍子组件如何依据父组件的条件执行校验,以确保组件间的低耦合和灵活性。
摘要由CSDN通过智能技术生成

问题背景:

业务需求需要用到一个数据批量上传和上传模板导入功能,并且在很多个页面中都需要用到。但是每个页面调用的上传或模版下载依赖的接口地址或者接口方法都有区别。基于此,想要将这个公共上传组件抽离出来,并且尽量低耦合,能够满足不同页面的调用和传参。

以下言论,是一个小白解决问题的过程,若思考思路和知识面限制,还请各路大佬指点

  • 痛点一:如何解决不同页面的接口调用方法依赖问题
  • 痛点二:如何解决在调用页面执行组件内部的某些方法前,如何添加父级组件层面的校验问题

关于依赖

尝试动态注入依赖

import

关于痛点一,第一个想到的,就是能不能执行依赖的动态注入,但是所有的接口调用方法均按模块封装成api.js文件,并且模块中通过export 进行导出,需要使用import { xxx } form './XXXpath'导出到组件中,方能进行使用。并且import导入为静态导入,于是放弃这个尝试。

require

接下来想到另一个导入的方式require,但是require导入的是一个模块(具体了解CommonJS),而接口api.js 如果重新改动,牵扯太多,于是也放弃此法。

其他思考

如果将api.js放到公共组件中,则耦合度会很高,后期新增或者修改接口依赖,或者进行其他扩展,就要伤筋动骨,不符合低耦合的理念,因此不考虑在组件内部注入相关接口依赖。

解决办法

既然不打算将接口依赖放到组件中,那么就只有暴露出来给父级组件,在某些时间的时候,调用某些接口,执行某些方法。

部分代码如下:

 <div class="AS-upload">
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值