ASP.NET MVCでJavaScript/jQueryを使って別ページにリダイレクトさせる
2023-10-29 02:45:19
質問
ASP.NET MVC 3.0でJavaScript/jQuery/Ajaxを使って、あるページから別のページにリダイレクトしたいのですが、どうすればいいですか?ボタンのクリックイベントで、私は以下のようなJavaScriptコードを書きました。
function foo(id)
{
$.post('/Branch/Details/' + id);
}
私のコントローラのコードはこのようなものです。
public ViewResult Details(Guid id)
{
Branch branch = db.Branches.Single(b => b.Id == id);
return View(branch);
}
ボタンをクリックするとBranchController内のDetailsアクションが呼び出されるのですが、Detailsビューに戻りません。
エラーや例外は発生していません。でステータス200 OKを表示しています。 Firebug . また、どのようにすれば詳細表示ページにリダイレクトできるのでしょうか?
どのように解決するのですか?
あなたは、$.post AJAXコールで成功コールバックを購読していません。 つまり、リクエストは実行されましたが、その結果については何もしていません。結果を使用して何か便利なことをしたい場合は、試してみてください。
$.post('/Branch/Details/' + id, function(result) {
// Do something with the result like for example inject it into
// some placeholder and update the DOM.
// This obviously assumes that your controller action returns
// a partial view otherwise you will break your markup
});
一方、リダイレクトをしたい場合は、絶対にAJAXは必要ありません。AJAXを使うのは、同じページにとどまり、その一部だけを更新したいときだけです。
つまり、ブラウザをリダイレクトさせたいだけなら
function foo(id) {
window.location.href = '/Branch/Details/' + id;
}
余談ですが このようなハードコーディングのURLは決して使ってはいけません。ASP.NET MVCアプリケーションでurlを扱うときは、常にurlヘルパーを使用すべきです。ですから
function foo(id) {
var url = '@Url.Action("Details", "Branch", new { id = "__id__" })';
window.location.href = url.replace('__id__', id);
}
関連
-
[解決済み】C#のequal to演算子でtextとvarcharのデータ型は互換性がない
-
[解決済み] あるJavaScriptファイルを他のJavaScriptファイルにインクルードするにはどうすればよいですか?
-
[解決済み] JavaScriptでJSONをきれいに印刷する
-
[解決済み] jQueryでページを更新するにはどうすればよいですか?
-
[解決済み] jQueryを使ってドロップダウンリスト(セレクトボックス)から選択されたテキストを取得する
-
[解決済み] JavaScriptでドロップダウンリストの選択値を取得する
-
[解決済み] jQueryを使ったAjaxリクエストの中断
-
[解決済み] JavaScriptでページの一番上までスクロールする?
-
[解決済み] jQueryでフォームデータをJavaScriptオブジェクトに変換する
-
[解決済み] ファイルアップロード ASP.NET MVC 3.0
最新
-
nginxです。[emerg] 0.0.0.0:80 への bind() に失敗しました (98: アドレスは既に使用中です)
-
htmlページでギリシャ文字を使うには
-
ピュアhtml+cssでの要素読み込み効果
-
純粋なhtml + cssで五輪を実現するサンプルコード
-
ナビゲーションバー・ドロップダウンメニューのHTML+CSSサンプルコード
-
タイピング効果を実現するピュアhtml+css
-
htmlの選択ボックスのプレースホルダー作成に関する質問
-
html css3 伸縮しない 画像表示効果
-
トップナビゲーションバーメニュー作成用HTML+CSS
-
html+css 実装 サイバーパンク風ボタン
おすすめ
-
[解決済み] [Solved] 1つ以上のエンティティで検証に失敗しました。詳細は'EntityValidationErrors'プロパティを参照してください [重複]。
-
[解決済み】WebForms UnobtrusiveValidationModeは、jqueryのScriptResourceMappingを必要とする
-
[解決済み】プロジェクトビルド時のエラー。エディタでスクリプトにコンパイルエラーがあるため、Playerのビルドにエラーが発生する
-
[解決済み】非静的メソッドはターゲットを必要とする
-
[解決済み】リソースの読み込みに失敗した:ステータス500(内部サーバーエラー)のサーバーの応答)
-
[解決済み】C# - パスに不正な文字がある場合
-
[解決済み】EF 5 Enable-Migrations : アセンブリにコンテキストタイプが見つかりませんでした
-
[解決済み】2つ(またはそれ以上)のリストを1つに統合する(C# .NETで
-
[解決済み] 2つのリストを結合する
-
VSでscanfエラーを恒久的に解決するには、ソースファイルを作成し、自動的に#define _CRT_SECURE_NO_WARNINGS 1を追加してください。