Я хочу импортировать кнопку Razorpay в React, чтобы принимать платежи. Но это не отображается в моем компоненте.
Код кнопки Razorpay: -
<form>
<script src = "https://checkout.razorpay.com/v1/payment-button.js" data-payment_button_id = "pl_G8bIDza4zHQRfm">
</script>
</form>
Я пытался это сделать, но не смог: -
import React, { useEffect } from 'react';
import './Homepage.css';
const Homepage = () => {
useEffect(() => {
const script = document.createElement('script');
script.src = 'https://checkout.razorpay.com/v1/payment-button.js';
script['data-payment_button_id'] = 'pl_G8bIDza4zHQRfm';
script.async = true;
const element = document.querySelector('#home form');
element.appendChild(script);
return () => {
element.removeChild(script);
};
}, []);
return (
<section id='home'>
<form></form>
</section>
);
};
export default Homepage;
Документы см. по адресу: - https://razorpay.com/docs/payment-button/donations/#step-3-embed-payment-button-code-in-website
Используйте функцию setAttribute --> script.setAttribute('data-payment_button_id', 'pl_G8bIDza4zHQRfm');





Если вы хотите установить data-attribute, вы можете использовать Element.setAttribute():
script.setAttribute('data-payment_button_id', 'pl_G8bIDza4zHQRfm');
Я рекомендую вам использовать хук useRef и получить ссылку на форму:
const form = useRef(null);
useEffect(() => {
const script = document.createElement('script');
script.src = 'https://checkout.razorpay.com/v1/payment-button.js';
script.setAttribute('data-payment_button_id', 'pl_G8bIDza4zHQRfm');
script.async = true;
form.current.appendChild(script);
return () => {
form.current.removeChild(script);
};
}, []);
return (
<section id='home'>
<form ref = {form}></form>
</section>
);
должно быть .querySelector('#home'), а не .querySelector('#home form'), и лучше добавить скрипт в заголовки