javascript - 如何在input框内实时加上某些文字?
ringa_lee
ringa_lee 2017-04-11 10:58:08
[JavaScript讨论组]

需求:在某个输入框中,当用户输入后,实时在光标后面加上某些文字

图中的(万元)是用placeholder做的,现在想要当用户输入某个数字,实时在数字后面添加"万元"这两个字,试过如下代码:

$('#amount').on('keyup', function(e) {
  if(e.keycode === num){
  $(this).val($(this).val()+'万元');
  }else{
  $(this).val('');
  }
});

但效果有点搞笑……关键是这么一弄光标就会跳到最后面去,用户体验很不好。

有什么好的解决方案吗?

ringa_lee
ringa_lee

ringa_lee

全部回复(2)
迷茫

我写过一个类似的react组件,react-format-number,但真心的,实现有点麻烦。强烈不推荐,最好商量下,把需求改成,“单位写在input后面,不要直接加在里面了”

巴扎黑

1、focus在空input上,添加“万元”,并将光标移至最前面;
2、focus在非空input上,若存在“万元”单位,则将光标移至单位前;否则添加“万元”单位
3、操作只在每次focus时发生,输入内容时没有额外开销
在线的例子

$('#money').on('focus', function() {
  var val = $(this).val(),
    len = val.length;
  if (val.indexOf('万元') !== -1) {
    changeCursorPos('money', len - 2);
  } else {
    $(this).val(val + '万元');
    changeCursorPos('money', len);
  }
})

function changeCursorPos(inputId, pos) {// 更改光标位置
  var inpObj = document.getElementById(inputId);
  if (window.getSelection) {
    inpObj.setSelectionRange(pos, pos);
  } else {
    var range = document.selection.createRange();
    var textRange = inpObj.createTextRange();
    textRange.moveStart('character', pos);
    textRange.collapse();
    textRange.select();
  }
}
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号