IvanIlyasov
@IvanIlyasov
Познаю мир

Как вывести элементы в нужном месте?

Есть JS-код, который выводит сообщения об ошибке, если форма заполнена не верно.

Шаблон следующего вида:
var buildPrompt = function(caller,promptText) {
		var divFormError = document.createElement('div')
		var formErrorContent = document.createElement('div')
		
		
		$(divFormError).addClass("formError")
		$(divFormError).addClass($(caller).attr("name"))
		$(formErrorContent).addClass("formErrorContent")
		
		$("body").append(divFormError)
		$(divFormError).append(formErrorContent)
		$(formErrorContent).html(promptText)

		$(divFormError).fadeTo("fast",0.8);
	};


В HTML, в конечном виде он отображается так:
<div class="formError name"><div class="formErrorContent">Это поле не должно быть пустым!</div></div>
<div class="formError telephone"><div class="formErrorContent">Это поле не должно быть пустым!</div></div>
<div class="formError email"><div class="formErrorContent">Это поле не должно быть пустым!</div></div>

Находятся эти он в body, что видно из кода JS выше.

Сама форма имеет вид:
<form method="GET" action="contact.html" name="form-1">
            <table class="form">
              <tr>
                <td class="form-left">Имя:</td>
                <td>
                  <input name="name" type="text" class="buy-input">
                  <span id="error_text_name"></span>
                </td>
              </tr>
              <tr>
                <td class="form-left">Телефон:</td>
                <td>
                  <input name="telephone" type="text" class="buy-input">
                  <span id="error_text_telephone"></span>
                </td>
              </tr><tr>
                <td class="form-left">Почта:</td>
                <td>
                  <input name="email" type="text" placeholder="Имя" class="buy-input">
                  <span id="error_text_email"></span>
                </td>
              </tr>
            <div class="form-submit">
              <input name="send" type="button" value="Отправить" class="feedback">
            </div>
</form>


На данный момент сообщения с ошибками <div class="formError XXX"> отображаются внизу страницы под формой.

Вопрос:
Как сделать так, чтобы сообщения с ошибками <div class="formError XXX"> отображались в соответствующих блоках <span id="error_text_XXX">?
  • Вопрос задан
  • 2346 просмотров
Решения вопроса 1
IvanIlyasov
@IvanIlyasov Автор вопроса
Познаю мир
Решение было найдено самостоятельно:
1. Заменил все <span id="error_text_XXX"> на <span id="XXX">

var buildPrompt = function(caller,promptText) {
		var divFormError = document.createElement('div')
		var formErrorContent = document.createElement('div')
		var spanIdfromDiv = document.getElementById($(caller).attr("name"))
		
		$(divFormError).addClass("formError")
		$(divFormError).addClass($(caller).attr("name"))
		$(formErrorContent).addClass("formErrorContent")
		
		$(spanIdfromDiv).append(divFormError)
		$(divFormError).append(formErrorContent)
		$(formErrorContent).html(promptText)

		$(divFormError).fadeTo("fast",0.8);
	};
Ответ написан
Комментировать
Пригласить эксперта
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Войти через центр авторизации
Похожие вопросы
КРАФТТЕК Санкт-Петербург
от 60 000 до 80 000 ₽
Brightdata Тель-Авив
от 5 500 до 6 500 $
Rocket Брянск
от 60 000 до 100 000 ₽
27 мая 2024, в 18:34
1000 руб./за проект
27 мая 2024, в 18:33
15000 руб./за проект
18 мая 2024, в 11:01
40000 руб./за проект