怎么在Vue中使用Components实现一个数字键盘?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。
首先监听所有的input,有input聚焦时调起数字键盘,通过getBoundingClientRect判断input位置让数字键盘在input附近,失去焦点后则隐藏数字键盘
let inputElement = document.getElementsByTagName("input");
[...inputElement].forEach(ipele => {
ipele.addEventListener("focus", function(e) {
$this.inputTarget = e.target;
let scrollTop =
window.pageYOffset ||
document.documentElement.scrollTop ||
document.body.scrollTop;
let scrollLeft =
window.pageXOffset ||
document.documentElement.scrollLeft ||
document.body.scrollLeft;
$this.NumberkeyBoardStyle =
"top:" +
(e.target.getBoundingClientRect().top +
scrollTop +
e.target.offsetHeight) +
"px;left:" +
(e.target.getBoundingClientRect().left +
scrollLeft +
e.target.offsetWidth) +
"px";
});
ipele.addEventListener("blur", function(e) {
$this.inputTarget = null;
$this.NumberkeyBoardStyle = "display:none";
});
});
点击小键盘时阻止默认事件,阻止input失去焦点。
BoardNumberKeyDown(e) {
if (e && e.preventDefault) {
e.preventDefault();
} else {
window.event.returnValue = false;
return false;
}
},
点击小键盘时,根据事件委托,得出点击的数字,然后根据selectionStart,selectionEnd获取input中的焦点,将小键盘中的数字插入焦点处,最后焦点右移一位。
let inputTarget = this.inputTarget;
let Pointstart = inputTarget.selectionStart;
let PointEnd = inputTarget.selectionEnd;
let wordLength = inputTarget.value.length;
if (e.target.className == "numberTD" && e.target.innerText != "←") {
inputTarget.value =
inputTarget.value.slice(0, Pointstart) +
e.target.innerText +
inputTarget.value.slice(PointEnd, wordLength);
//一个小数点和开头不能有小数点
inputTarget.value = inputTarget.value.replace(/^\./g, "");
inputTarget.value = inputTarget.value
.replace(".", "$#$")
.replace(/\./g, "")
.replace("$#$", ".");
inputTarget.selectionStart = Pointstart + 1;
inputTarget.selectionEnd = Pointstart + 1;
//让光标显示在input可视区域
inputTarget.blur();
inputTarget.focus();
点击删除键时,删除光标处数字,最后光标右移。
if (e.target.className == "numberTD" &&
e.target.innerText == "←" &&
//PointEnd==0时会复制整个input的value
PointEnd != 0
) {
inputTarget.value =
inputTarget.value.slice(0, Pointstart - 1) +
inputTarget.value.slice(PointEnd, wordLength);
inputTarget.selectionStart = Pointstart - 1;
inputTarget.selectionEnd = Pointstart - 1;
//让光标显示在input可视区域
inputTarget.blur();
inputTarget.focus();
}
关于怎么在Vue中使用Components实现一个数字键盘问题的解答就分享到这里了,希望以上内容可以对大家有一定的帮助,如果你还有很多疑惑没有解开,可以关注亿速云行业资讯频道了解更多相关知识。
亿速云「云服务器」,即开即用、新一代英特尔至强铂金CPU、三副本存储NVMe SSD云盘,价格低至29元/月。点击查看>>
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。