Форум программистов, компьютерный форум, киберфорум
React/ReactJS
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
0 / 0 / 1
Регистрация: 30.11.2016
Сообщений: 29

Добавить валидацию и отправлять форму, только когда поля заполнены

09.04.2019, 20:08. Показов 3301. Ответов 0
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Допустим такой компонент и к нему тест. куда прописать следует заполнение поля title?
JavaScript
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
import React from 'react';
 
export default class Order extends React.Component {
  constructor() {
    super();
 
    this.state = {
      title: '',
      price: '',
      type: ''
    };
  }
 
  formClear() {
    this.setState({
      title: '',
      price: '',
      type: ''
    });
  }
 
  handleSubmit = event => {
    event.preventDefault();
 
    this.props.handleSubmit(this.state);
 
    this.formClear();
  };
 
  handleInputChange = event => {
    this.setState({
      [event.target.name]: event.target.value
    });
  };
 
  render() {
    return (
      <form onSubmit={this.handleSubmit}>
        <input
          type="text"
          name="title"
          value={this.state.title}
          onChange={this.handleInputChange}
          placeholder="Название"
        />
        <input
          type="text"
          name="price"
          value={this.state.price}
          onChange={this.handleInputChange}
          placeholder="Цена"
        />
        <input
          type="text"
          name="type"
          value={this.state.type}
          onChange={this.handleInputChange}
          placeholder="Тип"
        />
        <button type="submit">Отправить</button>
      </form>
    );
  }
}
тест:
JavaScript
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
import React from 'react';
import { mount } from 'enzyme';
import Order from './Order';
 
const createEvent = (name, value) => ({ target: { name, value } });
 
describe('Order', () => {
let component;
  let handleSubmit;
 
  beforeEach(() => {
    handleSubmit = jest.fn();
    component = mount(<Order handleSubmit={handleSubmit} />);
  });
describe('Валидация', () => {
    /*
    Мы не хотим отправлять форму, если какое либо из полей пустое.
    Для этого, мы должны добавить валидацию и отпраправлять форму, только когда оба поля заполнены
 
    Нужно добавить валидацию полей в Order.js. Пока будете валидация только на предмет не пустого значения.
    Но, нужна такая реализация, которую можно будет потом расширить к примеру - валидацию дат, валидация типа введенных данных.
     */
    it('Заполняем только поле title и отправляем', () => {
      component.find('[name="title"]').simulate('change', createEvent('title', 'Apple'));
      component.find('form').simulate('submit');
 
      expect(handleSubmit).not.toHaveBeenCalled();
    });
  });
});
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
09.04.2019, 20:08
Ответы с готовыми решениями:

Разрешить нажатие кнопки только когда заполнены все поля
Подскажите что подкорректировать в коде чтобы кнопка была активна только после заполнения всех полей и при том поля должны быть заполнены...

Числовые поля, их суммирование, когда не все заполнены
Здравствуйте ! У меня на форме 5 числовых полей. 1 для итога, 4 для подсчета. К примеру, если 3 поля заполнены числами, а 4 нет, то...

Перехват ошибки dataGridView когда заполнены не все поля строки
Я добавил на форму dataGridView и добавил через источник данных таблицу с тремя столбцами. Во всех столбцах запрещены Null значения. ...

0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
09.04.2019, 20:08
Помогаю со студенческими работами здесь

Как в форму добавить поля только что созданной таблицы?
Отредактировал форму, создал новую таблицу, но не получается добавить в форму поля недавно созданной таблицы - просто таких полей нет! В...

Как выбрать только те поля которые заполнены?
Есть таблица mysql в ней есть строки где некоторые поля заведомо пусты. Как выбрать только те поля которые заполнены. Пример ...

Блокировка входа в подчиненную форму, если в главной не заполнены основные поля
Доброго времени суток! Бьюсь над таким вопросом: как заблокировать вход в Подчиненную форму, если в Главной форме (на которой размещена...

Как добавить поля в форму
Необходимо добавить расчетные поля в подчиненную форму. То есть,нужно Добавить поле &quot;Цена&quot;,используя данные с уже имеющихся полей...

в MySQL заносятся данные только когда заполняются все поля
в MySQL заносятся данные только когда заполнены все поля. а как сделать, чтобы можно было заполнять не все поля? например два заполнить, а...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
1
Ответ Создать тему
Новые блоги и статьи
Символьное дифференцирование
igorrr37 13.02.2026
/ * Программа принимает математическое выражение в виде строки и выдаёт его производную в виде строки и вычисляет значение производной при заданном х Логарифм записывается как: (x-2)log(x^2+2) -. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL3_image
8Observer8 10.02.2026
Содержание блога Библиотека SDL3_image содержит инструменты для расширенной работы с изображениями. Пошагово создадим проект для загрузки изображения формата PNG с альфа-каналом (с прозрачным. . .
Установка Qt-версии Lazarus IDE в Debian Trixie Xfce
volvo 10.02.2026
В общем, достали меня глюки IDE Лазаруса, собранной с использованием набора виджетов Gtk2 (конкретно: если набирать текст в редакторе и вызвать подсказку через Ctrl+Space, то после закрытия окошка. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru