首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何从全局函数- IE11兼容函数访问角分量函数?

如何从全局函数- IE11兼容函数访问角分量函数?
EN

Stack Overflow用户
提问于 2018-10-04 12:33:09
回答 1查看 414关注 0票数 0

这里是情况-我在一个基于角度的应用程序中使用Mastercard支付网关api。api接受成功和错误的回调,回调在脚本标记的数据错误和数据成功属性中传递,以加载Mastercard api。

代码语言:javascript
复制
<script src="https://eu-gateway.mastercard.com/checkout/version/49/checkout.js" 
        data-error="errorCallback" 
        data-cancel="cancelCallback">
</script>

这里的细节

我有一个在火狐和Chrome中运行很好的解决方案,但是在IE11中绝对失败了。我已经取消了所有的多边形填充导入,但是无论我尝试了多少,都没有任何效果。

以下是我迄今所做的工作:

代码语言:javascript
复制
  export class AppComponent implements OnInit {
    constructor(private ngZone: NgZone, private router:Router) {
    var _self = this;

    (<any>window).errorPaymentCallback = function(error){
      console.log(error);
    };

    (<any>window).cancelPaymentCallback = function(){
      console.log('cancel');
    };      
}

无论我尝试了什么,回调都不会被触发,而是api返回一个错误。有什么想法吗?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2018-10-04 13:13:43

您可以分派一个事件,然后在AppComponent中捕获它。

你就是这样做的:

代码语言:javascript
复制
<script src="https://eu-gateway.mastercard.com/checkout/version/49/checkout.js" 
        data-error="errorCallback" 
        data-cancel="cancelCallback">
</script>

    <script type="text/javascript">
        function errorCallback(error) { document.dispatchEvent(new Event('payment-error', { bubbles: true })); }
        function cancelCallback() { document.dispatchEvent(new Event('payment-error', { bubbles: true })); }
        window.global = window;
      </script>

AppComponent

代码语言:javascript
复制
@HostListener('document:payment-error', ['$event'])
  paymentError(event){
    //do your work
  }
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/52646829

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档