Экспресс-запрос Node.js - ошибка загрузки и исчезновения при загрузке - PullRequest
0 голосов
/ 24 августа 2018

Я использую экспресс-сессию node.js и запрос.Если в запросе есть ошибка, я начинаю выводить и выводить предупреждение.Это работает.Но если я хочу добавить и выгружать мод загрузки ... это не сработает.Вот мои настройки:

script.js

$(document).ready(function(){

    // alerts
    window.setTimeout(function() {
        $(".alert").fadeTo(500, 0).slideUp(500, function(){
            $(this).remove();
        });
    }, 4000);

    // modals
    window.setTimeout(function() {
        $("#myModal").fadeIn('slow', function(){
            $(this).modal('hide');
            });
    }, 4000);

});

modalError.ejs

<!-- Modal -->
<div class="modal fade" id="myModal" tabindex="-1" role="dialog" aria-labelledby="myModalLabel">
  <div class="modal-dialog" role="document">
    <div class="modal-content">
      <div class="modal-header">
        <button type="button" class="close" data-dismiss="modal" aria-label="Close"><span aria-hidden="true">&times;</span></button>
        <h4 class="modal-title" id="myModalLabel">Modal title</h4>
      </div>
      <div class="modal-body">
        <%= messages.error %>
      </div>
    </div>
  </div>
</div>  

alertError.ejs

<div class="alert alert-danger alert-dismissible" role="alert">
  <button type="button" class="close" data-dismiss="alert" aria-label="Close"><span aria-hidden="true">&times;</span></button>
  <%= messages.error %>
</div>

login.ejs

<html>
    <body>
        <div>   
            <% if (messages.error) { %>
                <% include partials/alertError %>
            <% } %>

            <% if (messages.error) { %>
                <% include partials/modalError %>
            <% } %>
        </div>
        <% include partials/script %>
    </body>
</html>

У кого-нибудь есть решение?

В запросе я проверяю статус так:

if(getStatus == 401){
  req.flash('error', 'An error occurred during login.') 
  res.redirect('/login')
}

Ответы [ 2 ]

0 голосов
/ 24 августа 2018

Bootstrap Modal имеет эффекты затухания. но время перехода меньше, попробуйте увеличить, чтобы эффекты были более заметными.

.fade {
    opacity: 0;
    -webkit-transition: opacity 1s linear;
    transition: opacity 1s linear;
}
0 голосов
/ 24 августа 2018

вы можете получить доступ к переменным ejs внутри скрипта,

<script>
    if(messages.error){
     $("#myModal").modal('show');
    }   
</script>
...