> 웹 프론트엔드 > JS 튜토리얼 > Duck Typing을 사용하여 Safari, Chrome, Firefox, IE 및 Opera 브라우저를 안정적으로 감지하려면 어떻게 해야 합니까?

Duck Typing을 사용하여 Safari, Chrome, Firefox, IE 및 Opera 브라우저를 안정적으로 감지하려면 어떻게 해야 합니까?

DDD
풀어 주다: 2024-12-18 13:41:16
원래의
582명이 탐색했습니다.

How Can I Reliably Detect Safari, Chrome, Firefox, IE, and Opera Browsers Using Duck Typing?

Duck-Typing으로 Safari, Chrome, IE, Firefox 및 Opera 브라우저 감지

리디렉션을 위해 사용자의 브라우저를 확인해야 하는 경우가 많습니다. 브라우저별 확장 프로그램에 대한 적절한 다운로드 링크로 이동하세요. 그러나 브라우저 감지를 위해 사용자 에이전트 문자열에 의존하는 것은 스푸핑에 취약하기 때문에 신뢰할 수 없습니다.

더크 타이핑(duck-typing)이라는 보다 안정적인 방법을 사용하면 특정 특성을 기반으로 브라우저를 식별할 수 있습니다. 자세한 내용은 다음과 같습니다.

Opera 8.0 :

var isOpera = (!!window.opr && !!opr.addons) || !!window.opera || navigator.userAgent.indexOf(' OPR/') >= 0;
로그인 후 복사

Firefox 1.0 :

var isFirefox = typeof InstallTrigger !== 'undefined';
로그인 후 복사

Safari 3.0 :

var isSafari = /constructor/i.test(window.HTMLElement) || (function (p) { return p.toString() === "[object SafariRemoteNotification]"; })(!window['safari'] || (typeof safari !== 'undefined' && window['safari'].pushNotification));
로그인 후 복사

Internet Explorer 6~11:

var isIE = /*@cc_on!@*/false || !!document.documentMode;
로그인 후 복사

Edge 20 :

var isEdge = !isIE && !!window.StyleMedia;
로그인 후 복사

크롬 1 - 79:

var isChrome = !!window.chrome && (!!window.chrome.webstore || !!window.chrome.runtime);
로그인 후 복사

Edge(크롬 기반) 감지:

var isEdgeChromium = isChrome && (navigator.userAgent.indexOf("Edg") != -1);
로그인 후 복사

블링크 엔진 감지:

var isBlink = (isChrome || isOpera) && !!window.CSS;
로그인 후 복사

이러한 방법을 사용하여 브라우저를 감지하면 사용자를 리디렉션할 수 있습니다.

그러나 브라우저별 설치 지침 표시와 같이 필요한 경우에만 브라우저 감지를 사용해야 한다는 점을 강조하는 것이 중요합니다. 일반적인 모범 사례로서 가능할 때마다 기능 감지에 중점을 둡니다.

위 내용은 Duck Typing을 사용하여 Safari, Chrome, Firefox, IE 및 Opera 브라우저를 안정적으로 감지하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