23

ブートストラップモーダルでajaxを使用してデータを取得しようとしています:

<a href="{{ path('ajax_get_messages', { 'superCategoryID': 35, 'sex': sex }) }}" data-toggle="modal" data-target="#birthday-modal">
  <img src="{{ asset('bundles/yopyourownpoet/images/messageCategories/BirthdaysAnniversaries.png') }}" alt="Birthdays" height="120" width="109"/>
</a>

私のモーダル:

<div id="birthday-modal" class="modal hide fade">
<div class="modal-header">
    <button type="button" class="close" data-dismiss="modal" aria-hidden="true">&times;</button>
    <h3>Birthdays and Anniversaries</h3>
</div>
<div class="modal-body">

</div>
<div class="modal-footer">
    <a href="#" data-dismiss="modal" class="btn">Close</a>
    {#<button class="btn" data-dismiss="modal" aria-hidden="true">Close</button>#}
</div>
</div>

リンクをクリックすると、モーダルが表示されますが、本文は空です。その上、ajaxリクエストが行われているのを見ていません。Bootstrap2.1.1を使用しています

私は何が間違っているのですか?

4

3 に答える 3

41

一番多く投票された回答はBootstrap 3.3 で廃止され、 v4 で削除されます。代わりにこれを試してください:

JavaScript:

// Fill modal with content from link href
$("#myModal").on("show.bs.modal", function(e) {
    var link = $(e.relatedTarget);
    $(this).find(".modal-body").load(link.attr("href"));
});

Html (公式の例に基づいています。Bootstrap 3.*data-remote="false"では、非推奨の Bootstrap ロード機能を無効にするように設定していることに注意してください):

<!-- Link trigger modal -->
<a href="remoteContent.html" data-remote="false" data-toggle="modal" data-target="#myModal" class="btn btn-default">
    Launch Modal
</a>

<!-- Default bootstrap modal example -->
<div class="modal fade" id="myModal" tabindex="-1" role="dialog" aria-labelledby="myModalLabel" aria-hidden="true">
  <div class="modal-dialog">
    <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">
        ...
      </div>
      <div class="modal-footer">
        <button type="button" class="btn btn-default" data-dismiss="modal">Close</button>
        <button type="button" class="btn btn-primary">Save changes</button>
      </div>
    </div>
  </div>
</div>

自分で試してみてください: https://jsfiddle.net/ednon5d1/

于 2014-12-31T09:04:30.983 に答える
27

次のように Bootstrap 3 で簡単に実行できます。

<a data-toggle="modal" href="remote.html" data-target="#modal">Click me</a>
于 2013-09-08T18:34:23.630 に答える
20

これが私が問題を解決した方法です、いくつかに役立つかもしれません:

Ajaxモーダルはboostrap2.1.1では利用できないようです

だから私はそれを自分でコーディングすることになりました:

$('[data-toggle="modal"]').click(function(e) {
  e.preventDefault();
  var url = $(this).attr('href');
  //var modal_id = $(this).attr('data-target');
  $.get(url, function(data) {
      $(data).modal();
  });
});

モーダルを呼び出すリンクの例:

<a href="{{ path('ajax_get_messages', { 'superCategoryID': 6, 'sex': sex }) }}" data-toggle="modal">
    <img src="{{ asset('bundles/yopyourownpoet/images/messageCategories/BirthdaysAnniversaries.png') }}" alt="Birthdays" height="120" width="109"/>
</a>

モーダルマークアップ全体をajax経由で送信します。

drewjohへのクレジット

于 2013-02-20T09:02:18.647 に答える