Есть ли способ предотвратить ввод типа ввода = "число", получающего отрицательные значения?

Я хочу получить только положительные значения, есть ли способ предотвратить его использование только html
Пожалуйста, не предлагайте метод проверки

Screenshot of input control

Ответ 1

Используйте атрибут min следующим образом:

<input type="number" min="0">

Ответ 2

Меня не устраивает @Abhrabm answer, потому что:

Он запрещал вводить только отрицательные числа из стрелки вверх/вниз, тогда как пользователь может ввести отрицательное число с клавиатуры.

Решение состоит в предотвращении с помощью key code:

// Select your input element.
var number = document.getElementById('number');

// Listen for input event on numInput.
number.onkeydown = function(e) {
    if(!((e.keyCode > 95 && e.keyCode < 106)
      || (e.keyCode > 47 && e.keyCode < 58) 
      || e.keyCode == 8)) {
        return false;
    }
}
<form action="" method="post">
  <input type="number" id="number" min="0" />
  <input type="submit" value="Click me!"/>
</form>

Ответ 3

Для меня решение было:

<input type="number" min="0" oninput="this.value = Math.abs(this.value)">

Ответ 4

Этот код работает отлично для меня. Можете ли вы проверить:

<input type="number" name="test" min="0" oninput="validity.valid||(value='');">

Ответ 5

Простой способ:

<input min='0' type="number" onkeypress="return (event.charCode == 8 || event.charCode == 0) ? null : event.charCode >= 48 && event.charCode <= 57">

Ответ 6

Только для справки: с jQuery вы можете перезаписать отрицательные значения для фокуса следующим кодом:

$(document).ready(function(){
    $("body").delegate('#myInputNumber', 'focusout', function(){
        if($(this).val() < 0){
            $(this).val('0');
        }
    });
});

Это не заменяет проверку на стороне сервера!

Ответ 7

Ответ @Manwal хорош, но мне нравится код с меньшим количеством строк кода для лучшей читаемости. Также мне нравится использовать onclick/onkeypress в html вместо.

Мое предлагаемое решение делает то же самое: Добавить

min="0" onkeypress="return isNumberKey(event)"

для ввода html и

function isNumberKey(evt){
    var charCode = (evt.which) ? evt.which : event.keyCode;
    return !(charCode > 31 && (charCode < 48 || charCode > 57));
}

как функция javascript.

Как сказано, он делает то же самое. Это просто личное предпочтение тому, как решить проблему.

Ответ 8

Я хотел разрешить десятичные числа и не очистить весь ввод, если был введен отрицательный. Это хорошо работает в Chrome, по крайней мере:

<input type="number" min="0" onkeypress="return event.charCode != 45">

Ответ 9

Здесь angular 2 решение:

создать класс OnlyNumber

import {Directive, ElementRef, HostListener} from '@angular/core';

@Directive({
  selector: '[OnlyNumber]'
})
export class OnlyNumber {

  // Allow decimal numbers. The \. is only allowed once to occur
  private regex: RegExp = new RegExp(/^[0-9]+(\.[0-9]*){0,1}$/g);

  // Allow key codes for special events. Reflect :
  // Backspace, tab, end, home
  private specialKeys: Array<string> = ['Backspace', 'Tab', 'End', 'Home'];

  constructor(private el: ElementRef) {
  }

  @HostListener('keydown', ['$event'])
  onKeyDown(event: KeyboardEvent) {
    // Allow Backspace, tab, end, and home keys
    if (this.specialKeys.indexOf(event.key) !== -1) {
      return;
    }

    // Do not use event.keycode this is deprecated.
    // See: https://developer.mozilla.org/en-US/docs/Web/API/KeyboardEvent/keyCode
    let current: string = this.el.nativeElement.value;
    // We need this because the current value on the DOM element
    // is not yet updated with the value from this event
    let next: string = current.concat(event.key);
    if (next && !String(next).match(this.regex)) {
      event.preventDefault();
    }
  }
}

добавьте OnlyNumber в объявления в app.module.ts и используйте как это в любом месте вашего приложения.

<input OnlyNumber="true">

Ответ 10

<input type="number" name="credit_days" pattern="[^\-]+" 
    #credit_days="ngModel" class="form-control" 
    placeholder="{{ 'Enter credit days' | translate }}" min="0" 
    [(ngModel)]="provider.credit_days"
    onkeypress="return (event.charCode == 8 || event.charCode == 0 || 
    event.charCode == 13) ? null : event.charCode >= 48 && event.charCode <= 
    57" onpaste="return false">

Ответ 11

oninput="this.value=(this.value   < Number(this.min) || this.value   > Number(this.max))  ? '' : this.value;"

