FetchIt
Легковесный компонент для обработки и отправки форм с помощью Fetch API
Если ваша вёрстка реализована на фреймворке Bulma, то разметка скорее всего выглядит таким образом:
<form>
<div class="field">
<label class="label">Username</label>
<div class="control">
<input class="input" type="text" name="name" value="">
</div>
<p class="help is-danger"></p>
</div>
<div class="field">
<label class="label">Email</label>
<div class="control">
<input class="input" type="email" name="email" value="">
</div>
<p class="help is-danger"></p>
</div>
<div class="field is-grouped">
<div class="control">
<button type="submit" class="button is-link">Submit</button>
</div>
<div class="control">
<button type="reset" class="button is-link is-light">Cancel</button>
</div>
</div>
</form>
Для подготовки вам необходимо сделать следующее:
data-error="*"
для элементов которые будут отображены с текстом ошибки.is-danger
, поэтому вам необходимо в системной настройке fetchit.frontend.input.invalid.class
указать её.Важно
Валидаторы разметки до сих пор ругаются на пустой атрибут action
, поэтому в нём необходимо указывать ссылку на страницу.
<form>
<form action="[[~[[*id]]]]" method="post">
<div class="field">
<label class="label">Username</label>
<div class="control">
<input class="input" type="text" name="name" value="">
<input class="input" type="text" name="name" value="[[+fi.name]]">
</div>
<p class="help is-danger"></p>
<p class="help is-danger" data-error="name">[[+fi.error.name]]</p>
</div>
<div class="field">
<label class="label">Email</label>
<div class="control">
<input class="input" type="email" name="email" value="">
<input class="input" type="email" name="email" value="[[+fi.email]]">
</div>
<p class="help is-danger"></p>
<p class="help is-danger" data-error="email">[[+fi.error.email]]</p>
</div>
<div class="field is-grouped">
<div class="control">
<button type="submit" class="button is-link">Submit</button>
</div>
<div class="control">
<button type="reset" class="button is-link is-light">Cancel</button>
</div>
</div>
</form>