遭遇したいくつかのブラウザ互換性の問題について簡単に説明します

遭遇したいくつかのブラウザ互換性の問題について簡単に説明します

背景

ブラウザの互換性の問題を解決するのは非常に面倒なことです。高度な技術はそれほど必要ありませんが、開発のニーズに応じて解決する必要があります。最近、開発プロジェクトでいくつかの互換性の問題に遭遇しました。これらの問題の解決策を記録しておき、次回同じ問題に遭遇したときに直接使用したいと考えています。また、他の人にも役立つことを願っています。

互換性の問題と解決策

1. Object-fitはIE11およびEdgeと互換性がありません。いくつかのCSSハックを使用できます。

画像のスタイルを設定するには、object-fitの代わりにbackground-sizeとbackground-positionを使用します。

<img class="loadingImage" src="url"/>
.loadingImage{
    幅: 100%;
    高さ: 100%;
    遷移: すべて 1 の緩和;
    オブジェクトフィット: カバー;
  }

上記のコードは次のように変更できます。

<div class="loadingImage"></div>
.loadingImage{
    幅: 100%;
    高さ: 100%;
    背景サイズ: カバー;
    背景の位置: 中央;
    背景画像: url(url);
}

ビデオ再生の場合、object-fit:cover を使用すると、ビデオが画面に合わせて拡大縮小されない問題を解決できます。

<ビデオクラス="ビデオ"></ビデオ>
。ビデオ {
  幅: 100%;
  高さ: 自動;
  位置: 相対的;
  左: 50%;
  上位: 50%;
  変換: translate(-50%, -50%);
  オブジェクトフィット: カバー;
}

次の CSS を使用してビデオ タグを設定すると、object-fit が IE および Edge と互換性がない問題を解決できます。

<ビデオクラス="ビデオ"></ビデオ>
。ビデオ {
  幅: 100%;
  高さ: 自動;
  位置: 相対的;
  左: 50%;
  上位: 50%;
  変換: translate(-50%, -50%);
  オブジェクトフィット: 塗りつぶし;
}

2. window.onloadイベントは、画像やその他のリソースが読み込まれた後にメソッドを実行しますが、ビデオリソースが読み込まれたかどうかは検出しません。次のコードを使用して、ビデオが読み込まれたかどうかを検出できます。

<ビデオ id="ビデオ"></ビデオ>
ビデオを document.getElementById('ビデオ') に設定します。
ビデオの準備状態が 4 の場合
    console.log('完了!')
}

3. CSSトランジションが実行されると、transitionendイベントがトリガーされますが、互換性があります。次のコードを使用して、ブラウザ間の互換性を解決できます。

関数 checkTransitionEvent() {
  var el = document.createElement('div')
  var 遷移 = {
    '遷移':'遷移終了',
    'OTransition':'oTransitionEnd',
    'MozTransition':'遷移終了',
    'WebkitTransition':'webkitTransitionEnd'
  }

  for(t in transitions){
      if(el.style[t] !== 未定義){
          transitions[t]を返します。
      }
  }
}

4. オンホイールイベントの互換性

サポート() {
  let support = "onwheel" in document.createElement("div") ? "wheel" : // 最近のブラウザは "wheel" をサポートしています
    document.onmousewheel !== undefined ? "mousewheel" : // Webkit と IE は少なくとも "mousewheel" をサポートしています
    "DOMMouseScroll";
  返品サポート
},

5. ホイールイベントのwheelDelta属性とdetail属性は、ブラウザによって値が異なります。次のコードを使用して正規化できます。https://stackoverflow.com/questions/5527601/normalizing-mousewheel-speed-across-browsersを参照してください。

var ホイール距離 = function(evt){
  if (!evt) evt = イベント;
  var w = evt.wheelDelta、d = evt.detail;
  もし(d){
    if (w) return w/d/40*d>0?1:-1; // オペラ
    そうでない場合は -d/3 を返します。 // Firefox; TODO: OS X では /3 を実行しないでください。
  } else return w/120; // IE/Safari/Chrome TODO: Chrome OS X の場合は /3
};

var ホイール方向 = function(evt){
  if (!evt) evt = イベント;
  戻り値 (evt.detail<0) ? 1 : (evt.wheelDelta>0) ? 1 : -1;
};

6. requestAnimationFrameの互換性

cancelAnimationFrame = window.cancelAnimationFrame とします。 
  || window.mozCancelAnimationFrame 
  || 関数(id) { clearTimeout(id) };
requestAnimationFrame = window.requestAnimationFrame とします。 
  || window.mozRequestAnimationFrame || window.webkitRequestAnimationFrame 
  || window.msRequestAnimationFrame
  || 関数 (コールバック) { return setTimeout(コールバック, 1000 / 60) };

以上がこの記事の全内容です。皆様の勉強のお役に立てれば幸いです。また、123WORDPRESS.COM を応援していただければ幸いです。

<<:  MySQL複合インデックスの詳細な研究

>>:  XHTML Web ページ チュートリアル

推薦する

JavaScript を使用して QR コードを解析する 3 つの方法

目次1. JavaScriptを使用してQRコードを解析する1. QR コードとは何ですか? 2.q...

HTML フローティング フレーム (iframe 読み込み HTML) の設定と使用の例

コードをコピーコードは次のとおりです。 <!DOCTYPE html PUBLIC "...

Vue プロジェクトでの支払い機能の実装 (WeChat 支払いと Alipay 支払い)

目次プロジェクトにおける一般的な支払い方法Alipay決済微信ペイプロジェクトにおける一般的な支払い...

Linux で開いているポートへのリモート アクセスを許可する方法

1. ファイアウォール設定ファイルを変更する # vi /etc/sysconfig/iptable...

HTML マルチヘッダーテーブルコード

1. マルチヘッダーテーブルコードコードをコピーコードは次のとおりです。 <!DOCTYPE ...

Vueはマーキースタイルのテキストの水平スクロールを実装します

この記事では、マーキースタイルのテキストの水平スクロールを実現するためのVueの具体的なコードを参考...

ミニプログラムは左スライドのドロワーメニューをネイティブに実装します

目次WXS レスポンス イベントプランAページ構造とスタイルWXS イベントコールバック関数WXS ...

mysql IS NULL インデックスケースの説明を使用する

導入MySQL の SQL クエリ ステートメントで is null、is not null、!= ...

Vue2.0でデータの双方向バインディング機能をjsを使って実装する

Object.definePropertyの理解文法:オブジェクト.defineProperty(o...

html 内の絶対パス URL と相対パス URL、サブディレクトリ、親ディレクトリ、ルート ディレクトリ

絶対 URL は、インターネット上の特定のファイルに必要なすべてのコンテンツを表すために使用されます...

JavaScript での実行コンテキストと実行スタックの例の説明

JavaScript - 原則シリーズ日常の開発では、既存のプロジェクトを引き継ぐときは常に、まず他...

シェアしたい絶妙なApple風無料アイコン素材18セット

Apple マグカップのアイコンと追加機能 HD ストレージボックス – アドオンパックセイバースノ...

vueプロジェクトのマルチ環境設定(.env)の実装

目次マルチ環境構成とは何ですか? また、なぜそれが必要なのですか? .env ファイルはどこで設定さ...

Vue のライフサイクルとフック関数

目次1.ライフサイクルとは何か2. Vueのライフサイクル3. ライフサイクルフック関数1.ライフサ...

CentOS 7 に mysql5.7 の解凍バージョンをインストールするチュートリアル

1. mysqlの圧縮パッケージを/usr/localフォルダに解凍し、名前をmysqlに変更します...