javascript - 如何正确加载和使用 Angular 9 中的 gapi.iframes 库?
问题描述
我正在尝试将 google api iframe 添加到我的项目中,如Android Management API 文档中所述:
<script src="https://apis.google.com/js/api.js"></script>
<div id="container"></div>
<script>
gapi.load('gapi.iframes', function() {
var options = {
'url': 'https://play.google.com/work/embedded/search?token=web_token&mode=SELECT',
'where': document.getElementById('container'),
'attributes': { style: 'width: 600px; height:1000px', scrolling: 'yes'}
}
var iframe = gapi.iframes.getContext().openChild(options);
});
</script>
<script>
由于框架不支持标签,如何使其在 Angular 9 组件上工作?
我已经阅读了很多关于如何使用 Injection、Renderer2 和其他东西动态加载外部 js 的答案,但是所有示例都只描述了如何加载 js 库,而不是如何从 angular 组件中实际使用它。
解决方案
您可以在您的组件 *.ts 文件中声明一个变量,就像您的导入一样,
declare const gapi: any;
在您要启动 iframe 加载的函数中。
gapi.load('gapi.iframes', function() {
var options = {
'url': 'https://play.google.com/work/embedded/search?token=web_token&mode=SELECT',
'where': document.getElementById('container'),
'attributes': { style: 'width: 600px; height:1000px', scrolling: 'yes'}
}
var iframe = gapi.iframes.getContext().openChild(options);
});
推荐阅读
- r - ggplot - 如何手动调整标签
- python-3.x - Django-Python十进制数格式化逗号问题
- jboss - 从工件加载 Keycloak 模块
- c# - MWS 金融服务客户端库返回空异常
- spring - 使用 mvn clean install 执行应用程序
- swift - urlrequest 不发送 post 请求
- c# - Windows表单组合框中的小复杂数据绑定
- amazon-web-services - 用于替换 AWS 身份验证的访问密钥
- iis - 设置 IIS 应用程序虚拟目录物理路径
- c# - How to control NuGet packages in Android Class Library?