ユーザー エージェント スニッフィングは、ブラウザ検出の最も一般的なアプローチです。残念ながら、さまざまな理由により、フロントエンド開発にはあまりアクセスしにくいです。ブラウザ ベンダーは常にスニッフィングを不可能にしようとしています。したがって、各ブラウザには独自のユーザー エージェント文字列形式があり、解析が非常に複雑です。
ブラウザ CSS API を使用して同じことを実現する、より簡単な方法があります。それを紹介します。それでは、ブラウザ機能の検出 React フックを作成しましょう。
CSS.supports() 静的メソッドを使用します。ブラウザーが特定の CSS 機能をサポートしているかどうかを示すブール値を返します。これは @supports at-rule に似た JavaScript です。メディア クエリと同様に機能しますが、CSS 機能が主題となります。
サポートされている機能を検出するためのフック
コンポーネントのレンダリング サイクル中に CSS.supports() を呼び出すという最も単純なアプローチでは、Next.js などのサーバー サイド レンダリング環境で問題が発生します。サーバー側レンダラはブラウザ API にアクセスできないため、コード文字列を生成するだけです。
import type {FC} from 'react'; const Component: FC = () => { // ? Don't do this! const hasFeature = CSS.supports('your-css-declaration'); // ... }
代わりにこの単純なフックを使用します。フックは、検証する CSS ルールである サポート条件 を含む文字列を受け取ります。ディスプレイ: フレックス
import {useState, useEffect} from 'react'; export const useSupports = (supportCondition: string) => { // Create a state to store declaration check result const [checkResult, setCheckResult] = useState<boolean undefined>(); useEffect(() => { // Run check as a side effect, on user side only setCheckResult(CSS.supports(supportCondition)); }, [supportCondition]); return checkResult; }; </boolean>
これで、React コンポーネント内からさまざまな CSS 機能のサポートを確認できるようになりました。 MDN @supports リファレンスはこちらです
import type {FC} from 'react'; const Component: FC = () => { // Check for native `transform-style: preserve` support const hasNativeTransformSupport = useSupports(' (transform-style: preserve) '); // Check for vendor prefixed `transform-style: preserve` support const hasNativeTransformSupport = useSupports(' (-moz-transform-style: preserve) or (-webkit-transform-style: preserve) '); // ... }
CSSサポート条件を利用してユーザーブラウザを検出
ユーザーのブラウザを検出するには、ちょっとしたハッキングを行う必要があります。
ブラウザのハッキングは法律違反とは何の関係もありません。これは、利用可能なブラウザのいずれかで動作が異なる単なる特別な CSS 宣言またはセレクターです。
これは、ブラウザーのさまざまなハックに関するリファレンス ページです。私のマシンで徹底的に実験した結果、次のものを選択しました:
const hacksMapping = { // anything -moz will work, I assume firefox: '-moz-appearance:none', safari: '-webkit-hyphens:none', // tough one because Webkit and Blink are relatives chrome: ' not (-webkit-hyphens:none)) and (not (-moz-appearance:none)) and (list-style-type:"*"' }
そして、最終的なフックは次のようになります:
export const useDetectBrowser = () => { const isFirefox = useSupports(hacksMapping.firefox); const isChrome = useSupports(hacksMapping.chrome); const isSafari = useSupports(hacksMapping.safari); return [ {browser: 'firefox', condition: isFirefox}, {browser: 'chromium based', condition: isChrome}, {browser: 'safari', condition: isSafari}, ].find(({condition}) => condition)?.browser as 'firefox' | 'chromium based' | 'safari' | undefined; };
完全なデモ
これはフックの完全に動作するデモです。
最終的な考え
これが完璧で安定したアプローチであるとは言えません。ブラウザは更新され、ベンダーのプロパティは標準によって放棄されたり置き換えられたりすることが非常に頻繁にあります。同時に、ユーザー エージェント スニッフィングについても次のことが言えます。どちらの方法でも同様の問題があります。ただし、CSS.contains() の方が保守が簡単で、より粒度が細かいです。開発者がグレースフル デグラデーションまたはプログレッシブ エンハンスメント アプローチを使用し、パッチをきめ細かく適用することを歓迎します。
以上がブラウザとその機能を検出するための単純な React フックを作成してみましょうの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

CSSグリッドは、複雑で応答性の高いWebレイアウトを作成するための強力なツールです。設計を簡素化し、アクセシビリティを向上させ、古い方法よりも多くの制御を提供します。

記事では、レスポンシブデザインにおけるスペースの効率的なアラインメントと分布のためのレイアウト方法であるCSS FlexBoxについて説明します。 FlexBoxの使用量を説明し、CSSグリッドと比較し、ブラウザのサポートを詳細に説明します。

この記事では、ビューポートメタタグ、柔軟なグリッド、流体メディア、メディアクエリ、相対ユニットなど、CSSを使用してレスポンシブWebサイトを作成するための手法について説明します。また、CSSグリッドとフレックスボックスを使用してカバーし、CSSフレームワークを推奨しています

この記事では、要素の寸法の計算方法を制御するCSSボックスサイズのプロパティについて説明します。コンテンツボックス、ボーダーボックス、パディングボックスなどの値と、レイアウト設計とフォームアライメントへの影響について説明します。

記事では、CSS、キープロパティ、およびJavaScriptとの組み合わせを使用してアニメーションの作成について説明します。主な問題は、ブラウザの互換性です。

記事では、3D変換、主要なプロパティ、ブラウザの互換性、およびWebプロジェクトのパフォーマンスに関する考慮事項にCSSを使用して説明します。

この記事では、CSSグラデーション(線形、放射状、繰り返し)を使用して、ウェブサイトのビジュアルを強化し、深さ、フォーカス、および現代の美学を追加します。

記事では、CSSの擬似要素、HTMLスタイリングの強化における使用、および擬似クラスとの違いについて説明します。実用的な例を提供します。


ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

Video Face Swap
完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

人気の記事

ホットツール

MinGW - Minimalist GNU for Windows
このプロジェクトは osdn.net/projects/mingw に移行中です。引き続きそこでフォローしていただけます。 MinGW: GNU Compiler Collection (GCC) のネイティブ Windows ポートであり、ネイティブ Windows アプリケーションを構築するための自由に配布可能なインポート ライブラリとヘッダー ファイルであり、C99 機能をサポートする MSVC ランタイムの拡張機能が含まれています。すべての MinGW ソフトウェアは 64 ビット Windows プラットフォームで実行できます。

EditPlus 中国語クラック版
サイズが小さく、構文の強調表示、コード プロンプト機能はサポートされていません

AtomエディタMac版ダウンロード
最も人気のあるオープンソースエディター

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 英語版
推奨: Win バージョン、コードプロンプトをサポート!

ホットトピック









