Я хочу передать переменную из java-скрипта в html-ссылку.
<li hidden><a id = "url_call" href='/paytm/response/?response = {{response}}'
value = "{{response}}">{{response}}</a></li>
<script src = "https://checkout.razorpay.com/v1/checkout.js"></script>
<script>
var options = {
"key": "rzp_test_rpDFJlAD0LDl8Y",
"subscription_id": "{{ sub_id }}",
"name": "My Billing Label",
"description": "Auth txn for sub_8seKGNhVEOwnjj",
"handler": function (response){
// alert(response.razorpay_payment_id);
document.getElementById("url_call").click(response);
}
};
var rzp1 = new Razorpay(options);
document.getElementById('rzp-button').onclick = function(e){
rzp1.open();
}
</script>
В приведенном выше коде я хочу получить переменный ответ от
"handler": function (response){
// alert(response.razorpay_payment_id);
document.getElementById("url_call").click(response);
}
к
<li hidden><a id = "url_call" href='/paytm/response/?response = {{response}}'
value = "{{response}}">{{response}}</a></li>
Я думаю, что то, как я поступаю, неправильно. Может ли кто-нибудь помочь мне с этим? Спасибо.



![Безумие обратных вызовов в javascript [JS]](https://i.imgur.com/WsjO6zJb.png)


Вы можете установить значение атрибута href следующим образом:
document.getElementById('url_call').setAttribute('href', '/paytm/response/?response='+response);
Note
<atag does not havevalueattribute. Click here to learn about valid attributes
Если вы настаиваете на изменении значения атрибута value, сделайте следующее:
document.getElementById('url_call').setAttribute('value', response);
Чтобы изменить текст тега <a, используйте:
document.getElementById('url_call').innerText = response;
Если вы хотите все вышеперечисленные изменения, ваш окончательный код будет выглядеть так:
"handler": function (response){
var el = document.getElementById('url_call');
el.setAttribute('href', '/paytm/response/?response='+response);
el.setAttribute('value', response);
el.innerText = response;
}
Тот факт, что вы используете django для серверной части, совершенно не имеет значения - к моменту выполнения кода js он будет работать точно так же, если бы html был сгенерирован с помощью PHP, Java или Ruby или был просто статическим html... (тег удален)