JS支持负数的进制转换和产生随机颜色

来源:互联网 发布:cms系统开发文档 编辑:程序博客网 时间:2024/06/04 23:34

进制转换

  1. <HTML>
  2. <HEAD>
  3. <META http-equiv='Content-Type' content='text/html; charset=gb2312'>
  4. <TITLE>功能要较强的数字进制转换的脚本</TITLE>
  5. <SCRIPT LANGUAGE="JavaScript">
  6. <!-- Begin
  7. var hex = new Array("0", "1", "2", "3", "4", "5", "6", "7", "8", "9", "A", "B", "C", "D", "E", "F");
  8. function CKparseInt(n, r) {
  9. for (var i = 0; i < n.length; ++i)
  10. if (n.charAt(i) >= r) {
  11. alert("格式错");
  12. return 0;
  13. }
  14. if (isNaN(M = parseInt(n, r)))
  15. alert ("格式错");
  16. return M;
  17. }
  18. // decimal to any other base 2 to 16
  19. function DecimaltoAnother(A, radix) {
  20. s = "";
  21. while (A >= radix) {
  22. s += hex[A % radix];  // remainder
  23. A = Math.floor(A / radix); // quotient, rounded down
  24. }
  25. return transpose(s += hex[A]);
  26. }
  27. // string reversal
  28. function transpose(s) {
  29. N = s.length;
  30. for (i = 0,t = ""; i < N; i++)
  31. t += s.substring(N-i-1, N-i); // s.substring(from, to)
  32. return t;
  33. }
  34. // convert item.value using radix
  35. function EvalAny(item, r) {
  36. M = CKparseInt(item.value, r); // check this one
  37. for (var i = 0MyForm = document.forms[0]; i < MyForm.length; ++i) // re-evaluate all
  38. MyForm.elements[i].value = DecimaltoAnother(M, MyForm.elements[i].name.substr(1,3));
  39. }
  40. //  End -->
  41. </script>
  42. </HEAD>
  43. <BODY >
  44. <center>
  45.   <h3>进制转换</h3>
  46.   <br>
  47. <form method="post">
  48. <table border=0 align=center>
  49. <tr>
  50. <td align=right>
  51.           <p>二进制:</p>
  52.         </td>
  53. <td><input name="b002" value="0" onChange="EvalAny(this, 2)" size=27></td>
  54. </tr>
  55. <tr>
  56.         <td align=right>三进制:</td>
  57. <td><input name="t003" value="0" onChange="EvalAny(this, 3)" size=21></td>
  58. </tr>
  59. <tr>
  60.         <td align=right>五进制:</td>
  61. <td><input name="q005" value="0" onChange="EvalAny(this, 5)" size=16></td>
  62. </tr>
  63. <tr>
  64.         <td align=right>八进制:</td>
  65. <td><input name="o008" value="0" onChange="EvalAny(this, 8)" size=12></td>
  66. </tr>
  67. <tr>
  68.         <td align=right>十进制:</td>
  69. <td><input name="d010" value="0" onChange="EvalAny(this, 10)" size=11></td>
  70. </tr>
  71. <tr>
  72.         <td align=right>十六进制:</td>
  73. <td><input name="h016" value="0" onChange="EvalAny(this, 16)" size=8></td>
  74. </tr>
  75. </table>
  76. </form>
  77. </center>
  78. </BODY></HTML>

支持负数的16进制转换

 

  1. var errCode = -1474953214;
  2. function memoryHex(value)
  3. {
  4.     return (value >= 0 ? value : 0x100000000 + value).toString(16) 
  5. }
  6. alert(memoryHex(errCode));

产生随机色

  1. function colorFormat(color)
  2. {
  3.     var s = color.toString(16);
  4.     var l = s.length;
  5.     return "#" + "000000".substring(l) + s;
  6. }
  7. var color = Math.ceil(0x1000000 * Math.random());
  8. alert(colorFormat(color));
  9. alert(("000000" + Math.ceil(0x1000000 * Math.random()).toString(16)).replace(/^.*(.{6})$/, "#$1"));