老师这样写可以嘛
1 | <!DOCTYPE html>< br >< html lang = "en" >< br >< br >< head >< br > < meta charset = "UTF-8" >< br > < meta http-equiv = "X-UA-Compatible" content = "IE=edge" >< br > < meta name = "viewport" content = "width=device-width, initial-scale=1.0" >< br > < title >Document</ title >< br ></ head >< br >< br >< body >< br > < p >字数限制在30字内,< span >您还可以输入< b >30</ b > 字</ span ></ p >< br > < textarea cols = "50" rows = "7" id = "text" ></ textarea >< br > < script type = "text/javascript" >< br > var text_t = document.getElementById('text');< br > var b = document.getElementsByTagName('b')[0];< br > var span = document.getElementsByTagName('span')[0];< br > var sum = 30;< br > text_t.onkeypress = function () {< br > sum--;< br > if(sum<=30 && sum >=0){< br > b.innerHTML = sum;< br > }else{< br > span.innerHTML = '您已经超出了'+(-sum)+'字';< br >< br > }< br > }< br >< br >< br > </ script >< br ></ body >< br >< br ></ html >< br > |
18
收起
正在回答
1回答
同学你好,当内容回删的时候内容长度不会改变
这是因为超出的时候没有了b标签,所以回删的时候无法在b标签中添加内容。
建议:
1、使用onkeyup事件,文字显示的时候是在onkeyup阶段,才能正确获取长度
2、只对sum进行操作不对,需要让sum和内容长度去计算
3、在没有30字的时候也改变span内容
参考修改:
祝学习愉快!
恭喜解决一个难题,获得1积分~
来为老师/同学的回答评分吧