Javascript-форум (https://javascript.ru/forum/)
-   Общие вопросы Javascript (https://javascript.ru/forum/misc/)
-   -   переменная $_POST и JS (https://javascript.ru/forum/misc/50712-peremennaya-%24_post-i-js.html)

voral 08.10.2014 17:47

<form method="post">
	<input name="login" type="text">
	<input name="submit" type="submit" class='btn' id="submit"></form>
<?php
if(empty ($_POST['login'])) {?>	

<script>
  window.onload = function() {
    swal("Password or Login incorrect!");
  }
</script>
<?php 
} else {echo 'login correct';}
?>

arimanecro 08.10.2014 17:54

почти то что надо, огромное спасибо :thanks:

но сразу появляется проблема, как только я захожу на страницу, скрипт автоматом срабатывает(выскакивает окно), видимо поэтому и нужно было onclick = function(). Кажись тупиковая ситуация :(

voral 08.10.2014 17:58

Нет
Ну "онклик" же явно говорит, что функция срабатывает на клик. А вам это не надо. Соответсвенно ваша ошибка в php.
Вы проверяете пустой или нет $_POST['login'], а вам нужно проверить есть ли он вообще. if (isset($_POST['login']))..... и вы этом случае не выводить ни чего. В настоящий момент при этой ситуации php скрипт попадает в ваше условие заставляющее отобразить окно с ошибкой


<?php
  if (isset($_POST['login'])) {
    if(empty ($_POST['login'])) {?> 
       <script>
          window.onload = function() {
             swal("Password or Login incorrect!");
          }
       </script>
<?php
    }
    else {
       echo 'login correct';
   }
}
?>

arimanecro 08.10.2014 18:05

voral,
да, Вы совершенно правы, я по своей невнимательности, забыл сначала проверить на isset.
Благодарю ещё раз, за столь быстрые и правильные ответы :thanks:
В карму смог добавить только один плюсик, больше не получается, из-за того, что требуется ещё кому-нибудь поставить (

danik.js 08.10.2014 18:22

<input name="login" type="text" required> и фиг ты отправишь пустое поле, по крайней мере в современных браузерах)
Но это не отменяет необходимость серверной проверки.

kostyanet 09.10.2014 09:28

Так не делают, это уродство. Когда страница перезагружается то все сообщения валятся прямо в html, а когда страница не перезагружается, то все сообщения валятся в js-скрипт, который затем валит их в html.

В принципе можно и алерты втюхивать, onload тут вообще не при делах. Как только парсер дошел до алерта - показал. Потому что все уже решено до того как.

kostyanet 09.10.2014 10:12

Вот так сделайте, как людей:

В процессе валидации просто собираете ерроры в массив, например

if(!validate($var))
$error[]='Нет такого юзера, или юзер ввел пароль неправильно';

Затем в рендере у вас, например

Код:

<div class="error_message">
 ?>
  if(count($errors))
    echo '<ul><li>', join('</li><li>',$errors), '</li></ul>';
 <?php
</div>

и все. Если ошибки были - они в хтмле проявятся. А если не было, этот div вообще не будет виден, ибо это div, а пустой div занимает 0 целых Х десятых места.

Более того, если вы захотите запросить данные с того же скрипта, то попросту выделяете этот кусок в отдельный файл (или метод, или функцию) и вызываете его (его, ее) единственно когда случились ошибки. Тогда по XMLHttpRequest скрипт получит точно такой же кусок хтмля и вставит его в то же самое место. - Это для случая без перезагрузки.

danik.js 09.10.2014 10:24

Цитата:

Сообщение от kostyanet
ибо это div, а пустой div занимает 0 целых Х десятых места.

А если ему назначен padding и иконка/бэкграунд?

voral 09.10.2014 10:34

Цитата:

Сообщение от kostyanet (Сообщение 334231)
А если не было, этот div вообще не будет виден, ибо это div, а пустой div занимает 0 целых Х десятых места.

Ну уж если все "вылизывать" то зачем вообще этот div выводить? Это сейчас он пустой, а завтра обновят на сайте стили....

На вопрос "зачем". Тут все от общей задачи зависит. Так просто "это не правильно" говорить не надо. Возможно окно строится общим для сайта скриптом. И используется скрипт в различных ситуациях. А может шаблон окна уже есть в html.


Часовой пояс GMT +3, время: 06:17.