0

http://jsfiddle.net/KYDPd

最小数を0にし、ユーザーがクリックしたときに0を下回らないようにする方法はありますか?

<form>
  <input type="text" name="name" value="0" />
  <input type="button" value="up" onclick="this.form.name.value++;" >
  <input type="button" value="down" onclick="this.form.name.value--;">
</form>
4

3 に答える 3

5

別のボタンが必要なく、HTML5 がオプションである場合は、これを使用できます。

<form>
    <input type="number" min="0" name="name" value="0" />
</form>
于 2012-04-12T09:11:49.407 に答える
2

これでうまくいくはずです。各操作を許可する前に、値を確認してください。また、テキスト入力に onchange を追加して、最小要件 0 を強制しました。ただし、これは関数内にある必要があるという他の回答に同意します。

http://jsfiddle.net/xqV6V/1/

<form>
    <input type="text" name="name" value="0" onchange="if(this.value<0){this.value=0;}" />
    <input type="button" value="up" onclick="if(this.form.name.value>=0){this.form.name.value++;}" >
    <input type="button" value="down" onclick="if(this.form.name.value>0){this.form.name.value--};">
</form>
于 2012-04-12T08:54:28.527 に答える
1

おそらく、このJavaScriptを関数に入れる必要があります。

<form>
    <input type="text" name="name" value="0" />
    <input type="button" value="up" onclick="this.form.name.value++;" >
    <input type="button" value="down" onclick="if(this.form.name.value>0)this.form.name.value--;">
</form>

関数を使用した追加の回答

<script>

function ud_find_text(self) {
    var children = self.parentNode.getElementsByTagName('input');
    for (var i = 0; i < children.length; i++) {
        if (children[i].getAttribute('type') == 'text') {
            return children[i];
        }
    }
}

function ud_inc(self) {
    var text = ud_find_text(self);
    text.value++;
}

function ud_dec(self) {
    var text = ud_find_text(self);
    if (text.value > 0) text.value--;
}

</script>

<form>
  <input type="text" name="name" value="0" />
  <input type="button" value="up" onclick="ud_inc(this)" >
  <input type="button" value="down" onclick="ud_dec(this)">
</form>
于 2012-04-12T08:53:04.783 に答える