本文 翻译 自Steve Fulton & am p; Jeff Fulton HTML5 canvas , Chapter 1, [ test ing to See Whether the br owser Supports Canvas].
在获取HT ML 页面上Canvas元素的引用后,我们需要测试一下该元素 是否 包含[上下文](context)。Canvas的上下文指的是由浏览器定义的用于绘画的平面。 简单 地说,如果上下文不存在的话,Canvas也就名存实亡了。测试浏览器是否支持Canvas有好 几种 方法。第一种方法是检查HTML页面中Canvas元素的getContext方法是否存在:
复制代码
代码如下:
if (!theCanvas || !theCanvas.getContext) {
return;
}
事实上,上述代码测试了两点:其一,测试了theCanvas是否为false(如果id不存在的话,document.getElementById()会返回false);其二,测试了getContext()函数是否存在。
在上述代码中,如果测试失败,那么return语句执行,程序终止。
另一种方法是创建一个专门用于判断Canvas是否得以支持的函数,而在该函数中,实时生成一个Canvas元素来进行这种判断 — 这种方法很流行,Mark Pilgrim在他的HTML5网站http://div ei ntohtml5. org 中提到了这种 方案 :
复制代码
代码如下:
function canvasSupport() {
return !!document.createElement('canvas').getContext;
}
function canvasApp() {
if (!canvasSupport()) {
return;
}
}
我们最钟爱的方法是使 用M odernizr.js库(在http://www.modernizr .COM 中可以找到)。Modernizr是一个简单易用的轻量级JavaScript库,用于测试各种Web技 术 的兼容性 — 它提供了很多静态的Boolean方法,可以用来测试当前Canvas是否得到支持。
在HTML页面中引入modernizr很简单,从http://www.modernizr.com上下载代码,然后在HTML页面中包含这个外部js文件即可:
复制代码
代码如下:
<script src="modernizr-1.6.min.js"></script>
使用Modernizr测试Canvas的支持性,只需将上面的canvasSupport函数改动一下就可以了:
复制代码
代码如下:
function canvasSupport() {
return Modernizr.canvas;
}
我们认为,判断浏览器是否支持Canvas,使用Modernizr.js是最好的方案。
总结
以上是 为你收集整理的 HTML5 Canvas之测试浏览器是否支持Canvas的方法 全部内容,希望文章能够帮你解决 HTML5 Canvas之测试浏览器是否支持Canvas的方法 所遇到的问题。
如果觉得 网站内容还不错, 推荐好友。
查看更多关于HTML5 Canvas之测试浏览器是否支持Canvas的方法的详细内容...