我想用Numeral.js实时格式化输入框。
我试过这样的方法。
$('#exchangeInputFirst').keyup(function () {
//eur formatting
numeral.language('sk');
$('#exchangeInputFirst').val(numeral($('#exchangeInputFirst').val()).format('0,0.00$');
//to HUF format $('#exchangeInputSecond').val($('#exchangeInputFirst').val()*$('#first').html());
numeral.language('hu');
var string = numeral($('#exchangeInputSecond').val()).format('0,0.00$');
$('#exchangeInputSecond').val(string);
});第二个函数工作得很好(以HUF格式),但第一个功能不是。
发布于 2016-11-20 16:59:54
我想你漏掉了数字语言文件:
<script src="//cdnjs.cloudflare.com/ajax/libs/numeral.js/1.5.3/languages.min.js"></script>除非我不包括语言js文件,否则我无法再现您的情况。试试你的例子,点击第一个输入框中的一个键:
var a = false;
$('#exchangeInputFirst, #exchangeInputSecond').click(function () {
$(this).caret(0);
});
$('#exchangeInputFirst, #exchangeInputSecond').keyup(function(){
if(a == false){
$(this).val('');
a = true
} else {
numeral.language($(this).data('language'));
$(this).val(numeral($(this).val()).format('0,0.00$'));
$(this).caret(0);
}
});<script src="http://cdnjs.cloudflare.com/ajax/libs/jquery/2.1.4/jquery.js"></script>
<script src="//cdnjs.cloudflare.com/ajax/libs/numeral.js/1.5.3/numeral.min.js"></script>
<script src="//cdnjs.cloudflare.com/ajax/libs/numeral.js/1.5.3/languages.min.js"></script>
<script src="http://zikro.gr/dbg/html/jquery.caret/dist/jquery.caret-1.5.2.min.js"></script>
<input type="text" data-language="sk" id="exchangeInputFirst">
<input type="text" data-language="hu" id="exchangeInputSecond">
更新
光标的位置也有问题。您可以通过使用此jQuery插件acdvorak/jquery.符号来将插入符号位置设置为每次键入字符时输入的乞讨位置来解决这一问题:
$(this).val(numeral($(this).val()).format('0,0.00$'));
$(this).caret(0);此外,我还在输入的数据(如data-language="sk" )中包含了该语言,现在您可以在keyup事件中直接读取它,如下所示:
numeral.language($(this).data('language'));看我更新的片段。现在,它应该可以按照您的要求工作。
https://stackoverflow.com/questions/40703891
复制相似问题