0

入力の現在の値(int)を単語に変換するスクリプトを作成しようとしています。

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 'You must enter 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, ' ');
    return false;
}


var input = $('#numbers'),
    label = $('.words'),
    converted = toWords(input.val());

input.bind('keyup keydown', function() {
    converted = toWords(this.value)
    setTimeout(function() {
        label.empty().text(converted);
    }, 1000);
});​

この時点で、入力した内容をライブ入力できますが、toWords関数を介して送信すると、ページの読み込み時に指定された入力の値が取得されます。

つまり、入力された新しい数値で入力フィールドの値が更新されないため、新しい数値が単語に変換されます。

何か案は?-http ://jsfiddle.net/qTBxv/211/

4

4 に答える 4

4

変換された変数を入力の新しい値で更新する必要があります。

$(document).ready(function(){
    input.bind('keyup', function() {
        setTimeout(function() {
            converted = toWords(input.val());
            label.append(converted);
    }, 500);
    });
});

デモ: http://jsfiddle.net/qTBxv/214/

于 2012-09-18T20:48:49.830 に答える
3

への呼び出しを追加しtoWords、添付イベントにも現在の入力値を渡します。

input.bind('keyup keydown', function() {
    converted = toWords(this.value)
    setTimeout(function() {
        label.empty().text(converted);
    }, 1000);
});​

デモ

于 2012-09-18T20:53:52.267 に答える
2

converted値が変更されるたびに必ず更新する必要があります (この場合、重要なイベントにフックしているので、そこで実行できます)。そのようです:

var input = $('#numbers'),
    label = $('.words'),
    converted;

input.bind('keyup keydown', function() {
    converted = toWords(input.val());
    setTimeout(function() {
        label.empty().text(converted);
    }, 1000);
});​

それは私にとってそれを修正するように見えました。

于 2012-09-18T20:54:21.987 に答える
0

究極の答えとしてangularJSを提案するかもしれません。

于 2013-08-07T17:45:37.457 に答える