gpt4 book ai didi

javascript - 具有数字格式的 Jquery keydown() 在 android webview 上无法正常工作

转载 作者:行者123 更新时间:2023-11-28 03:38:47 25 4
gpt4 key购买 nike

我在 android 浏览器/webview 上遇到了一个奇怪的行为。我正在测试一个将自动格式化为电话号码格式“(xxx) xxx-xxxx”的输入。但是后来发生的事情是当我点击或按下机器人键盘上的任何数字时,第一个输入是这样的“(x”但是然后光标在“(”和“x”之间。有没有办法把光标放在后面“x”值?

我在 iPhone 和 Windows 网络浏览器上对此进行了测试,它运行良好。如果我的 jquery 或 javascripts 有错误,请告诉我。

谢谢

HTML 代码:

<html>
<head>
<title>Sample Phone Number Format</title>
<script type="text/javascript" src="http://code.jquery.com/jquery-1.8.2.min.js"></script>
</head>
<body>
<input type="text" id="phone" />

<script type="text/javascript">
$('#phone').on('keydown', function (event) {

objval = $(this).val();
if (event.keyCode == 46 || event.keyCode == 8) {} else {
if (!((event.keyCode > 47 && event.keyCode < 58) || (event.keyCode > 95 && event.keyCode < 106) || (objval.length > 13))) {
event.preventDefault();
} else {
if (objval.length == 0) {
$(this).val(objval + '(');
alert(objval + '(');
} else if (objval.length == 4) {
$(this).val(objval + ') ');
alert(objval + ') ');
} else if (objval.length == 9) {
$(this).val(objval + '-');
alert(objval + '-');
} else if (objval.length >= 14) {
if (event.keyCode == 9) {
return;
} else {
event.preventDefault();
}
}
}
}
});

$('#phone').on('keydown', function (event) {

var objVal = $(this).val();
if(objVal.length < 14)
{
validateCallerForm(objVal + String.fromCharCode((96 <= event.keyCode && event.keyCode <= 105)? event.keyCode-48 : event.keyCode));
}
});

//Validates proper phone format, true if valid phone number, false otherwise
function isValidPhoneNumber(elementValue) {
var numberPattern = /^\(?(\d{3})\)?[- ]?(\d{3})[- ]?(\d{4})$/;
return numberPattern.test(elementValue);
}

//validates entire caller form, also updates css classes for proper response
function validateCallerForm(PhoneNumber) {

if (isValidPhoneNumber(PhoneNumber)) {
alert("true");
} else {
alert("false");
}

}
</script>
</body>
</html>

给予 +50 赏金给谁会正确回答这个问题

最佳答案

你必须首先像下面这样定义用于打字和复制粘贴的监听器(不是必需的):

$("#phone").keyup( function() {
maskLine(this);
});
$("#phone").change( function() {
maskLine(this);
});

然后,为了管理光标位置,您必须缓存以前的电话号码,然后,您可以比较差异并在需要时更新光标位置。所以声明,你必须像这样声明一个全局数组:

var _cacheElementValues = new Array();

最后,您可以检查下面的函数,它将您的掩码应用于电话号码字段并管理光标位置:

function maskLine( element ) {
element = $(element);
var maskedLine = '';
var line = element.attr('value');

// check the cache of the input and abord if no change since last treatment
if (_cacheElementValues[element.attr('id')] != undefined && _cacheElementValues[element.attr('id')] == line) {
return;
}
line = line.replace(/\D/g, ''); // remove all characters != digits
line = line.substring(0, 10);
if (line != '') {
// apply mask
if (line.length <= 2 ) {
maskedLine = "(" + line;
} else if (line.length < 6) {
maskedLine = line.replace(/^([0-9]{3})([0-9]{0,3})/g, '($1) $2');
} else {
// mask : '(XXX) XXX-XXXX'
maskedLine = line.replace(/^([0-9]{3})([0-9]{3})([0-9]{0,4})/g, '($1) $2-$3');
}
}

// define cursor position at the end of the input by default
var pos = maskedLine.length;

// Change cursor placement if necessary
if (typeof element[0].selectionStart != 'undefined') {
var start = element[0].selectionStart;
var end = element[0].selectionEnd;
var insText = element[0].value.substring(start, end);

// get current cursor placement
if (insText.length == 0) {
pos = start;
} else {
pos = start + insText.length;
}

// find how many digits typing since last mask application
var previousLength = 0;
if (_cacheElementValues[element.attr('id')] != undefined) {
previousLength = _cacheElementValues[element.attr('id')].replace(/\s/g, '').length;
}
var diff = maskedLine.replace(/\s/g, '').length - previousLength;

// if sum of new typing digit is > 0 : we change cursor placement
if (diff > 0) {
pos += (diff - 1) + Math.round((diff-1)/3);
if (pos%6 == 0 && maskedLine.length >= pos+1) pos++;
}
}

// update input data & cache
element.val(maskedLine);
_cacheElementValues[element.attr('id')] = maskedLine;

// update cursor placement
element[0].selectionStart = element[0].selectionEnd = pos;
}

你可以在 jsFiddle 上找到这个例子:http://jsfiddle.net/UE9LB/5/

我希望这个小小的解释可以解决您的问题;)享受吧!

ps: 我为我糟糕的英语道歉:s

关于javascript - 具有数字格式的 Jquery keydown() 在 android webview 上无法正常工作,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12541028/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com