本文譯自Steve Fulton & Jeff Fulton HTML5 Canvas, Chapter 1, “Testing to See Whether the Browser Supports Canvas”.
在取得HTML頁面上Canvas元素的參考後,我們需要測試一下該元素是否包含「上下文」(context)。 Canvas的上下文指的是由瀏覽器定義的用於繪畫的平面。簡單地說,如果上下文不存在的話,Canvas也就名存實亡了。測試瀏覽器是否支援Canvas有好幾種方法。第一種方法是檢查HTML頁面中Canvas元素的getContext方法是否存在:
事實上,上述程式碼測試了兩點:其一子,測試了theCanvas是否為false(如果id不存在的話,document.getElementById()會傳回false);其二,測試了getContext()函數是否存在。
在上述程式碼中,如果測試失敗,那麼return語句執行,程式終止。
另一種方法是創建一個專門用於判斷Canvas是否得以支援的函數,而在該函數中,實時生成一個Canvas元素來進行這種判斷— 這種方法很流行,Mark Pilgrim在他的HTML5網站http://diveintohtml5.org提到了這個方案:
我們最鍾愛的方法是使用modernizr.js庫(在http://www.modernizr.com中可以找到)。 Modernizr是一個簡單易用的輕量級JavaScript庫,用於測試各種Web技術的兼容性 — 它提供了許多靜態的Boolean方法,可以用來測試目前Canvas是否支援。
在HTML頁面中引入modernizr很簡單,從http://www.modernizr.com下載程式碼,然後在HTML頁中包含這個外部js檔案: