| 123456789101112131415161718192021222324252627282930313233343536373839404142434445 |
- /**
- *
- */
- function showdetail(event){
- var valuetext = event.currentTarget.childNodes[0].childNodes[0].value;
- var values = new Array(); //定义一数组
- values = valuetext.split(","); //字符分割
- mui.alert('<table style="width:100%;"> <tr> <td class="detailTableName" >合同应收:</td> <td class="detailTableValue" >'+formatNumber(values[2])+'元 </td> </tr> '
- +'<tr> <td class="detailTableName" style="width:40%;">已收款:</td> <td class="detailTableValue" >'+formatNumber(values[3])+'元</td></tr>'
- +'<tr> <td class="detailTableName" style="width:40%;">未收款:</td> <td class="detailTableValue" >'+formatNumber(values[4])+'元</td></tr>'
- +'<tr> <td class="detailTableName" style="width:40%;">已开票:</td> <td class="detailTableValue" >'+formatNumber(values[5])+'元</td></tr>'
- +'<tr> <td class="detailTableName" style="width:40%;">未开票:</td> <td class="detailTableValue" >'+formatNumber(values[6])+'元</td></tr>'
- +'</table>',values[0]
- );
- }
- /**
- * 将数值格式化成金额形式
- *
- * @param num 数值(Number或者String)
- * @param precision 精度,默认不变
- * @param separator 分隔符,默认为逗号
- * @return 金额格式的字符串,如'1,234,567',默认返回NaN
- * @type String
- */
- function formatNumber(num, precision, separator) {
- var parts;
- // 判断是否为数字
- if (!isNaN(parseFloat(num)) && isFinite(num)) {
- // 把类似 .5, 5. 之类的数据转化成0.5, 5, 为数据精度处理做准, 至于为什么
- // 不在判断中直接写 if (!isNaN(num = parseFloat(num)) && isFinite(num))
- // 是因为parseFloat有一个奇怪的精度问题, 比如 parseFloat(12312312.1234567119)
- // 的值变成了 12312312.123456713
- num = Number(num);
- // 处理小数点位数
- num = (typeof precision !== 'undefined' ? (Math.round(num * Math.pow(10,precision)) / Math.pow(10,precision)).toFixed(precision) : num).toString();
- // 分离数字的小数部分和整数部分
- parts = num.split('.');
- // 整数部分加[separator]分隔, 借用一个著名的正则表达式
- parts[0] = parts[0].toString().replace(/(\d)(?=(\d{3})+(?!\d))/g, '$1' + (separator || ','));
-
- return parts.join('.');
- }
- return NaN;
- }
|