Передать переменную из функции в другую в jQuery - PullRequest
0 голосов
/ 27 мая 2018

Я новичок в мире Javascript, и я много раз искал похожий вопрос, но никогда не работал для меня.

Так что я работаю с модалом Bootstrap, у меня есть 3 кнопки с разными именамиэто открывает модальное окно.Когда я закрываю модальное окно, мне нужно уведомление, в котором отображается название кнопки, на которую я нажал.

Например, если я нажимаю на кнопку «Email Ted», когда я закрываю модальное предупреждениескажет «Вы не отправили сообщение Теду».

Я получаю имена из атрибута data-name = "" в каждой кнопке.

Iтакже попытался вставить первую функцию в глобальную переменную, но не сработало;поэтому приведенный ниже код является идеей того, что я хочу сделать.

$(document).ready(function() {

      $("#exampleModal").on('show.bs.modal', function(e) {
        var button = $(e.relatedTarget);
        var recipient = button.data('name');
        var modal = $(this);
        modal.find('.modal-title').text('New message to ' + recipient);
        return String(recipient);
      });


      $('#exampleModal').on('hidden.bs.modal', function(recipient) {
        alert('The message will not be sended to ' + recipient);
      });

    });

Спасибо!

Ответы [ 2 ]

0 голосов
/ 27 мая 2018

Я сделал рабочую демонстрацию из того, что я понимаю по вашему вопросу.

Пожалуйста, посмотрите и спросите, что вам нужно объяснить.

$(document).ready(function() {

  
  $("#open").on("click",function(){
    $("#exampleModal").modal("show");
  });
  
  var recipient="";
  
  $("#exampleModal").on('show.bs.modal', function(e) {
    recipient = $("#open").data('name');
    var modal = $(this);
    modal.find('.modal-title').text('New message to ' + recipient);
    return String(recipient);
  });


  $('#exampleModal').on('hidden.bs.modal', function() {
    alert('The message will not be sended to ' + recipient);
  });

});
<link href="https://stackpath.bootstrapcdn.com/bootstrap/4.1.1/css/bootstrap.min.css" rel="stylesheet"/>
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<script src="https://stackpath.bootstrapcdn.com/bootstrap/4.1.1/js/bootstrap.min.js"></script>

<div class="modal" tabindex="-1" role="dialog" id="exampleModal">
  <div class="modal-dialog" role="document">
    <div class="modal-content">
      <div class="modal-header">
        <h5 class="modal-title">Modal title</h5>
        <button type="button" class="close" data-dismiss="modal" aria-label="Close">
          <span aria-hidden="true">&times;</span>
        </button>
      </div>
      <div class="modal-body">
        <p>Modal body text goes here.</p>
      </div>
      <div class="modal-footer">
        <button type="button" class="btn btn-primary">Save changes</button>
        <button type="button" class="btn btn-secondary" data-dismiss="modal" data-name="TEST Name">Close</button>
      </div>
    </div>
  </div>
</div>

<button id="open" data-name="John Doh">Open modal</button>
0 голосов
/ 27 мая 2018

Прежде всего, важно отметить, что ваш фрагмент не просто общий JavaScript, а способ работы Twitter Bootstrap.Там нет родных показанных и скрытых событий.Таким образом, у вас есть пользовательские события здесь. Btw.ссылаясь на ссылку начальной загрузки, это должно быть shown.bs.modal (распознать пропущенное 'n' в вашем коде) или, возможно, я ошибаюсь, и они внесли некоторые изменения.

Вы можете сохранить имя кнопки впеременная вроде этого:

$(document).ready(function() {

      var recipient = null;

      $("#exampleModal").on('shown.bs.modal', function(e) {
        var button = $(e.relatedTarget);
        var modal = $(this);
        recipient = button.data('name');
        modal.find('.modal-title').text('New message to ' + recipient);
      });


      $('#exampleModal').on('hidden.bs.modal', function(recipient) {
        if (recipient) {
            alert('The message will not be sended to ' + recipient);
            recipient = null; // important to reset this var for a second trigger
        }
      });

  });
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...