我正在尝试将角度为2的条纹元素与接受信用卡信息的元素卡集成在一起。请注意,我不是在寻找到使用条纹结账因为有这个几个例子如何条纹与角2带角度的条纹元素2
declare var Stripe:any;
@Component({
selector: 'app-account',
templateUrl: './account.component.html',
styleUrls: ['./account.component.scss']
})
export class AccountComponent implements OnInit {
constructor(
private _zone: NgZone
) { }
private cardToken:any;
ngOnInit() {
if (typeof window !== 'undefined') {
this.setUpCard();
}
}
setUpCard() {
var stripe = Stripe('TEST_API_KEY');
var elements = stripe.elements();
var style = {
base: {
fontSize: '16px',
lineHeight: '24px'
}
};
var card = elements.create('card', {style: style});
card.mount('#card-element');
}
getCardData(number, month, year, cvc) {
this.getCardToken(number, month, year, cvc);
}
getCardToken(number, month, year, cvc) {
var dataObj = {"number": number, "exp_month": month, "exp_year": year, "cvc": cvc};
Stripe.card.createToken(dataObj,
(status, response) => {
this._zone.run(() => {
if (status === 200) {
this.cardToken = response;
console.log("the card token: ", this.cardToken);
}
else {
console.log("error in getting card data: ", response.error)
}
});
}
);
}
HTML
<form role="form" id="payment-form">
<div id="card-element">
<!-- a Stripe Element will be inserted here. -->
</div>
</form>
集成当我的部件载荷我得到这个错误:
The selector you specified (#card-element) applies to no DOM elements that are currently on the page. Make sure the element exists on the page before calling mount().
如何访问angular 2中的dom元素以正常使用Stripe?
此外,我在我的角应用程序上使用服务器端渲染,如果这影响角度在客户端上的作用方式。
嗨,谢谢。正如你所建议的那样,我设法弄清了它与AfterViewInit的关系。这解决了我收到的错误信息的问题,虽然它没有完全解决我的问题,这就是为什么我还没有提供工作解决方案。我相信我用我的ssr-setup阻止了条纹初始化。我目前无法访问我的代码来检查我的后续问题,但如果您确定您的解决方案一般能够正常工作,我会很乐意接受您的答案! –