Comment changer la valeur de l'attribut href
d'une balise <a/>
via Javascript lors d'un clic sur un bouton?
<script type="text/javascript">
function f1()
{
document.getElementById("abc").href="xyz.php";
}
</script>
<a href="" id="abc">jhg</a>
<a href="" id="" onclick="f1()">jhhghj</a>
Sans avoir une href
, le clic rechargera la page en cours, vous avez donc besoin de quelque chose comme:
<a href="#" onclick="f1()">jhhghj</a>
Ou empêchez le parchemin comme ceci:
<a href="#" onclick="f1(); return false;">jhhghj</a>
Ou return false
dans votre fonction f1
et:
<a href="#" onclick="return f1();">jhhghj</a>
.... ou de manière discrète:
<a href="#" id="abc">jhg</a>
<a href="#" id="myLink">jhhghj</a>
<script type="text/javascript">
document.getElementById("myLink").onclick = function() {
document.getElementById("abc").href="xyz.php";
return false;
};
</script>
Exactement ce que Nick Carver a fait là-bas mais je pense que ce serait mieux si on utilisait la méthode DOM setAttribute.
<script type="text/javascript">
document.getElementById("myLink").onclick = function() {
var link = document.getElementById("abc");
link.setAttribute("href", "xyz.php");
return false;
}
</script>
C'est une ligne de code supplémentaire mais trouvez-le mieux en termes de structure.
supprimer l'attribut href
:
<a id="" onclick="f1()">jhhghj</a>
si les styles de liens sont importants, alors:
<a href="javascript:void(f1())">jhhghj</a>
<a href="#" id="a" onclick="ChangeHref()">1.Change 2.Go</a>
<script>
function ChangeHref(){
document.getElementById("a").setAttribute("onclick", "location.href='http://religiasatanista.ro'");
}
</script>
Voici mon point de vue là-dessus. J'avais besoin de créer une URL en collectant la valeur d'une zone de texte, lorsque l'utilisateur appuyait sur un bouton Soumettre.
<html>
<body>
Hi everyone
<p id="result"></p>
<textarea cols="40" id="SearchText" rows="2"></textarea>
<button onclick="myFunction()" type="button">Submit!</button>
<script>
function myFunction() {
var result = document.getElementById("SearchText").value;
document.getElementById("result").innerHTML = result;
document.getElementById("abc").href="http://arindam31.pythonanywhere.com/hello/" + result;
}
</script>
<a href="#" id="abc">abc</a>
</body>
<html>
Pour qu'un lien change dynamiquement en cliquant dessus:
<input type="text" id="emailOfBookCustomer" style="direction:RTL;"></input>
<a
onclick="this.href='<%= request.getContextPath() %>/Jahanpay/forwardTo.jsp?handle=<%= handle %>&Email=' + document.getElementById('emailOfBookCustomer').value;" href=''>
A dynamic link
</a>