码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 浅谈如何解决公共组件父子组件依赖调用和子组件校验父组件条件的问题


    问题背景:

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

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

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

    关于依赖

    尝试动态注入依赖

    import

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

    require

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

    其他思考

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

    解决办法

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

    部分代码如下:

     
    • 相关阅读:
      职场CPU反着用!爽呆了!
      Java基础28(方法重载)
      动态负载均衡
      如何找到能真正实现FTP替代的文件传输软件?
      PDF有限制密码,不能复制怎么办?
      获取文件信息: 大小, 文件类型等.
      含文档+PPT+源码等]精品基于springboot幼儿园管理系统包运行成功]Java毕业设计SpringBoot项目源码
      Turtlebot3-burger入门教程#foxy版#-PC安装
      经济发展由新技术推动着来
      Java底层HashMap的如何解释?
    • 原文地址:https://blog.csdn.net/web220507/article/details/127856869
    • 最新文章
    • 攻防演习之三天拿下官网站群
      数据安全治理学习——前期安全规划和安全管理体系建设
      企业安全 | 企业内一次钓鱼演练准备过程
      内网渗透测试 | Kerberos协议及其部分攻击手法
      0day的产生 | 不懂代码的"代码审计"
      安装scrcpy-client模块av模块异常,环境问题解决方案
      leetcode hot100【LeetCode 279. 完全平方数】java实现
      OpenWrt下安装Mosquitto
      AnatoMask论文汇总
      【AI日记】24.11.01 LangChain、openai api和github copilot
    • 热门文章
    • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
      奉劝各位学弟学妹们,该打造你的技术影响力了!
      五年了,我在 CSDN 的两个一百万。
      Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
      面试官都震惊,你这网络基础可以啊!
      你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
      心情不好的时候,用 Python 画棵樱花树送给自己吧
      通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
      13 万字 C 语言从入门到精通保姆级教程2021 年版
      10行代码集2000张美女图,Python爬虫120例,再上征途
    Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
    正则表达式工具 cron表达式工具 密码生成工具

    京公网安备 11010502049817号