javascript的search()函数行为不正常

时间:2013-08-21 14:46:39

标签: javascript javascript-events javascript-framework

不知道为什么search()函数为SPECIAL CHARACTER的任何输入返回0,我想找到第一次出现特殊字符的位置。当我正在努力研究search()方法的值时,它工作正常,但是当我从文本框中获取值时,它无法正常工作。

以下是我的HTML代码:

<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1">

<script type="text/javascript" src="jquery-1.6.4.min.js"></script>
<script type="text/javascript" src="test.js"></script>

</head>
<body>

    <input type="text" id="txt" onkeyup="return checkLength();"/>
    <input type="button" id="btn" value="Verify" onclick="getValue()"/>


</body>
</html>

以下是我已经实现了javascript的search()使用的脚本,但不知道为什么我为任何输入获得0值。其实我想找到第一个特殊性格出现的位置。

$(document).ready(function() {

    $('#btn').attr('disabled',true);

    $("#txt").bind({
        paste : function(){
            $('#btn').attr('disabled',false);
            checkLength();
        },
        cut : function(){
            checkLength();
        }
    });
});

function checkLength(){

    var txtLength = $("#txt").val().length;
    var banTxt = document.getElementById("txt").value;

    if (txtLength != 0) {

        if(isAlphaNumeric(document.getElementById("txt").value)) {
            $('#btn').attr('disabled',false);
        } else {


            var str=banTxt;
                          //Here I am using search() to find position of Special Character.
            var n=banTxt.search(/[^a-zA-Z ]/g);
            alert("position of special char is: " + n);


            var preTxt = banTxt.substring(0,(txtLength - 1));
            var preTxtLength = preTxt.length;
            alert("Special characters are not allowed!");
            if(preTxtLength == 0){
                $('#btn').attr('disabled',true);
                document.getElementById("txt").value = "";
            }else if(preTxtLength != 0){
                document.getElementById("txt").value = preTxt;
                $('#btn').attr('disabled',false);
            }
        }
    } else {
        $('#btn').attr('disabled',true);
    }
}

function isAlphaNumeric(inputString) {
    return inputString.match(/^[0-9A-Za-z]+$/);
}

function getValue(){
    var txtValue = document.getElementById("txt").value;
    alert("Value submitted is: " + txtValue);
}

2 个答案:

答案 0 :(得分:0)

var n=banTxt.search(/[^a-zA-Z ]/g);
     

我尝试使用123#4 $ 5,12#4等特殊字符的字符串,因为特殊字符的位置是:0

这正是你的正则表达式所匹配的:没有字母字符而且没有空格 - 包括数字。相反,您的isAlphaNumeric函数与/^[0-9A-Za-z]+$/匹配 - 您可能希望将它们彼此对齐。

答案 1 :(得分:0)

实际上我使用了以下行var n = banTxt.search(/ [^ a-zA-Z] / g);获取特殊字符的位置,同时请注意我已经使用了onkeyup事件,所以如果我复制粘贴代码,即首先 ctrl 然后 v ctrl + v 然后 ctrl 本身就是keyup事件我认为这可能是我获得0作为特殊字符的位置的原因,因为在按下 ctrl 没有粘贴任何文本但触发了onkeyup事件。

我正在寻找它的解决方案。