Ответ 12

вы должны использовать атрибут min во входных данных

<input type='number' min='0'/>

Ответ 13

Это решение позволяет использовать все функции клавиатуры, включая копирование и вставку с клавиатуры. Это предотвращает вставку отрицательных чисел с помощью мыши. Это работает со всеми браузерами, и демонстрация на codepen использует bootstrap и jQuery. Это должно работать с неанглийскими настройками и клавиатурой. Если браузер не поддерживает захват события вставки (IE), он удалит отрицательный знак после фокусировки. Это решение ведет себя так, как должен работать нативный браузер с min = 0 type = number.

Разметка:

<form>
  <input class="form-control positive-numeric-only" id="id-blah1" min="0" name="nm1" type="number" value="0" />
  <input class="form-control positive-numeric-only" id="id-blah2" min="0" name="nm2" type="number" value="0" />
</form>

Javascript

$(document).ready(function() {
  $("input.positive-numeric-only").on("keydown", function(e) {
    var char = e.originalEvent.key.replace(/[^0-9^.^,]/, "");
    if (char.length == 0 && !(e.originalEvent.ctrlKey || e.originalEvent.metaKey)) {
      e.preventDefault();
    }
  });

  $("input.positive-numeric-only").bind("paste", function(e) {
    var numbers = e.originalEvent.clipboardData
      .getData("text")
      .replace(/[^0-9^.^,]/g, "");
    e.preventDefault();
    var the_val = parseFloat(numbers);
    if (the_val > 0) {
      $(this).val(the_val.toFixed(2));
    }
  });

  $("input.positive-numeric-only").focusout(function(e) {
    if (!isNaN(this.value) && this.value.length != 0) {
      this.value = Math.abs(parseFloat(this.value)).toFixed(2);
    } else {
      this.value = 0;
    }
  });
});

Ответ 14

Вот решение, которое работает лучше всего для поля QTY, которое допускает только числа.

// Only allow numbers, backspace and left/right direction on QTY input
    if(!((e.keyCode > 95 && e.keyCode < 106) // numpad numbers
        || (e.keyCode > 47 && e.keyCode < 58) // numbers
        || [8, 9, 35, 36, 37, 39].indexOf(e.keyCode) >= 0 // backspace, tab, home, end, left arrow, right arrow
        || (e.keyCode == 65 && (e.ctrlKey === true || e.metaKey === true)) // Ctrl/Cmd + A
        || (e.keyCode == 67 && (e.ctrlKey === true || e.metaKey === true)) // Ctrl/Cmd + C
        || (e.keyCode == 88 && (e.ctrlKey === true || e.metaKey === true)) // Ctrl/Cmd + X
        || (e.keyCode == 86 && (e.ctrlKey === true || e.metaKey === true)) // Ctrl/Cmd + V
    )) {
        return false;
    }

Ответ 15

Просто добавьте еще один способ сделать это (используя Angular), если вы не хотите портить HTML еще большим количеством кода:

Вам нужно только подписаться на поле valueChanges и установить значение в качестве абсолютного значения (заботясь о том, чтобы не генерировать новое событие, потому что это вызовет другое значение valueChange, а следовательно, рекурсивный вызов и вызовет ошибку превышения максимального размера вызова)

HTML-код

<form [formGroup]="myForm">
    <input type="number" formControlName="myInput"/>
</form>

TypeScript CODE (внутри вашего компонента)

formGroup: FormGroup;

ngOnInit() { 
    this.myInput.valueChanges 
    .subscribe(() => {
        if (this.myInput.value) {
            this.myInput.setValue(Math.abs(this.myInput.value), {emitEvent: false});
        }
    });
}

get myInput(): AbstractControl {
    return this.myForm.controls['myInput'];
}

Ответ 16

Ответ на это не полезен. поскольку он работает только при использовании клавиш вверх/вниз, но если вы наберете -11, он не будет работать. Итак, вот небольшое исправление, которое я использую

этот для целых чисел

  $(".integer").live("keypress keyup", function (event) {
    //    console.log('int = '+$(this).val());
    $(this).val($(this).val().replace(/[^\d].+/, ""));
    if (event.which != 8 && (event.which < 48 || event.which > 57))
    {
        event.preventDefault();
    }
   });

этот, когда у вас есть номера цены

        $(".numeric, .price").live("keypress keyup", function (event) {
     //    console.log('numeric = '+$(this).val());
    $(this).val($(this).val().replace(/[^0-9\,\.]/g, ''));

    if (event.which != 8 && (event.which != 44 || $(this).val().indexOf(',') != -1) && (event.which < 48 || event.which > 57)) {
        event.preventDefault();
    }
   });