Required Browser Features - PeerJ/pdf.js GitHub Wiki
This page describes the features that are required for a web browser to have PDF.js function properly. Some of the features are critical and do not let PDF.js function properly if they are not supported or disabled. Some of them can be emulated if absent (e.g. in the compatibility.js file), however the performance and memory usage of PDF.js will be worse than when the feature is present.
The required feature tests can be run at http://mozilla.github.com/pdf.js/features/
Support of the CANVAS element and 2D context is required feature for PDF.js. No emulation of the CANVAS element is provided for the browsers that do not support it.
Chrome | Firefox (Gecko) | Internet Explorer | Opera | Safari |
---|---|---|---|---|
Yes (v.24) | Yes (v.6) | Yes (v.9) | ? | Yes (v.5) |
PDF.js will set the canvas backing ImageData object contents.
If the set
function does not exist, it will be emulated.
Chrome | Firefox (Gecko) | Internet Explorer | Opera | Safari |
---|---|---|---|---|
Emulated / Yes (v.21) | Yes (v.4) | Emulated / Yes (v.11) | ? | Yes (v.5) |
The core library defines object properties using object 'get' literal:
var obj = {
get prop() { return 1; }
};
The browsers that don't understand this syntax will not be able to execute the code.
Chrome | Firefox (Gecko) | Internet Explorer | Opera | Safari |
---|---|---|---|---|
Yes (v.24) | Yes (v.6) | Yes (v.9) | ? | Yes (v.5) |
The addEventListener
method is used to bind event listeners for DOM elements.
No emulation of the addEventListener
method is provided in the browsers that do not support it.
Chrome | Firefox (Gecko) | Internet Explorer | Opera | Safari |
---|---|---|---|---|
Yes (v.24) | Yes (v.6) | Yes (v.9) | ? | Yes (v.5) |
The Uint8Array
, Uint16Array
, Int32Array
, Uint32Array
, Float32Array
and Float64Array
will be replaced by the artificial TypedArray object if those types are not implemented natively.
Only subarray
, buffer
, set
and byteLength
are similated. The subarray
just clones the array. The set
method is provided to emulate the Uint8Array
's set
method. The emulated typed arrays are slower, don't truncate the items to specific data types and are memory inefficient.
If the Float32Array
native implementation exists and the Float64Array
is absent, then the Float32Array
will be used instead of Float64Array
.
Chrome | Firefox (Gecko) | Internet Explorer | Opera | Safari |
---|---|---|---|---|
Yes (v.24) | Yes (v.6) | Yes (v.10) | ? | Yes (v.5.1) |
The Object.create
method will be added to the Object
function if the native implementation is absent.
Chrome | Firefox (Gecko) | Internet Explorer | Opera | Safari |
---|---|---|---|---|
Yes (v.24) | Yes (v.6) | Yes (v.9) | ? | Yes (v.5) |
The Object.defineProperty
method will be added to the Object
function if the native implementation is absent. The __defineGetter__
/ __defineSetter__
will be used instead.
Chrome | Firefox (Gecko) | Internet Explorer | Opera | Safari |
---|---|---|---|---|
Yes (v.24) | Yes (v.6) | Yes (v.9) | ? | Yes (v.5.1) |
Some browsers do not allow using the Object.defineProperty
with DOM objects.
In this case, the Object.defineProperty
is replaced by the artificial one. See Object.defineProperty() is present.
Chrome | Firefox (Gecko) | Internet Explorer | Opera | Safari |
---|---|---|---|---|
Yes (v.24) | Yes (v.6) | Yes (v.9) | ? | Yes (v.5.1) |
Some browsers does not allow redefine properties defined with get literal by the Object.defineProperty
.
In this case, the Object.defineProperty
is replaced by the artificial one. See Object.defineProperty() is present.
Chrome | Firefox (Gecko) | Internet Explorer | Opera | Safari |
---|---|---|---|---|
Yes (v.24) | Yes (v.6) | Yes (v.9) | ? | Yes (v.5) |
The Object.keys
method will be added to the Object
function if the native implementation is absent.
Chrome | Firefox (Gecko) | Internet Explorer | Opera | Safari |
---|---|---|---|---|
Yes (v.24) | Yes (v.6) | Yes (v.9) | ? | Yes (v.5) |
The FileReader
allows PDF.js read the file data provided in the input[type=file] HTML element. The live PDF.js demo will not be able to read a local file, if the FileReader
object is not supported.
Chrome | Firefox (Gecko) | Internet Explorer | Opera | Safari |
---|---|---|---|---|
Yes (v.24) | Yes (v.6) | Yes (v.10) | ? | Yes (v.6.0) |
Older browsers that have no readAsArrayBuffer
method implementation: the readAsBinaryString
will be used to emulate its functionality.
Chrome | Firefox (Gecko) | Internet Explorer | Opera | Safari |
---|---|---|---|---|
Yes (v.24) | Yes (v.7) | Yes (v.10) | ? | Yes (v.6.0) |
The empty overrideMimeType
method will be added to the XMLHttpRequest.prototype
, if the browser does not support it.
Chrome | Firefox (Gecko) | Internet Explorer | Opera | Safari |
---|---|---|---|---|
Yes (v.24) | Yes (v.6) | Emulated (v.10) | ? | Yes (v.5) |
The response
getter will be added to the XMLHttpRequest.prototype
, if the browser does not support it.
This is important for retrieving the binary PDF data using XHR.
Chrome | Firefox (Gecko) | Internet Explorer | Opera | Safari |
---|---|---|---|---|
No | Yes (v.6) | Yes (v.10) | ? | No |
The btoa
will be added to the window object, if the browser does not support it.
Chrome | Firefox (Gecko) | Internet Explorer | Opera | Safari |
---|---|---|---|---|
Yes (v.24) | Yes (v.6) | Yes (v.10) | ? | Yes (v.5) |
The bind
method will be added to the Function.prototype
, if the browser does not support it.
Chrome | Firefox (Gecko) | Internet Explorer | Opera | Safari |
---|---|---|---|---|
Yes (v.24) | Yes (v.6) | Yes (v.9) | ? | Yes (v.5) |
The dataset
property will be added to the HTMLElement.prototype
, if the browser does not support it.
This is important for specifying addition information (e.g. for text selection layer)
attached to specific HTML DOM element.
Chrome | Firefox (Gecko) | Internet Explorer | Opera | Safari |
---|---|---|---|---|
Yes (v.24) | Yes (v.6) | Emulated (v.10) Yes (v.11) |
? | Yes (v.5.1) |
The classList
property will be added to the HTMLElement.prototype
, if the browser does not support it.
This is important to simplify the viewer implementation.
Chrome | Firefox (Gecko) | Internet Explorer | Opera | Safari |
---|---|---|---|---|
Yes (v.24) | Yes (v.6) | Yes (v.10) | ? | Yes (v.5.1) |
The console
object will be added to the window object with empty log
and error
methods,
if the browser does not support it. This is important for the output of error messages and diagnostic information.
Chrome | Firefox (Gecko) | Internet Explorer | Opera | Safari |
---|---|---|---|---|
Yes (v.24) | Yes (v.6) | Yes (v.9) | ? | Yes (v.5) |
The console.log
and console.error
functions will be replaced, if the browser does not allow using
the bind method with these functions.
Chrome | Firefox (Gecko) | Internet Explorer | Opera | Safari |
---|---|---|---|---|
Yes (v.24) | Yes (v.6) | Yes (v.10) | ? | Yes (v.5) |
The core code relies on the Function.prototype.apply
method to accept the typed array as the second argument.
No emulation is provided in browsers that do not support it.
Chrome | Firefox (Gecko) | Internet Explorer | Opera | Safari |
---|---|---|---|---|
Yes (v.24) | ? | ? | ? | ? |
The language getter will be added to the window.navigator object, if the browser does not support it.
Chrome | Firefox (Gecko) | Internet Explorer | Opera | Safari |
---|---|---|---|---|
Yes (v.24) | Yes (v.6) | Emulated (v.10) Yes (v.11) |
? | Yes (v.5) |
Some PDF content is using "even-odd" fill rule/method. The content will not be displayed properly (example: #2351) if this feature is not supported.
Chrome | Firefox (Gecko) | Internet Explorer | Opera | Safari |
---|---|---|---|---|
No (v.25) | Yes (v.7) | No (v.10) | ? | No (v.6.0) |
Some PDF content is using custom dash line styles. The content will not be displayed properly if this feature is not supported.
Chrome | Firefox (Gecko) | Internet Explorer | Opera | Safari |
---|---|---|---|---|
Yes (v.24) | Yes (v.7) | No (v.10) | ? | No (v.6.0) |
Most of PDF documents use embedded fonts. If the browser does not support @font-face
style rule, the document will not be displayed property.
Chrome | Firefox (Gecko) | Internet Explorer | Opera | Safari |
---|---|---|---|---|
Yes (v.24) | Yes (v.6) | Yes (v.9) | ? | Yes (v.5) |
The PDF.js shall wait some time before using fonts with CANVAS, if the browser cannot tell if fonts are loaded and can be used.
Chrome | Firefox (Gecko) | Internet Explorer | Opera | Safari |
---|---|---|---|---|
Emulated (v.25) | Yes (v.14) | Yes (v.9) | ? | Yes (v.6) |
The PDF.js will execute all code (even long running) on the main thread, if the browser does not support web workers.
Chrome | Firefox (Gecko) | Internet Explorer | Opera | Safari |
---|---|---|---|---|
Yes (v.24) | Yes (v.6) | Yes (v.10) | ? | Yes (v.5) |
The PDF.js will execute all code on the main thread, if the browser cannot send (large) typed arrays to web workers.
Chrome | Firefox (Gecko) | Internet Explorer | Opera | Safari |
---|---|---|---|---|
Yes (v.24) | Yes (v.6) | Yes (v.10) | ? | Yes (v.6.0) |
Checks if the browser can transfer large chunks of data to the main thread vs cloning typed arrays. See Using web workers
Chrome | Firefox (Gecko) | Internet Explorer | Opera | Safari |
---|---|---|---|---|
Yes (v.17) | Yes (v.18~27) | No (v.11) | ? | ? |
The PDF.js will execute all code on the main thread, if the browser cannot request network binary data from web workers.
Chrome | Firefox (Gecko) | Internet Explorer | Opera | Safari |
---|---|---|---|---|
Yes (v.24) | Yes (v.10) | Yes (v.10) | ? | Yes (v.5.1) |