edittext实现显示千分位格式
在edittext中你在输入1123456789过程中自动显示为1,123,456,789这种千分位格式的。那么我们该怎么做呢? 查阅Android edittext api发现它有这样一个方法addTextChangedListener,这个方法就是用来监听用户在输入过程中的事件监听,它会重写这几个方法:
- editText.addTextChangedListener(new TextWatcher() {
- @Override
- public void onTextChanged(CharSequence s, int start, int before, int count) {
- // TODO Auto-generated method stub
- }
- @Override
- public void beforeTextChanged(CharSequence s, int start, int count,
- int after) {
- // TODO Auto-generated method stub
- }
- @Override
- public void afterTextChanged(Editable s) {
- // TODO Auto-generated method stub
- }
- });
不难发现。从字面意思理解我们需实现这个功能就需要在afterTextChanged()这个方法中写我们的逻辑代码,代码如下:
- @Override
- ublic void afterTextChanged(Editable s) {
- // TODO Auto-generated method stub
- if (!StringUtils.touzi_ed_values22.equals(editText.getText().toString().trim().replaceAll(",",""))) {
- editText.setText(StringUtils.addComma(editText.getText().toString().trim().replaceAll(",",""),editText));
- editText.setSelection(StringUtils.addComma(editText.getText().toString().trim().replaceAll(",",""),editText).length());
- }
StringUtils.addComma这个方法我是写成了一个帮助类,方便重复调佣
- public static String touzi_ed_values22 = "";
- /**
- * 在数字型字符串千分位加逗号
- * @param str
- * @param edtext
- * @return sb.toString()
- */
- public static String addComma(String str,EditText edtext){
- touzi_ed_values22 = edtext.getText().toString().trim().replaceAll(",","");
- boolean neg = false;
- if (str.startsWith("-")){ //处理负数
- str = str.substring(1);
- neg = true;
- }
- String tail = null;
- if (str.indexOf('.') != -1){ //处理小数点
- tail = str.substring(str.indexOf('.'));
- str = str.substring(0, str.indexOf('.'));
- }
- StringBuilder sb = new StringBuilder(str);
- sb.reverse();
- for (int i = 3; i < sb.length(); i += 4){
- sb.insert(i, ',');
- }
- sb.reverse();
- if (neg){
- sb.insert(0, '-');
- }
- if (tail != null){
- sb.append(tail);
- }
- return sb.toString();
- }
代
码中,我定义了一个静态的变量touzi_ed_values22是为了方便与activity中的
StringUtils.touzi_ed_values22.equals(editText.getText().toString().trim().replaceAll(",",""))
做判断,判断在输入过程中是否不同,也就是数值改变了,如果改变了,那么就会调用addComma()方法返回新的字符串数值赋值给edittext。
其中addComma中的touzi_ed_values22 = edtext.getText().toString().trim().replaceAll(",","");非常关键。它是为了不断获取当前数值与返回后的数值进行比较,如果没有这句代码。你的app将再edittext输入时就会出现卡死现象,因为你的touzi_ed_values22是永远为空的。在作比较的时候会进入该方法,就会无限赋值无限判断。
现在就要使用啦!
请直接看代码
jewelry_money.addTextChangedListener(new TextWatcher() {
@Override
public void beforeTextChanged(CharSequence s, int start, int count, int after) {
}
@Override
public void onTextChanged(CharSequence s, int start, int before, int count) {
if (!ValueUtils.touzi_ed_values22.equals(jewelry_money.getText().toString().trim().replaceAll(",",""))) {
jewelry_money.setText(ValueUtils.addComma(jewelry_money.getText().toString().trim().replaceAll(",", ""), jewelry_money));
jewelry_money.setSelection(ValueUtils.addComma(jewelry_money.getText().toString().trim().replaceAll(",", ""), jewelry_money).length());
}
}
@Override
public void afterTextChanged(Editable s) {
}
});
最后在给大家一个小工具,有时候上传价格的数据时,不允许上传带逗号的,所以在上传之前要去掉逗号啦!
public static String getValue(String str){
String[] s = str.split(",");
String value = "";
for (int i=0;i<s.length;i++){
value += s[i];
}
return value;
}
调用这个方法就可以啦
到时在获取数据展示的时候又要加逗号,可以这样解决
HttpUtil.post(this, UrlConfig.JEWELRY_DETAIL, params, new HttpUtil.Ok() {
@Override
public void success(String str) {
JSONObject data = JSON.parseObject(str);
show_jewelry_name.setText(Helper.value(data.getString("sellerName"), "未知"));
show_jewelry_ID.setText(Helper.value(data.getString("sellerId"), "未知"));
show_jewelry_phone.setText(Helper.value(data.getString("sellerTel"), "未知"));
java.text.NumberFormat nf = java.text.NumberFormat.getInstance();
9 Double value=data.getDouble("price");
10 show_jewelry_money.setText(nf.format(value)+"元");
这样又有逗号了
哈哈,这才真正的解决了数字的千分位问题
edittext实现显示千分位格式的更多相关文章
- input框输入金额显示千分位
比如输入:1000000,则显示为1,000,000(或者是保留3位小数:1,000,000.000) 知识点: 1)JavaScript parseFloat() 函数: 定义:parseFloat ...
- js从千分位格式
从千分位格式化谈JS性能优化 http://heeroluo.net/article/detail/115 方法六 // 方法六 function toThousands(num) { ).toStr ...
- JavaScript加减计算方法和显示千分位
Math.formatFloat = function (f, digit) { var m = Math.pow(10, digit); return parseInt(f * m, 10) / m ...
- JS返回一个数据的千分位格式
/** * 价钱转换-从右往左每3位数字加一个逗号 * @param price 需要转换的价格 */ formatPrice(price){ var newPrice = price.split(' ...
- js数字格式化千分位格式
带小数点的 var a = 8462948.2453; console.log(a.toLocaleString()) //8,462,948.245 不带小数点的 num.toString().re ...
- sql为数字添加千分位(也就是钱的格式)
感觉这个东西在项目中用得挺多的,之前在前台页面是用正则来处理,现在由于是数据查询,所以直接在查出数据的时候将其转为指定的千分位格式,省的前台再处理,不讲原理,因为我也看不懂,不过会用就行了,在网上找了 ...
- C# 数字带逗号(千分位符、金钱千分位字符)
首先要明确带了逗号之后 数字就变成字符串了 ,不再是数字了. 昨天做项目的时候需要格式化数字变成带逗号的,本来打算自己写个方法的,后来时间太紧了,就打算从网上查个,查来查去都是要对字符串的位进行操作 ...
- C#数字千分位问题
1.C#中用最简单的方法把数字(不含小数)转换为千分位格式: 如1234567变成1,234,567 方法:1234567.ToString("###,###") 或 ...
- js jquery版本的 金额千分位转换函数(非正则,效率极高)
没想到js里面没有 金额千分位格式化的处理函数(例:1,234.01 这样的格式),网上搜了一圈,都是使用正则的方式处理的.正则的效率不敢恭维啊,又耗费资源速度又慢(虽然处理起来会直观一些). 因此专 ...
随机推荐
- Prefabs
[Prefabs] A Prefab is a type of asset -- a reusable GameObject stored in Project View. Prefabs can b ...
- GWT+CodeTemplate+TableCreate快速开发
刚进一家新公司,公司表示让我们几个新人写页面联系熟悉 怎么快速开发,进入正题: 1.根据设计规范设计页面excel 2.CodeTemplate根据excel生成属性类和对应方法(文本框,下拉框等等单 ...
- HTML结构标签介绍
HTML:超文本标记语言 介绍HTML基本标记 1:头部标记(head)----- 头部的内容不会再页面上显示 在头部元素中,一般需要包括标题<title>,基本信息(文档样式, ...
- unigui 导入导出数据
导入:首先要用TUniFileUpload将文件从客户端上传至服务端,然后完成导入. TUniFileUpload上传文件的演示代码: UniFileUpload1.Execute; UniFileU ...
- 我的Memcache学习笔记
一.编绎安装Memcached 二.Memcached基本命令 四.PHP扩展模块安装 五.设置session用memcache来存储 六.PHP使用Memcache的一致性哈希连接方式 七.Memc ...
- Linux内核完全注释之编程语言和环境(二)
c程序的编译和链接 使用gcc汇编器编译c语言程序时通常会经历四个阶段,即预处理阶段.编译阶段.汇编阶段.链接阶段,如下图. 例如: gcc -o hello hello.c 生成可执行文件hello ...
- Apache实现动态虚拟主机
经常在开发中为Apache web server添加虚拟主机 方便多个项目的 同时运营,但是每次增加新的项目时都得重新配置增加VirtualHost:虚拟主机 部分,时间久了VirtualHo ...
- win10的安装、win10启动盘制作
需要的材料 win10映像 U盘 UltraISO软件 1.下载对应的win10映像 有64位和32位可选(自己找地方下) 2.下载UltraISO软件 3.准备一只U盘,插入电脑 4.启动Ultra ...
- js正则表达式之解析——URL的正则表达式
首先,此片文章并不是直接告诉你,url的正则表达式是什么,以及怎么使用这个正则表达式去解析一个URL地址,相信这种问题在网络上已经能找到很多.本文的宗旨在于教你如何理解URL的正则表达式,以达到理解正 ...
- hadoop学习笔记之倒排索引
开发工具:eclipse 目标:对下面文档phone_numbers进行倒排索引: 13599999999 1008613899999999 12013944444444 13800138000137 ...