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

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

ただいまの
回答率

90.61%

  • JavaScript

    16005questions

    JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

postmassageで子から親へ複数の値を渡す

受付中

回答 1

投稿 編集

  • 評価
  • クリップ 0
  • VIEW 132

ysfree14

score 1

親のhtmlで別サーバーのiframeを読み込ませています。

子から親へ複数の値を渡して、親でそれぞれ別に取り出すことはできるのでしょうか?

現状iframeの高さを取得して親側で自動調整しているのですが、別でiframe内の上部からhogeまでの数値を取得して親に渡したいと考えています。
親側にどのように記載すればいいのか分からない状況です。

■子

html
<p id="hoge"><img src="" alt=""></p>

JS
<script>
     window.onload = function() {

        //高さを取得
        var height = document.getElementsByTagName("body")[0].scrollHeight;
        window.parent.postMessage(["setHeight", height], "*");

        //ページ上からhogeまでの距離を取得
        var clientRect = document.getElementById("hoge").getBoundingClientRect() ;
        var scroll = clientRect.top ;
        window.parent.postMessage(['scroll', scroll], "*");

    }
</script>

■親

html
<div id="fugapage">
<iframe src="iframeのソース" frameborder="0" width="100%" height="100%" id="fugapage-frame"></iframe>
</div>

<div id="button"></div>

JS
<script>
       var src = jQuery("#fugapage-frame").attr("src");
    jQuery("#fugapage-frame").attr("src","");
    jQuery("#fugapage-frame").attr("src",src);

    window.addEventListener('message', function(e) {
    var iframe = jQuery("#fugapage");
    var eventName = e.data[0];
    var data = e.data[1];
    switch(eventName) {
        case 'setHeight':
            iframe.height(data);
            break;
        case 'scroll':    
            jQuery('#button').on('click',function(){
                var scrollHeight = e.data[1];
                var frameoff = jQuery('#fugapage').offset();
                var _frameoff = frameoff.top;
                var total = _frameoff + scrollHeight;
                jQuery("html,body").animate({scrollTop:total - 120});
            });
        }
    }, false);
</script>


よろしくお願い致します。

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

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

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

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

質問への追記・修正、ベストアンサー選択の依頼

  • mts10806

    2018/04/26 15:35

    親子両方のhtmlを提示願います。

    キャンセル

  • ysfree14

    2018/04/26 18:20

    html追記いたしました、よろしくお願い致します。

    キャンセル

回答 1

+2

ただの決めの問題なので、[ '機能名', データ ] という配列を渡すと決めているのなら、それに統一すればいいのではないでしょうか?

window.parent.postMessage(['scroll', scroll], "*");


        switch(eventName) {
            case 'setHeight':
                iframe.height(data);
                break;
            case 'scroll':
                // 処理

                break;
        }

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2018/04/27 14:30 編集

    ご回答ありがとうございます。自分で記述した部分を追記致しました。
    上記の方法で実装することができました。

    ただスマホの場合、リロードすると動作しません。
    初回表示時には上記の記述で動作するのですが。
    キャッシュか何かが影響しているのでしょうか?

    キャンセル

  • 2018/04/27 17:28

    追記箇所を見ましたが、本当にPCで動いているでしょうか?
    あと、子が更新されていないようです。

    キャンセル

  • 2018/04/27 18:16

    子の部分更新致しました。
    こちらで動作はしているのですが、問題点などはありますか?

    キャンセル

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

  • ただいまの回答率 90.61%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

  • 解決済

    Jquery部分作動せず 信号制作

    信号制作で クリック、青三秒点灯、青三秒点滅、からの黄色二秒点灯、最後に赤五秒点灯させたいのですがJQueryで書いた部分、青点滅終了と黄色点灯開始が反応しません。なぜでしょうか?

  • 解決済

    jQueryでの年計算について

    jQueryでプルダウンの年計算を作っているのですがどうしてもわからないところがあります。 $(function() { for (var i = 2017; i >= 190

  • 解決済

    範囲内で表示されるアンカーリンクをjqueryで作る

    スクロールでnavからfooterの間のみで表示されるアンカーリンクをjQueryで作成したいです。 途中まで作成したのですが、上スクロールをした際にnavで消えないので、どなたか

  • 解決済

    自分のWebページに指定したURLのページを表示する

    前提・実現したいこと Webページを自分で作って、2行目以降に指定したURLのページを表示するWebページを作ることはできないでしょうか。 発生している問題・エラーメッセージ

  • 受付中

    ページトップにスクロールできません

    実装したい内容・問題点 ・jQueryを用いてページの一番上までスクロールするボタンを作成したい ・https://syncer.jp/jquery-to-top-buttonやh

  • 解決済

    javascript classがうまく付与されない

    javascript初心者なためどうしても解決できず質問しました。 パララックス サイトを構築しておりました。 参考url http://histerian.net/pallax/

  • 受付中

    jQuery 一定のスクロール範囲が複数ある場合

     前提・実現したいこと https://www.goodfind.jp/2019/seminar/date こちらのページの日付部分のような、スクロールしていくと次の日の日付に切り

  • 解決済

    jQueryで配列のソートをしたい

     前提・実現したいこと jQueryで配列のソート機能を実現したい 配列に入ったそれぞれの値を下記のように昇順にソートしたいです。 「1」「2」「3」 ↓ 「3」「2」「1

同じタグがついた質問を見る

  • JavaScript

    16005questions

    JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。