JavaScript — счетчик символов для ввода формы — не считая

У любого есть понимание того, почему в этом коде не отображаются оставленные символы, а отображается только максимальное количество символов. Я прошел через это несколько раз, и я не могу найти ошибку.

HTML

<form class="comment" method="post" action="postComment.php">
<input type="text" placeholder="Name" name="Cname" onKeyUp="charLeft(this.value,30,'n')"><br/><span id="nCharLeft"></span><br/>
<input type="text" placeholder="Email" name="Cemail" onKeyUp="charLeft(this.value,50,'e')"><br/><span id="eCharLeft"></span><br/>
<textarea rows="4" placeholder="Please leave a comment." name="Ccomment" onKeyUp="charLeft(this.value,300,'c')"></textarea><br/><span id="cCharLeft"></span><br>
<input type="submit" value="Post Comment"><br/>
</form>

JavaScript

function charLeft(val,len,indi) {
var output = indi + "CharLeft";
if (val.length==0) {
return;
}
var xmlhttp=new XMLHttpRequest();
xmlhttp.onreadystatechange=function() {
if (xmlhttp.readyState==4 && xmlhttp.status==200) {
document.getElementById(output).innerHTML=xmlhttp.responseText;
}
}
xmlhttp.open("GET","charLeft.php?q="+val+"&m="+len,true);
xmlhttp.send();
}

PHP (charLeft.php)

<?php
$v = $_REQUEST['v'];
$m = $_REQUEST['m'];
$len = strlen($v);
$charleft = $m - $len;

echo $charleft==="1" ? "$charleft character left." : "$charleft characters left.";
?>

0

Решение

При вызове AJAX вы отправляете значение в q, но обращаетесь к нему как
$ v = $ _REQUEST [‘v’];

Таким образом, либо изменить в вызове AJAX как
xmlhttp.open ( «GET», «charLeft.php? v =» + вал +»&м = «+ Len, правда);

или изменить в PHP как
$ v = $ _REQUEST [‘q’];

1

Другие решения

Вы отправили «charLeft.php? Q =» + val + «&m = «+ len, но получить значение можно по $ v = $ _REQUEST [‘v’];

Попробуй с

$v = $_REQUEST['q'];
0