JavaScript:子ウィンドウから親ウィンドウを再読み込みさせる方法

ことの起こり

Webの画面では、新規入力をしようとすると、別ウィンドウ=子ウィンドウが開いて入力し、登録ボタンを押すと、子ウィンドウが閉じる仕組みがある。

子ウィンドウが閉じるだけなら問題ないが、一覧表があって、子ウィンドウが閉じたら、登録された内容を反映したいときがある。

 

子ウィンドウが閉じるときに、JavaScript

window.opener.location.reload();
window.close();

とすれば、 親ウィンドウは再読込みされて、子ウィンドウは閉じられる。

 

これで問題なければいいが、今回は親ウィンドウ側に検索機能があって、POSTパラメータで処理をしていた。

そのため、同じことをすると、再読み込みの警告が表示されて、いちいちメッセージのOKをクリックしなくてはならなかった。

GETパラメータで処理していれば、発生しない現象なんだけど。

 

対処方法

対処の仕方は簡単で、子ウィンドウから親ウィンドウの検索のformをsubmitすれば、警告は表示されないで、検索が行われる。

JavaScriptは、

window.opener.$("#search").submit();
window.close();
とすれば子ウィンドウから親ウィンドウのformをsubmitできる。
jQueryを使う書き方で書いたが、getElementById()でも大丈夫なはずだ。
 
 
 こういった内容は、自分のネタ帳に入れておくと、忘れたときに役に立つ。
posted @ 2014-06-23 20:38  依然神思者  阅读(1613)  评论(0编辑  收藏  举报