文字实时比对应该用什么思路? - V2EX
V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
Eyon
V2EX    问与答

文字实时比对应该用什么思路?

  •  
  •   Eyon 2020-11-22 16:02:28 +08:00 1447 次点击
    这是一个创建于 1789 天前的主题,其中的信息可能已经有所发展或是发生改变。
    亲戚要学电脑,我喊她先学打字。于是就有个练打字小程序的需求,她网购了一个键盘就可以连手机练习了。

    如下图,目前我的方案是实时读取输入文字的长度,和原文所对应长度的切片做比对,如果相等就把原文的切片放入一个 class=red 的 text 标签里。

    但是有个问题,这样要求所有的输入文字都必须正确,如果其中有一个文字不正确都不会变红(因为不相等),请赐教应该用什么思路?

    9 条回复    2020-11-24 09:23:35 +08:00
    LxExExl
        1
    LxExExl  
       2020-11-22 16:31:25 +08:00 via iPhone
    这个没有现成的 app 吗?

    小时候 pc 上有金山打字通

    我还记得第一句话是 when you 开头的...
    jdhao
        2
    jdhao  
       2020-11-22 16:36:11 +08:00 via Android
    直接用电脑打字不就行了,还弄什么手机啊。。楼上说的金山打字通练字多好
    Eyon
        3
    Eyon  
    OP
       2020-11-22 16:38:28 +08:00
    楼上两位都都跑题了。。。
    jdhao
        4
    jdhao  
       2020-11-22 16:39:46 +08:00 via Android
    @Eyon 要打字就解决打字的问题,再搞个小程序,岂不是多此一举。当然你说你有兴趣实现这样的小程序,那肯定没问题啊。
    zxCoder
        5
    zxCoder  
       2020-11-23 10:37:04 +08:00
    意思是不买电脑 先用手机和键盘练习打字?
    lyy16384
        6
    lyy16384  
       2020-11-23 15:24:33 +08:00
    这就是个 diff 功能啊
    不过我觉得逐字对比就够用了,缺点是错位会全报错
    DL9412
        7
    DL9412  
       2020-11-23 15:36:51 +08:00
    切分开来逐字比对?随手写了个,如果不多字漏字是好使的,如果多字漏字的话就不好说了。
    猜个思路,不匹配时向后搜索匹配字符,到标点或句尾则放弃,下一个字符从上个匹配成功的位置开始搜索

    ```
    <style>
    .red{
    color: red;
    }
    </style>
    <div id="textblock"></div>
    <textarea id="inputtext"></textarea>
    <script>
    let text = `但是有个问题,这样要求所有的输入文字都必须正确,如果其中有一个文字不正确都不会变红(因为不相等),请赐教应该用什么思路`
    let inp = document.getElementById('inputtext')
    let textblock = document.getElementById('textblock')

    render()

    inp.Oninput= e => render()

    function render(){
    let inputarr = inp.value.split('')
    let arr = text.split('').map((v,i) => v==inputarr[i]?`<span class="red">${v}</span>`:v)
    textblock.innerHTML = arr.join('')
    }
    </script>
    ```
    sevenyangdx
        8
    sevenyangdx  
       2020-11-23 15:50:38 +08:00
    要学电脑,为啥不买台电脑正儿八经的学,要用手机学拼音的话,直接全键盘输入法不就行了么。难道用键盘是带着出门用的。
    Eyon
        9
    Eyon  
    OP
       2020-11-24 09:23:35 +08:00
    @DL9412 非常感谢。

    一直没有想用逐字比对的方案,就觉得一篇文章下来全部拆分文字和标点,运算要求比较高了。当然我即使逐字比对也写不出来你这么漂亮的代码哈,压根儿没学过 js 。map 真是个好东西。
    关于     帮助文档     自助推广系统     博客     API     FAQ     Solana     2415 人在线   最高记录 6679       Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 35ms UTC 15:47 PVG 23:47 LAX 08:47 JFK 11:47
    Do have faith in what you're doing.
    ubao msn snddm index pchome yahoo rakuten mypaper meadowduck bidyahoo youbao zxmzxm asda bnvcg cvbfg dfscv mmhjk xxddc yybgb zznbn ccubao uaitu acv GXCV ET GDG YH FG BCVB FJFH CBRE CBC GDG ET54 WRWR RWER WREW WRWER RWER SDG EW SF DSFSF fbbs ubao fhd dfg ewr dg df ewwr ewwr et ruyut utut dfg fgd gdfgt etg dfgt dfgd ert4 gd fgg wr 235 wer3 we vsdf sdf gdf ert xcv sdf rwer hfd dfg cvb rwf afb dfh jgh bmn lgh rty gfds cxv xcv xcs vdas fdf fgd cv sdf tert sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf shasha9178 shasha9178 shasha9178 shasha9178 shasha9178 liflif2 liflif2 liflif2 liflif2 liflif2 liblib3 liblib3 liblib3 liblib3 liblib3 zhazha444 zhazha444 zhazha444 zhazha444 zhazha444 dende5 dende denden denden2 denden21 fenfen9 fenf619 fen619 fenfe9 fe619 sdf sdf sdf sdf sdf zhazh90 zhazh0 zhaa50 zha90 zh590 zho zhoz zhozh zhozho zhozho2 lislis lls95 lili95 lils5 liss9 sdf0ty987 sdft876 sdft9876 sdf09876 sd0t9876 sdf0ty98 sdf0976 sdf0ty986 sdf0ty96 sdf0t76 sdf0876 df0ty98 sf0t876 sd0ty76 sdy76 sdf76 sdf0t76 sdf0ty9 sdf0ty98 sdf0ty987 sdf0ty98 sdf6676 sdf876 sd876 sd876 sdf6 sdf6 sdf9876 sdf0t sdf06 sdf0ty9776 sdf0ty9776 sdf0ty76 sdf8876 sdf0t sd6 sdf06 s688876 sd688 sdf86