区分动态ID

时间:2017-12-24 10:55:06

标签: javascript jquery blade

如何用jQuery区分动态id?

HTML:

@foreach($listeSeances as $seance)
    ... 

    <div class="modal fade reservationModal" id="reservationModal-{{ $seance->id_seance }}" tabindex="-1" role="dialog" aria-labelledby="reservationModal-{{ $seance->id_seance }}" aria-hidden="true">
         ...
    </div>

@endforeach

JS:

$('[id^="reservationModal-"]').on('shown.bs.modal', function (e) {
    console.log('works');
});

我的目标是找到&#34;替换&#34; {{ $seance->id_seance }}以JS中的任何数字来表示具有泛型函数。

感谢您的帮助!

2 个答案:

答案 0 :(得分:2)

shown.bs.modal事件的目标是div.modal,您可以从中检索元素ID - 通过一些解析,您可以在id_seance之前获得原始值$('[id^="reservationModal-"]').on('shown.bs.modal', function (e) { let id_seance = e.target.id.split('-').pop(-1); console.log('works', { id_seance }); });内插。

&#13;
&#13;
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>

<!-- Latest compiled and minified CSS -->
<link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha384-BVYiiSIFeK1dGmJRAkycuHAHRg32OmUcww7on3RYdg4Va+PmSTsz/K68vbdEjh4u" crossorigin="anonymous">

<!-- Optional theme -->
<link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap-theme.min.css" integrity="sha384-rHyoN1iRsVXV4nD0JutlnGaslCJuC7uwjduW9SVrLvRYooPp2bWYgmgJQIXwl/Sp" crossorigin="anonymous">

<!-- Latest compiled and minified JavaScript -->
<script src="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/js/bootstrap.min.js" integrity="sha384-Tc5IQib027qvyjSMfHjOMaLkfuWVxZxUPnCJA7l2mCWNIpG9mGCD8wGNIcPD7Txa" crossorigin="anonymous"></script>

<button type="button" class="btn btn-primary" data-toggle="modal" data-target="#reservationModal-1">
  Reservation 1
</button>

<button type="button" class="btn btn-primary" data-toggle="modal" data-target="#reservationModal-2">
  Reservation 2
</button>

<button type="button" class="btn btn-primary" data-toggle="modal" data-target="#reservationModal-3">
  Reservation 3
</button>

<div class="modal fade reservationModal" id="reservationModal-1" tabindex="-1" role="dialog" aria-labelledby="reservationModal-1" aria-hidden="true">
  <div class="modal-dialog" role="document">
    <div class="modal-content">
      <div class="modal-header">
        <h5 class="modal-title">Reservation 1</h5>
      </div>
    </div>
  </div>
</div>

<div class="modal fade reservationModal" id="reservationModal-2" tabindex="-1" role="dialog" aria-labelledby="reservationModal-2" aria-hidden="true">
  <div class="modal-dialog" role="document">
    <div class="modal-content">
      <div class="modal-header">
        <h5 class="modal-title">Reservation 2</h5>
      </div>
    </div>
  </div>
</div>

<div class="modal fade reservationModal" id="reservationModal-3" tabindex="-1" role="dialog" aria-labelledby="reservationModal-3" aria-hidden="true">
  <div class="modal-dialog" role="document">
    <div class="modal-content">
      <div class="modal-header">
        <h5 class="modal-title">Reservation 3</h5>
      </div>
    </div>
  </div>
</div>
&#13;
 daily_jobs= jobs.data;
&#13;
&#13;
&#13;

答案 1 :(得分:0)

向他们添加class,如下所示:

$('[id^="reservationModal-"]').addClass("reservationModal");

并使用此:

$(".reservationModal").on('shown.bs.modal', function (e) {
    console.log('works');
});

如果你想区分这些功能,你可以这样做:

$(".reservationModal").each(function() {
    var currentID = this.id;
    $(this).on('shown.bs.modal' function(e) {/*...*/});
});