老师这样写可以嘛

老师这样写可以嘛

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>


正在回答

登陆购买课程后可参与讨论,去登陆

1回答

同学你好,当内容回删的时候内容长度不会改变

http://img1.sycdn.imooc.com//climg/60642d50093f050b03810158.jpg

这是因为超出的时候没有了b标签,所以回删的时候无法在b标签中添加内容。

建议:

1、使用onkeyup事件,文字显示的时候是在onkeyup阶段,才能正确获取长度

2、只对sum进行操作不对,需要让sum和内容长度去计算

3、在没有30字的时候也改变span内容

参考修改:

http://img1.sycdn.imooc.com//climg/606d8e32093e14ff10340438.jpg

祝学习愉快!

  • 咸鱼王派大星 提问者 #1

    老师那这个text_t.value.lenth是可以直接拿到已经输入内容的长度嘛,

    2021-04-01 09:19:15
  • 你好,是的哦,text_t.value获取已输入内容,length属性获取长度。

    2021-04-01 09:58:47
问题已解决,确定采纳
还有疑问,暂不采纳

恭喜解决一个难题,获得1积分~

来为老师/同学的回答评分吧

0 星
请稍等 ...
微信客服

购课补贴
联系客服咨询优惠详情

帮助反馈 APP下载

慕课网APP
您的移动学习伙伴

公众号

扫描二维码
关注慕课网微信公众号

在线咨询

领取优惠

免费试听

领取大纲

扫描二维码,添加
你的专属老师
插入代码