browser-feature-detection

How can I detect CSS Variable support with JavaScript?

对着背影说爱祢 提交于 2019-12-03 07:54:39
问题 The latest version of Firefox has support for CSS Variables, but Chrome, IE and loads of other browsers do not. It should be possible to access a DOM Node or write a little method which returns whether the browser supports this feature, but I haven't been able to find anything which is currently able to do this. What I need is a solution which I can use as condition to run code if the browser does not support the feature, something like: if (!browserCanUseCssVariables()) { // Do stuff... }

How can I detect CSS Variable support with JavaScript?

本小妞迷上赌 提交于 2019-12-02 21:35:19
The latest version of Firefox has support for CSS Variables , but Chrome, IE and loads of other browsers do not. It should be possible to access a DOM Node or write a little method which returns whether the browser supports this feature, but I haven't been able to find anything which is currently able to do this. What I need is a solution which I can use as condition to run code if the browser does not support the feature, something like: if (!browserCanUseCssVariables()) { // Do stuff... } James Donnelly We can do this with CSS.supports . This is the JavaScript implementation of CSS's

IE9-11 detecting transform-style: preserve-3d

喜你入骨 提交于 2019-12-02 04:35:38
问题 I made a 3d sort of menu for a project and naturally IE is causing problems, because IE10+, even though 3d-transforms work, does not support transform-style: preserve-3d. I tried the workaround methods, by applying transforms to each child element of the 3d menu container, but the animations look awful, to say the least. Deciding to drop 3d entirely for IE, but without the ability to use conditional stylesheets for IE10+, I tried detecting the preserve-3d property value this way: var detect =

IE9-11 detecting transform-style: preserve-3d

拈花ヽ惹草 提交于 2019-12-02 01:28:48
I made a 3d sort of menu for a project and naturally IE is causing problems, because IE10+, even though 3d-transforms work, does not support transform-style: preserve-3d. I tried the workaround methods, by applying transforms to each child element of the 3d menu container, but the animations look awful, to say the least. Deciding to drop 3d entirely for IE, but without the ability to use conditional stylesheets for IE10+, I tried detecting the preserve-3d property value this way: var detect = document.createElement("div"); detect.style.transformStyle = "preserve-3d"; if (detect.style

Feature detection solution for window.print() JavaScript

江枫思渺然 提交于 2019-12-01 16:25:21
Question Is there any way to detect support for window.print()? I'd prefer to detect the feature itself vs trying to go down the rabbit hole of detecting whether I'm on a mobile browser or desktop or iOS or Android or which particular mobile browser I might be on. Background The following links lead me to believe that: Apple requires all 3rd party browsers to use UIWebView UIWebView as used in non-Safari apps does nothing when you run window.print() Safari on iOS does something appropriate when you run window.print() The links: https://productforums.google.com/forum/#!topic/chrome/7wTj1dteSeI

Feature detection solution for window.print() JavaScript

亡梦爱人 提交于 2019-12-01 16:05:05
问题 Question Is there any way to detect support for window.print()? I'd prefer to detect the feature itself vs trying to go down the rabbit hole of detecting whether I'm on a mobile browser or desktop or iOS or Android or which particular mobile browser I might be on. Background The following links lead me to believe that: Apple requires all 3rd party browsers to use UIWebView UIWebView as used in non-Safari apps does nothing when you run window.print() Safari on iOS does something appropriate

Feature detecting support for svg filters

爱⌒轻易说出口 提交于 2019-12-01 08:25:42
问题 I need to feature detect whether a browser supports svg filters (feGaussianBlur, to be specific). How would I go about testing for this? Safari, which doesn't support the filter, silently ignores the filter. 回答1: You could probably also check the enums available on the interfaces, e.g: var supportsfilter = typeof SVGFEColorMatrixElement !== undefined && SVGFEColorMatrixElement.SVG_FECOLORMATRIX_TYPE_SATURATE==2; That way you won't have to construct new elements, as in https://stackoverflow

Detect different kind of scrollbars (eg. normal / hidden osx)

和自甴很熟 提交于 2019-11-30 19:31:07
Using responsive Layout and a lot of CSS to create a Webpage, I am having a problem with scrollbars being hidden or shown and changing the layout by 17px. The main problem is that on OSX the scrollbars hover over the entire Layout without affecting it, but in any browser on Windows for example the scrollbar is part of the layout and therefore moving it to the left by its width of 17px. Trying to solve this I started to detect browsers like: if($.browser.chrome) { // adapt layout by 17px } else if ($.browser.mozilla) { // adapt layout by 17px } else if ($.browser.safari) { // dont adapt layout

Javascript: How can I delay returning a value for img.complete

主宰稳场 提交于 2019-11-30 15:39:42
I've written a script to test for SVG support in the IMG tag: function SVGinIMG() { var SVGdata = '%3D' var i = document.createElement('img'); i.setAttribute('src',SVGdata); return i.complete; } window.onload = function() { var hasSVG = SVGinIMG(); alert(hasSVG); } This does what I want, except that when I run the script in WebKit browsers the complete property doesn't trigger the first time I load the page; when I refresh the page, it works as it should. The return function

How can I feature-detect CSS filters?

安稳与你 提交于 2019-11-30 12:51:46
问题 In some browsers, including Chrome stable, you can do this: h3 { -webkit-filter: grayscale(1); filter: grayscale(1); } And wouldn’t you know it, the h1 will be rendered completely in grayscale. Everything old is new again. Anyway — does anyone know of any way to feature-detect for this? I need to be able to apply other styles if fil filter won’t work. 回答1: So called UPDATED answer: As the OP mentioned a good point I'm updating the answer but this does not have anything related or in