javascript - js的函数执行问题

查看:82
本文介绍了javascript - js的函数执行问题的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

问 题

问题:当我第一次输入字符串a的时候,添加成功了,当我第二次还输入相同的字符串a的时候,居然没添加成功,求高手找找那个地方的bug,并给我指点出来错误的原因,多谢~~~
代码如下:

<!DOCTYPE html>
<html>

    <head>
        <meta charset="UTF-8">
        <title></title>
    </head>

    <body>
        <ul class="ct">
            <li>这里是</li>
            <li>我们</li>
            <li>地方</li>
        </ul>
        <input class="ipt-add-content" placeholder="添加内容" />
        <button id="btn-add-start">开头添加</button>
        <button id="btn-add-end">结尾添加</button>
        <script>
            var oint = document.getElementsByClassName("ipt-add-content")[0];
            var obtnst = document.getElementById("btn-add-start");
            var obtnen = document.getElementById("btn-add-end");
            var oul = document.getElementsByClassName("ct")[0];
            var os = /[^\s]/g;
            obtnst.onclick = function() {
                if(os.test(oint.value)) {
                    var neol=oul.children[0];
                    var oli=document.createElement("li");
                    oli.innerText=oint.value;
                    oul.insertBefore(oli,neol);
                    oint.value="";
                }
            }
            obtnen.onclick = function() {
                if(os.test(oint.value)) {
                    var oli1 = document.createElement("li");
                    oli1.innerText = oint.value;
                    oul.appendChild(oli1);
                    oint.value = "";
                }
            }
        </script>
    </body>

</html>

解决方案

问题在你的正则表达式上var os = /[^s]/g;,改成var os = /[^s]/;。带g的正则会记忆上次匹配的index,造成下次匹配的时候匹配不上了就。

这篇关于javascript - js的函数执行问题的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