2016-04-15 54 views
2

我使用基於以下示例的示例可以稱爲: http://jsfiddle.net/5tt7d3e6/在一個div分配靜態數據量從一個函數

在此,將創建一個函數把一個數字字。

的功能在以下的HTML上面

<input type="text" name="number" placeholder="Number OR Amount" onkeyup="word.innerHTML=convertNumberToWords(this.value)" /> 
<div id="word"></div> 

允許您輸入一個數字的文本框處理。該功能將您輸入的數字轉換爲單詞。

有沒有一種簡單的方法來設置一個已經存有數字的div,而不是鍵入它來顯示?

如:

<div data="innerHTML=convertNumberToWords(1233213)"></div> 
+0

'onkeyup'是正在調用的事件..數據不是! – Rayon

回答

0

可以聯播的事件處理程序onreadystatechange和裏面,你可以把你的邏輯。

Fiddle 1

document.onreadystatechange = function() { 
    word.innerHTML = convertNumberToWords(1233213); 
}; 

但是,如果你想顯示基於現有價值裏面input數據,先放一個id屬性爲input

<input id="number" ... /> 

然後在JS:

document.onreadystatechange = function() { 
    word.innerHTML = convertNumberToWords(number.value); 
}; 

Fiddle 2

0

建議:在convertNumberToWords使用switch敘述()

switch(amount){ 
    case 0: 'zero'; break; 
    default: 'Please enter number only!'; break; 
} 
0

Fiddle Link

改變文本框和按點擊按鈕的值將返回到Word

<input id="check"type="text" name="number" placeholder="Number OR Amount" /> 
<div id="word"></div> 
<input type="button" id="button" value="click"> 

js代碼

$("#button").click(function() 
{ 
var number = $('#check').val(); 
$("#word").html(toWords(number)); 

}); 


var th = ['','thousand','million', 'billion','trillion']; 
var dg = ['zero','one','two','three','four', 'five','six','seven','eight','nine']; var tn = ['ten','eleven','twelve','thirteen', 'fourteen','fifteen','sixteen', 'seventeen','eighteen','nineteen']; var tw = ['twenty','thirty','forty','fifty', 'sixty','seventy','eighty','ninety']; function toWords(s){s = s.toString(); s = s.replace(/[\, ]/g,''); if (s != parseFloat(s)) return 'not a number'; var x = s.indexOf('.'); if (x == -1) x = s.length; if (x > 15) return 'too big'; var n = s.split(''); var str = ''; var sk = 0; for (var i=0; i < x; i++) {if ((x-i)%3==2) {if (n[i] == '1') {str += tn[Number(n[i+1])] + ' '; i++; sk=1;} else if (n[i]!=0) {str += tw[n[i]-2] + ' ';sk=1;}} else if (n[i]!=0) {str += dg[n[i]] +' '; if ((x-i)%3==0) str += 'hundred ';sk=1;} if ((x-i)%3==1) {if (sk) str += th[(x-i-1)/3] + ' ';sk=0;}} if (x != s.length) {var y = s.length; str += 'point '; for (var i=x+1; i<y; i++) str += dg[n[i]] +' ';} return str.replace(/\s+/g,' ');} 
+0

我編輯了我的答案 –

0

如果您想在處理文檔時寫入文檔,並且不晚於

<div id="word"> 

    <script> 
    document.write(convertNumberToWords(12233456)) 
    </script> 

</div> 

這是推薦的方式,雖然:

<div id="word"></div> 
    <script> 
    document.getElementById('word').innerHTML = convertNumberToWords(12233456); 
    </script> 

-

<script> 
 
    function convertNumberToWords(amount) { 
 
    var words = new Array(); 
 
    words[0] = ''; 
 
    words[1] = 'One'; 
 
    words[2] = 'Two'; 
 
    words[3] = 'Three'; 
 
    words[4] = 'Four'; 
 
    words[5] = 'Five'; 
 
    words[6] = 'Six'; 
 
    words[7] = 'Seven'; 
 
    words[8] = 'Eight'; 
 
    words[9] = 'Nine'; 
 
    words[10] = 'Ten'; 
 
    words[11] = 'Eleven'; 
 
    words[12] = 'Twelve'; 
 
    words[13] = 'Thirteen'; 
 
    words[14] = 'Fourteen'; 
 
    words[15] = 'Fifteen'; 
 
    words[16] = 'Sixteen'; 
 
    words[17] = 'Seventeen'; 
 
    words[18] = 'Eighteen'; 
 
    words[19] = 'Nineteen'; 
 
    words[20] = 'Twenty'; 
 
    words[30] = 'Thirty'; 
 
    words[40] = 'Forty'; 
 
    words[50] = 'Fifty'; 
 
    words[60] = 'Sixty'; 
 
    words[70] = 'Seventy'; 
 
    words[80] = 'Eighty'; 
 
    words[90] = 'Ninety'; 
 
    amount = amount.toString(); 
 
    var atemp = amount.split("."); 
 
    var number = atemp[0].split(",").join(""); 
 
    var n_length = number.length; 
 
    var words_string = ""; 
 
    if (n_length <= 9) { 
 
     var n_array = new Array(0, 0, 0, 0, 0, 0, 0, 0, 0); 
 
     var received_n_array = new Array(); 
 
     for (var i = 0; i < n_length; i++) { 
 
     received_n_array[i] = number.substr(i, 1); 
 
     } 
 
     for (var i = 9 - n_length, j = 0; i < 9; i++, j++) { 
 
     n_array[i] = received_n_array[j]; 
 
     } 
 
     for (var i = 0, j = 1; i < 9; i++, j++) { 
 
     if (i == 0 || i == 2 || i == 4 || i == 7) { 
 
      if (n_array[i] == 1) { 
 
      n_array[j] = 10 + parseInt(n_array[j]); 
 
      n_array[i] = 0; 
 
      } 
 
     } 
 
     } 
 
     value = ""; 
 
     for (var i = 0; i < 9; i++) { 
 
     if (i == 0 || i == 2 || i == 4 || i == 7) { 
 
      value = n_array[i] * 10; 
 
     } else { 
 
      value = n_array[i]; 
 
     } 
 
     if (value != 0) { 
 
      words_string += words[value] + " "; 
 
     } 
 
     if ((i == 1 && value != 0) || (i == 0 && value != 0 && n_array[i + 1] == 0)) { 
 
      words_string += "Crores "; 
 
     } 
 
     if ((i == 3 && value != 0) || (i == 2 && value != 0 && n_array[i + 1] == 0)) { 
 
      words_string += "Lakhs "; 
 
     } 
 
     if ((i == 5 && value != 0) || (i == 4 && value != 0 && n_array[i + 1] == 0)) { 
 
      words_string += "Thousand "; 
 
     } 
 
     if (i == 6 && value != 0 && (n_array[i + 1] != 0 && n_array[i + 2] != 0)) { 
 
      words_string += "Hundred and "; 
 
     } else if (i == 6 && value != 0) { 
 
      words_string += "Hundred "; 
 
     } 
 
     } 
 
     words_string = words_string.split(" ").join(" "); 
 
    } 
 
    return words_string; 
 
    } 
 
</script> 
 
<div id="word"> 
 

 
    <script> 
 
    document.write(convertNumberToWords(12233456)) 
 
    </script> 
 

 
</div>

相關問題