别院牧志知识库 别院牧志知识库
首页
  • 基础

    • 全栈之路
    • 😎Awesome资源
  • 进阶

    • Python 工匠系列
    • 高阶知识点
  • 指南教程

    • Socket 编程
    • 异步编程
    • PEP 系列
  • 面试

    • Python 面试题
    • 2022 面试记录
    • 2021 面试记录
    • 2020 面试记录
    • 2019 面试记录
    • 数据库索引原理
  • 基金

    • 基金知识
    • 基金经理
  • 细读经典

    • 德隆-三个知道
    • 孔曼子-摊大饼理论
    • 配置者说-躺赢之路
    • 资水-建立自己的投资体系
    • 反脆弱
  • Git 参考手册
  • 提问的智慧
  • 分类
  • 标签
  • 归档
GitHub (opens new window)
首页
  • 基础

    • 全栈之路
    • 😎Awesome资源
  • 进阶

    • Python 工匠系列
    • 高阶知识点
  • 指南教程

    • Socket 编程
    • 异步编程
    • PEP 系列
  • 面试

    • Python 面试题
    • 2022 面试记录
    • 2021 面试记录
    • 2020 面试记录
    • 2019 面试记录
    • 数据库索引原理
  • 基金

    • 基金知识
    • 基金经理
  • 细读经典

    • 德隆-三个知道
    • 孔曼子-摊大饼理论
    • 配置者说-躺赢之路
    • 资水-建立自己的投资体系
    • 反脆弱
  • Git 参考手册
  • 提问的智慧
  • 分类
  • 标签
  • 归档
GitHub (opens new window)
  • 工作
  • 规范

  • Linux

  • 数据库

  • Git

  • 👨‍💻Web

  • 英语

  • Docker

  • 编辑器

  • 网络

  • 前端

    • 前端模板收集
    • 《Vue》笔记

    • Vue 资源
    • Angular

      • Angular 弹框与父组件之间传值的问题(最重要的是父组件接收子组件的返回值)
        • 子组件(弹框 modal)中
        • 父组件中,调用发起方
        • 同步调用
        • 参考链接
      • Angular 中如何对一个动态表单根据 select 的选项 disable 关联的 input?
    • JavaScript

    • Vue文章

  • 存储

  • 备忘录

  • 如何开始你的单元测试
  • 以程序员的视角看中国——西安篇
  • 💻工作
  • 前端
  • Angular
佚名
2020-05-25
目录

Angular 弹框与父组件之间传值的问题(最重要的是父组件接收子组件的返回值)

# 子组件(弹框 modal)中

@Output() action = new EventEmitter();

// now on click ok button emit the output from confirmPopupComponent
public clickOk() {
    this.loading = true;
    this.action.emit(true); // 提交给父组件,here you can send object  instead of true
}
1
2
3
4
5
6
7

# 父组件中,调用发起方

LocateDiskAction(lightState) {
    this.clickModal = true  // 弹框置true
    let lightDisk = await this.getDisklight(lightState)
    let initialState = {
      lightDisk: lightDisk,
      action: lightState,
      hostName: this.hostName,
    };
    let bsModalRef = this.modalService.show(DiskLocateModalComponent, {
      initialState,
    });
    bsModalRef.content.action.take(1).subscribe((value) => {
        console.log(value) // here you will get the value
    });
    }
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15

如果上面的调用出错,可以试试下面的方法:

openModalWithComponent() {
  const initialState = {
    list: [
      {"tag":'Count',"value":this.itemList.length}
    ]
  };
  this.bsModalRef = this.modalService.show(ItemAddComponent, {initialState});
  this.bsModalRef.content.closeBtnName = 'Close';

  this.bsModalRef.content.event.subscribe(res => {
    this.itemList.push(res.data);
  });
}
1
2
3
4
5
6
7
8
9
10
11
12
13

# 同步调用

  async LocateDiskAction(lightState) {
    this.clickModal = true  // 弹框置true
    let lightDisk = await this.getDisklight(lightState)
    let initialState = {
      lightDisk: lightDisk,
      action: lightState,
      hostName: this.hostName,
    };

    let bsModalRef = this.modalService.show(DiskLocateModalComponent, {
      initialState,
    });

    let newSubscriber = this.modalService.onHide.subscribe(r=>{
      newSubscriber.unsubscribe();
      this.clickModal = false
      console.log('DATA',bsModalRef.content);
    });
  }

  getDisklight(diskSignal) {
    return this.client.get(`api/disk/${this.hostName}?disk_status=${diskSignal}`).toPromise();
  }
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23

# 参考链接

  1. How to pass data to modal ngx-bootstrap and receive return data ? · Issue #2290 · valor-software/ngx-bootstrap (opens new window)
  2. How to pass data between NGX Bootstrap modal and parent (opens new window)
编辑 (opens new window)
#前端
上次更新: 2024-07-15, 08:03:22
Vue 资源
Angular 中如何对一个动态表单根据 select 的选项 disable 关联的 input?

← Vue 资源 Angular 中如何对一个动态表单根据 select 的选项 disable 关联的 input?→

最近更新
01
提升沟通亲和力的实用策略
03-26
02
工作
07-15
03
如何选房子
06-25
更多文章>
Theme by Vdoing | Copyright © 2019-2025 IMOYAO | 别院牧志
  • 跟随系统
  • 浅色模式
  • 深色模式
  • 阅读模式