小写金额代码已有了,求其大写金额代码(也就是用零、壹、贰、参、肆、伍、陆、柒、捌、玖、拾、佰、仟、萬、亿、圆、整等):
<tr class="totalsum"><td>合计</td><td colspan=4></td><td colspan=2 align='right'><b id="totalsum">0</b>元td><td colspan=2></td></tr>网上找了很多,全部都无法用,加入后都只显示代码,不起作用。所以请高手帮个忙。

解决方案 »

  1.   

    这是一段网上找到的代码,但加入后仍不行。
    <script>
    function DX(n) {
        var strOutput = "";
        var strUnit = '千百拾亿千百拾万千百拾元角分';
        n += "00";
        var intPos = n.indexOf('.');
        if (intPos >= 0)
            n = n.substring(0, intPos) + n.substr(intPos + 1, 2);
        strUnit = strUnit.substr(strUnit.length - n.length);
        for (var i=0; i < n.length; i++)
            strOutput += '零壹贰叁肆伍陆柒捌玖'.substr(n.substr(i,1),1) + strUnit.substr(i,1);
        return strOutput;
    }
    alert(DX(1056002304.03));
    </script>
      

  2.   

    function DX(n) { 
      if (!/^(0|[1-9]\d*)(\.\d+)?$/.test(n))  return "数据非法";          
             var unit = "千百拾亿千百拾万千百拾元角分", str = ""; 
             n += "00";
             var p = n.indexOf('.');
             if (p >= 0)     n = n.substring(0, p) + n.substr(p+1, 2);
             unit = unit.substr(unit.length - n.length);
             for (var i=0; i < n.length; i++)    
                    str += '零壹贰叁肆伍陆柒捌玖'.charAt(n.charAt(i)) + unit.charAt(i); 
             return str.replace(/零(千|百|拾|角)/g, "零").replace(/(零)+/g, "零").replace(/零(万|亿|元)/g, 
    "$1").replace(/(亿)万|壹(拾)/g, "$1$2").replace(/^元零?|零分/g, "").replace(/元$/g, "元整");  
     }  
     alert('1526365.56 '+DX(1526365.56));    
      

  3.   

    加进去后只直接显示显示代码,未显示与小写金额相对应的大写金额,所以不成功。可能此代码与原来的HTEML代码不匹配。原代码是:<tr class="totalsum"><td>合计</td><td colspan=4></td><td colspan=2 align='right'><b id="totalsum">0</b>元td><td colspan=2></td></tr>
    也就是将"totalsum"由小写同时转为大写。就象E8票据通那样,将填票所产生的小写金额合计同时以大写金额的方式显示出来。
      

  4.   

    2楼的可以呀<tr class="totalsum"><td>合计</td><td colspan=4></td><td colspan=2 align='right'><b id="totalsum">34545.87</b></td><td colspan=2></td></tr>
    <script type="text/javascript">
        function DX(n) {
            if (!/^(0|[1-9]\d*)(\.\d+)?$/.test(n))  return "数据非法";
            var unit = "千百拾亿千百拾万千百拾元角分", str = "";
            n += "00";
            var p = n.indexOf('.');
            if (p >= 0)     n = n.substring(0, p) + n.substr(p+1, 2);
            unit = unit.substr(unit.length - n.length);
            for (var i=0; i < n.length; i++)
                str += '零壹贰叁肆伍陆柒捌玖'.charAt(n.charAt(i)) + unit.charAt(i);
            return str.replace(/零(千|百|拾|角)/g, "零").replace(/(零)+/g, "零").replace(/零(万|亿|元)/g,
                    "$1").replace(/(亿)万|壹(拾)/g, "$1$2").replace(/^元零?|零分/g, "").replace(/元$/g, "元整");
        }
        var id=document.getElementById("totalsum");
        id.innerHTML=id.innerHTML+"元("+DX(id.innerHTML)+")";
    </script>
      

  5.   

    ....你要显示不就document.write就行了    function DX(n) {
            if (!/^(0|[1-9]\d*)(\.\d+)?$/.test(n)) return "数据非法";
            var unit = "千百拾亿千百拾万千百拾元角分", str = "";
            n += "00";
            var p = n.indexOf('.');
            if (p >= 0) n = n.substring(0, p) + n.substr(p + 1, 2);
            unit = unit.substr(unit.length - n.length);
            for (var i = 0; i < n.length; i++)
                str += '零壹贰叁肆伍陆柒捌玖'.charAt(n.charAt(i)) + unit.charAt(i);
            return str.replace(/零(千|百|拾|角)/g, "零").replace(/(零)+/g, "零").replace(/零(万|亿|元)/g, "$1").replace(/(亿)万|壹(拾)/g, "$1$2").replace(/^元零?|零分/g, "").replace(/元$/g, "元整");
        }
        document.write('1056002304.03 ' + DX(1056002304.03));