iframe が HTML 内のページにジャンプするのを防ぎ、iframe を使用して WeChat Web バージョンをページに埋め込む方法

iframe が HTML 内のページにジャンプするのを防ぎ、iframe を使用して WeChat Web バージョンをページに埋め込む方法

私は、WinForm と HTML5 を組み合わせた小さなものを作りたいだけなのですが、突然、そこに WeChat の Web バージョンを埋め込むことに興味が湧いてきました。

さて、アイデアが浮かんだら、行動に移しましょう。最終的な効果は次のようになります。

当初は、ページに iframe を埋め込んで https://wx.qq.com を指すようにするつもりでしたが、あまりに無知だったため、WeChat ウェブバージョンが自動的にジャンプしてしまいました。結果は次のとおりです。

そこで、iframe リダイレクトを防ぐ方法をオンラインで検索しました。それは、iframe タグに security="restricted" と sandbox="" という 2 つの属性を追加するというものでした。前者はIEのjs無効化機能、後者はHTML5の機能です。

リダイレクトを防ぐには、 sandbox="allow-scripts allow-same-origin allow-popups"を使用します。しかし...結果は次のようになります:

その後、このジャンプは実際には元のページを閉じてからジャンプ ページを参照していることがわかりました。したがって、ページ終了イベント onbeforeunload を使用してジャンプを防ぐことができます。そこで、次のコードをページに追加します。

 document.body.onbeforeunload = 関数 (イベント) {
             var rel = "asdfawfewf";
             if (!window.event) {
                イベントの戻り値 = rel;
            } それ以外 {
                window.event.returnValue = rel;
             }
         };

その後、結果は依然として次のようになることがわかりました。

理由は何ですか?事件に対して何の反応もないのですか?それともWeChatウェブ版の飛躍が凄すぎるのでしょうか?この事件を無視するのですか?そこで、空の HTML を作成し、検証のためにこのイベントだけを追加しました。

<!DOCTYPE html> 
  <html lang="ja" xmlns="http://www.w3.org/1999/xhtml">
  <ヘッド>
      <メタ文字セット="utf-8" />
      <タイトル></タイトル>
  </head>
  <本文></本文>
  <スクリプト>
document.body.onbeforeunload = 関数 (イベント) {
    var rel = "asdfawfewf";
     if (!window.event) {
         イベントの戻り値 = rel;
     } それ以外 {
         window.event.returnValue = rel;
     }
 };
 </スクリプト>
 </html>

結果は実現可能です:

ただし、iframe をページに埋め込んだ後は直接ジャンプしてしまいます。次のコードを試してください。

<!DOCTYPE html> 
  <html lang="ja" xmlns="http://www.w3.org/1999/xhtml">
  <ヘッド>
      <メタ文字セット="utf-8" />
      <タイトル></タイトル>
  </head>
  <本文>
      <iframe src="https://wx.qq.com/" frameborder="0" style="position: absolute;border: navajowhite;left: 0;height: calc(100% - 30px);width:100%">
     </iframe>
 </本文>
 <スクリプト>
 document.body.onbeforeunload = 関数 (イベント) {
     var rel = "asdfawfewf";
     if (!window.event) {
         イベントの戻り値 = rel;
     } それ以外 {
         window.event.returnValue = rel;
     }
 };
 </スクリプト>
 </html>

困惑したとき、この方法をオンとオフに切り替えて、うまくいくかどうかを確認しました。突然、ページを開いてから短時間で閉じると、onbeforeunload イベントがトリガーされないことに気付きました。数秒待ってからページを閉じると、イベントがトリガーされ、プロンプトが表示されます。

さて、iframe を遅延させて src 値を割り当ててみます (ここでは JQuery が参照されています)。

