时间:2021-07-01 10:21:17 帮助过:9人阅读
译文:HTML5特性检测
译者:dwqs
随 着HTML 5的流行,现在HTML 5占据了主要的市场份额,HTML 5增加了很多的新功能,这些新功能可以让Web体验变得更好。大多数特性在现代的主流浏览器中获得了支持,因此我们可以放心使用这些新特性来增加Web体 验。但是,当有新版本的浏览器发布时,我们不要忘记一些旧版本或者老的浏览器。
目前的另外一个事实是,用户想用旧版本的浏览器来支持新特性。因此建立的产品必须是跨浏览器的,而我们唯一能做的就是HTML5特性检测,来确保指定特性被浏览器支持时才执行代码。
Modernizr是 一个非常好的JS库,它可以完成对HTML 5和CSS 3的特性检测。默认情况下,modernizr会对所有特性进行检测(当然可以自定义),但如果你只想检测某一个特定功能而不像引入整个JS库,那你就得 把代码放在正确的位置。在这篇文章中,我们将会看到如何使用原生的js和modernizr来检测HTML 5 的特性。
// JSreturn !!document.createElement('canvas').getContext; // Modernizrif (Modernizr.canvas) {}
Video
// JSreturn !!document.createElement('video').canPlayType; // Modernizrif (Modernizr.video) { }
Local Storage
// JSreturn 'localStorage' in window && window['localStorage'] !== null; // Modernizrif (Modernizr.localstorage) { }
Web Workers
// JSreturn !!window.Worker; // Modernizrif (Modernizr.webworkers) { }
Offline Web Application
// JSreturn !!window.applicationCache; // Modernizrif (Modernizr.applicationcache) { }
Geolocation
// JSreturn 'geolocation' in navigator; // Modernizrif (Modernizr.geolocation) { }
// JSvar i = document.createElement('input');return 'placeholder' in i; // Modernizrif (Modernizr.input.placeholder) { }
// JSvar i = document.createElement('input');return 'autofocus' in i; // Modernizrif (Modernizr.input.autofocus) { }
Microdata
// JSreturn !!document.getItems; // Modernizr does not provide support to detect Microdata
// JSreturn !!(window.history && history.pushState); // Modernizrif (Modernizr.history) { }
到目前为止,这是我收集的特性检测的代码列表。如果你有特性检测的代码想要在列表中分享,也可以告诉我。
-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------
这里涵盖了Web开发,移动开发,Java等编程语言、综合资讯、SEO等名博,博客收录集地址:http://www.ido321.com/daohang/