質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
jQuery UI

jQuery UI はjQuery公式のインターフェースライブラリであり、対話型のウェブアプリケーションを作る際に役立ちます。

JSP

JSP(Java Server Pages)とは、ウェブアプリケーションの表示レイヤーに使われるサーバーサイドの技術のことです。

Java

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

Q&A

解決済

1回答

2687閲覧

jQueryのDialogメソッドについて

syncrock

総合スコア209

jQuery UI

jQuery UI はjQuery公式のインターフェースライブラリであり、対話型のウェブアプリケーションを作る際に役立ちます。

JSP

JSP(Java Server Pages)とは、ウェブアプリケーションの表示レイヤーに使われるサーバーサイドの技術のことです。

Java

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

0グッド

0クリップ

投稿2016/11/18 06:10

編集2016/11/18 09:15

jqueryのdialogを使用してmodal画面を表示させています。
やり方としてはiframeを利用して中身を随時変更して表示しています。

java

1html = "<iframe src='" + url + "' id='" + 指定したいId + "' frameborder='0' scrolling='auto'>"; 2$(html).dialog(高さなどのオプションを入れた変数);

ieやchromeでは特に問題なく動作しているのですが、
Firefoxの場合のみなぜか親画面の最下部に変なスペース(空白)が出来てしまいます。
そのせいでスクロールバーが親画面に表示されます。
dialogが表示されればスペースが表示され、閉じれば消えます。
iframeが中身は出ないものの画面下部に領域として確保されて出ている?
と思っていますが、どうなのでしょうか。
Firefoxのみこの現象になっており、解決策が見えません。。。
Firefoxでdialogを使用するにあたり何か注意点等ありますでしょうか?

---------------追記

display:blockをnoneに変更するともちろんダイアログは消えますが、
親画面のスペースも消えます。
やはり、ダイアログ分の領域が何故か画面下部に表示されているみたいなのですが、わかりますでしょうか。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

kei344

2016/11/21 02:08

書かれている状況が再現するコード(HTML/CSS/jsなど)か、再現するURLを提示されたほうが回答を得やすいと思います。
guest

回答1

0

ベストアンサー

Firefoxでiframe を使用するとなるのだと思います。
ダイアログでiframeを使うメリットがない気がします。
divではのほうが制御しやすいです。

投稿2016/11/18 12:57

himakuma

総合スコア952

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

syncrock

2016/11/21 00:14

回答ありがとうございます。 まだその事象についてネットでの記載を見つけられていませんが、 現状、何も回避策はないということでしょうか。
himakuma

2016/11/21 00:55

基本iframeを避けるので、その現象に陥ったことがないのですが、 埋め込み部分のソースもないとどんな状況で発生しているかが分からないです。 $(html)の部分は普通は埋め込み部分のID等を指定すると思うのですが、 変数htmlはどこかにappendしていますか? していない場合、もしかしたらBODYの最後、HTMLタグの外に生成されてしまっているかもです。
syncrock

2016/11/21 01:18

>HTMLタグの外に生成されてしまっているかもです。 その通りです。 appendしていないので、(おそらく)外に生成されています。 親画面の下に意味のない白い空白が出来ている感じです。 動的に内容を変えたかったのでネットでの内容を参考にiframeで行うようにしたのですが、対応不可ということでしょうか。。。
syncrock

2016/11/21 01:22

ちなみにiframeにした理由として、別ページとしたかったというのがあります。 dialogで表示したページの中で処理を行い親に返したいと思っておりました。
himakuma

2016/11/21 01:42

であればappendすれば直る気がします。 適当なappend用のタグを用意して(DIV等)、 そこにappendして、処理終了後に手動でそのタグ配下削除するようにしては? HTMLタグのルートタグ配下に他のタグを記載するのがHTMLのルールなので、 外に作られてしまっている場合は、回避不可です。(バグです)
syncrock

2016/11/21 02:18

divにappendするようにして、そのdivに対してdialogメソッドを実行しましたが変わらずでした。 変わらずHTML外に空白が出来てしまいました。。
himakuma

2016/11/21 02:25

iframe に対してdialogメソッドを実行しても駄目ですか?
syncrock

2016/11/21 04:10

同じでした。。
himakuma

2016/11/21 04:12

Firefoxの開発ツールで、空白部分の情報を見てみてください。 どうなってますか?
syncrock

2016/11/21 04:23

それがどこに当てても当たらないんです。 要素を選択しようとしても選択が出来ない状態です。
himakuma

2016/11/21 04:34

ダイアログ生成後にiframeを開発ツールから消すとどうなりますか?
syncrock

2016/11/21 05:05

iframeを消すと空白も消えました。 また、一応解決?なのかわかりませんが。 これまでpositionをrelativeにしていましたが、absoluteに変更し、topを0にすると問題なく表示されました。 (html外の空白が無くなりました。) なぜなくなったのかは、僕の知識ではまだわかっていませんが。。。
himakuma

2016/11/21 05:53

なんとなく分かりました。相対位置にしていたのを絶対位置に変更したので、 ブラウザの大きさに左右されなくなったのですね。 positionをrelativeの状態でブラウザのサイズを変更すると空白が狭まったりしませんか?
syncrock

2016/11/21 07:24

資料ありがとうございます。 位置の問題であればなぜiframeが上部に表示されているのにもかかわらず、iframe分の余白が下に出来てしまったのかが謎ですが。。。 >positionをrelativeの状態でブラウザのサイズを変更すると空白が狭まったりしませんか? 特に狭まったりというのは見受けられませんでした。
himakuma

2016/11/21 07:50

そうなると、挿入先のタグの問題な気がしますね。 全体が分からないですが、タグの階層や、CSSの問題ですね。
syncrock

2016/11/21 08:58

そうですね、そのような気がします。 こちらの記述の仕方が問題であると思いますので、一旦締めたいと思います。 やりとりありがとうございました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問