微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

Angular中的小部件Eventbrite

如何解决Angular中的小部件Eventbrite

要在eventbrite中进行签出,请在文档中使用扩展窗口的小部件(https://www.eventbrite.com/platform/docs/embedded-checkout),但是如何在angular中使用原始代码?我已经这样做了:

  1. <script src="https://www.eventbrite.com/static/widgets/eb_widgets.js"></script>放入index.html
  2. 使用按钮<button id="eventbrite-widget-trigger" type="button">Buy Tickets</button>创建组件
  3. 使用窗口小部件配置创建.ts:
    const eventbriteCallback = function () {
      console.log("Order complete!");
    };
    
    window.EBWidgets.createWidget({
      widgetType: "checkout",eventId: "52766401728",//Here is event dinamically
      modal: true,modalTriggerElementId: "eventbrite-widget-trigger",onorderComplete: eventbriteCallback,});

但是如何将原始代码(第3点)与组件(第2点)合并并以动态方式发送eventId? 还是有人将eventbrite中的checkout与angular集成在一起?

解决方法

您可以使用NgZone来实现例如:

AppComponent中:

import { NgZone} from '@angular/core'; // import

在构造函数中:

 constructor(private _ngZone: NgZone) {

 this._ngZone.runOutsideAngular(() => {

 window.EBWidgets // put your code that will be executed outside of angular

  });

 } 
,

感谢Abderrahim Soubai-Elidrisi,我这样做可以解决我的问题:

在文件angular.json的scripts数组中添加脚本

按照本文中的步骤操作:How to call JavaScript functions from Typescript in Angular 5?

  1. 在以下文件夹中创建文件:src / assets / js / eventbrite / register.js,
    function registerEvent(eventId,action) {
      const button = document.createElement("button");
      button.setAttribute("id","example-widget-trigger");
      button.setAttribute("type","button");
      document.body.appendChild(button);
      button.style.display = "none";
      setTimeout(() => {
        document.body.removeChild(button);
      },200);
    
      window.EBWidgets.createWidget({
        widgetType: "checkout",eventId: eventId,modal: true,modalTriggerElementId: "example-widget-trigger",onOrderComplete: action,});
    
      button.click();
    }
  1. 在angular.json中搜索projects.architect.scripts并添加src / assets / js / eventbrite / register.js to array scripts
  2. 要在导入后调用该函数:声明function registerEvent(eventId,action): void;
  3. 致电registerEvent(eventId,exampleCallback); Show steps 3 and 4

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?