<!DOCTYPE html>
  <html lang="ja" xmlns="http://www.w3.org/1999/xhtml">
  <ヘッド>
      <メタ文字セット="utf-8" />
     <タイトル></タイトル>
      <script src="scripts/jquery-2.2.3.js"></script>
  </head>
  <本文>
      <iframe id="iframe" frameborder="0" style="position: absolute;border: navajowhite;left: 0;height: calc(100% - 30px);width:100%">
     </iframe>
 </本文>
 <スクリプト>
 $(関数() {
     setTimeout(関数() {
         iframe.src = "https://wx.qq.com/";
     },5000);
 });
 document.body.onbeforeunload = 関数 (イベント) {
     var rel = "asdfawfewf";
     if (!window.event) {
         イベントの戻り値 = rel;
     } それ以外 {
         window.event.returnValue = rel;
     }
 };
 </スクリプト>
 </html>

結果は成功しました。このページを離れるかどうかを尋ねるプロンプトが表示されます。[滞在] ボタンをクリックします。成功への飛躍はありません。下の写真は完成品です。

完了です。チャットやファイルの転送は普通にできますが、スクリーンショットを撮ることはできません。

欠点は、ログインを完了するには、ポップアップのキャンセルボタンを 2 回クリックする必要があり、1 回目はページを開き、2 回目はコードをスキャンした後にページが再びジャンプすることです。現在、この問題を解決する方法はありません。この問題を解決する方法を知っている友人が私に何か提案してくれることを願っています。タイムリーに返信します。123WORDPRESS.COM ウェブサイトをサポートしていただき、誠にありがとうございます。

<<:  MySQL 永続統計の詳細な説明

>>:  JavaScript でのモグラ叩きゲームの実装

推薦する

よく使用される Linux コマンドの完全なリスト (推奨コレクション)

目次1. システム情報2. シャットダウン(システムのシャットダウン、再起動、ログアウト) 3. フ...

Homebrewを使用してMacにMySQLをインストールするときにログインできない問題を解決する

お使いのコンピュータが Mac の場合、homebrew を使用して MySQL をインストールする...

Vue はインターフェースのスライド効果を実装します

この記事では、インターフェースのスライド効果を実現するためのVueの具体的なコードを例として紹介しま...

MySQL インデックス プッシュダウン (ICP) の簡単な理解と例

序文Index Condition Pushdown (ICP) は、MySQL 5.6 の新機能で...

CentOS7でFTPサーバーを設定する方法

FTP は主にファイル転送に使用され、Linux では vsftpd で実装されるのが一般的です。F...

Nginx 構成の実装 https

目次1: https証明書を準備する2: nginx sslモジュールを準備する3: SSL証明書を...

ウェブページのカラーマッチングにおけるオーバーラップとソフトカラーマッチングの手法を詳しく説明

この記事には、細かい点は一切なく、カラーマッチングのテクニックをシェアするだけです。とてもシンプルで...

レスポンシブフレームワークのテーブルヘッダーの自動改行問題に対する簡単な解決策

最近、Bootstrap を使って Web サイトを開発しています。表を処理していたところ、PC で...

js タグ構文の使用法の詳細

目次1. ラベルステートメントの紹介2. ラベルステートメントの使用序文:日常の開発では、プログラム...

モバイルの赤い封筒の雨機能ページを実装するための JavaScript HTML

この記事の例では、モバイル紅包雨機能ページを実現するためのHTMLの具体的なコードを共有しています。...

MySQL 5.5 のインストールと設定のグラフィックチュートリアル

MySQL 5.5 のインストールと構成のチュートリアル ノートを整理し、全員と共有します。 1.公...

CSSは固定比率のブロックレベルコンテナを簡単に実装できる

H5 レイアウトを設計する場合、通常はバナーに遭遇することになります。例えば、2:1 で表示したい場...

無効にしてHTMLフォーム入力を送信した後にフォーム値が取得されない問題を解決する方法

フォーム入力ボックスの入力をdisable属性に設定して送信すると、入力ボックスの値を取得できなくな...

Linuxファイアウォールiptablesの詳細な紹介、設定方法と事例

1.1 iptablesファイアウォールの概要Netfilter/Iptables (以下、Ipta...

MySQL の起動オプションとシステム変数の例の詳細な説明

目次ブートオプションコマンドラインパラメータの長い形式と短い形式設定ファイル構成グループシステム変数...