检查是否支持html元素

时间:2011-08-13 02:09:40

标签: javascript html browser-detection

如何检查是否支持html元素,例如datalist? MDC表示它仅在Opera和FireFox中被推销。

3 个答案:

答案 0 :(得分:19)

if ('options' in document.createElement('datalist')) {
    // supported!
}

http://diveintohtml5.info/everything.html#datalist

答案 1 :(得分:0)

如果有人需要检查是否支持其他HTML5元素,则也可以使用。

https://github.com/ryanmorr/is-element-supported

来自http://ryanmorr.com/determine-html5-element-support-in-javascript/

/*
 * isElementSupported
 * Feature test HTML element support 
 * @param {String} tag
 * @return {Boolean|Undefined}
 */

(function(win){
    'use strict';       

    var toString = {}.toString;

    win.isElementSupported = function isElementSupported(tag) {
        // Return undefined if `HTMLUnknownElement` interface
        // doesn't exist
        if (!win.HTMLUnknownElement) {
            return undefined;
        }
        // Create a test element for the tag
        var element = document.createElement(tag);
        // Check for support of custom elements registered via
        // `document.registerElement`
        if (tag.indexOf('-') > -1) {
            // Registered elements have their own constructor, while unregistered
            // ones use the `HTMLElement` or `HTMLUnknownElement` (if invalid name)
            // constructor (http://stackoverflow.com/a/28210364/1070244)
            return (
                element.constructor !== window.HTMLUnknownElement &&
                element.constructor !== window.HTMLElement
            );
        }
        // Obtain the element's internal [[Class]] property, if it doesn't 
        // match the `HTMLUnknownElement` interface than it must be supported
        return toString.call(element) !== '[object HTMLUnknownElement]';
    };

})(this);

答案 2 :(得分:0)

检查浏览器是否支持 HTMLDataListElement 接口:

if(typeof HTMLDataListElement === 'function') {
   // your code here      
} else {
  // your code here if this feature is not supported
}