从 iframe 关闭 Angular md-dialog

Close Angular md-dialog from an iframe

我正在查看是否可以从 iframe 关闭 md-dialog (Angular Material),该 iframe 包含另一个 Angular 应用程序。 iframe 已加载到我想关闭的 md 对话框中。

看例子:

<md-dialog class="modal-dialog contract-detail">
    <md-dialog-content flex="auto">
        <div class="modal-header">
            <button type="button" class="close" aria-label="Close" ng-click="closeDialog()">
                <span aria-hidden="true">&times;</span>
            </button>
        </div>
        <div class="modal-body">
      <iframe ng-src="{{urlIframe}}"
              frameborder="0"
              allowfullscreen
              style="position: absolute;top: 0;left: 0;width: 100%;height: 90%;"
              align="center">
      </iframe>
    </div>
  </md-dialog-content>
</md-dialog>

变量 {{urlIframe}} 包含 Angular 应用 URL。

您可以访问父 angular 应用程序的范围,例如,

var $scope = parent.angular.element('.modal-dialog.contract-detail').scope();

然后只需在 $scope 上调用 closeDialog 函数即可关闭对话框。