ダイアログにはjQueryUIライブラリを使用できます。このように簡単です
1)ページ/レイアウトにjQuery UIライブラリ(CDN / LocalCopyから参照)への参照を追加します
<script src="https://ajax.googleapis.com/ajax/libs/jqueryui/1.8.16/jquery-ui.min.js" type="text/javascript"></script>
<link href="http://ajax.googleapis.com/ajax/libs/jqueryui/1.8.16/themes/base/jquery-ui.css" rel="stylesheet" type="text/css" />
2)リンクに特定のクラスを追加して、jQueryセレクターとして使用できるようにします
@Html.ActionLink("Email", "Details", "Customers", null, new { @class = "popupLinks" })
3)Diloag機能をDOMレディイベントのリンクにバインドします
<script type="text/javascript">
$(function(){
$(".popupLinks").click(function (e) {
var url = this.href;
var dialog = $("#dialog");
if ($("#dialog").length == 0) {
dialog = $('<div id="dialog" style="display:hidden"></div>').appendTo('body');
}
dialog.load(
url,
{}, // omit this param object to issue a GET request instead a POST request, otherwise you may provide post parameters within the object
function (responseText, textStatus, XMLHttpRequest) {
dialog.dialog({
close: function (event, ui) {
dialog.remove();
},
modal: true,
width: 460, resizable: false
});
}
);
return false;
});
});
</script>
リンクをクリックすると、コントローラーのDetails
アクションメソッドの結果の内容が表示されます。Customers
(シナリオに応じて変更できます)