2009-11-25 3 views
5

usando qualcosa sulla falsariga di:c'è un modo praticabile per caratterizzare rilevare il supporto per un'immagine: base64 dati

background:url() no-repeat center center;} 

va bene ma voglio essere in grado di fornire graceful degradation (l'affermazione CSS è tramite JavaScript) quando base64 non è disponibile.

ovviamente, IE prima di v8 manca questa funzionalità in modo che potrei andare da browser - ma preferirei averlo rilevato funzione, se possibile.

qualche idea su come si fa a farlo?

risposta

6

Questo potrebbe essere quello che stai cercando: http://weston.ruter.net/2009/05/07/detecting-support-for-data-uris/

ho lavorato su una sceneggiatura che aggiunge un supporto parziale del regime DataURI in IE6 +: http://phenxdesign.net/projects/phenx-web/iedatauri/example.php e il codice è qui: http://code.google.com/p/phenx-web/source/browse/trunk/iedatauri/

IE5 + supporta un tipo di dati URI troppo, è ma non sempre possibile utilizzarlo: http://www.betalon.com/blog/html_css/data-uri-in-css-crossbrowser.htm

+0

+1 per l'approccio collegato, questo è un modo pratico pulito per controllare – curtisk

+0

grazie, fa il business semplicemente fantastico :) –

2

Utilizzando quanto sopra per estendere le mootools Browser.Features oggetto (se qualcuno trova utile, Modernizr non lo supporta)

http://www.jsfiddle.net/dimitar/5JT45/13/show/ o https://gist.github.com/821370

(function() { 
    Browser.Features.base64 = null; 
    var callback = function() { 
     Browser.Features.base64 = this.width == 1 && this.height == 1;   
     // alert(Browser.Features.base64); // true || false 
    }; 

    var img = new Image(), img = document.id(img) || new Element("img"); 
    img.onload = img.onerror = img.onabort = callback; 
    // 1x1 px gif to test with 
    img.src = ""; 

})(); 
1

Abbiamo trovato questo plug-in per Modernizr sulla loro wiki https://github.com/Modernizr/Modernizr/issues/14:

Modernizr.addTest('datauri',function(){ 
    var data = new Image(); 
    data.onload = data.onerror = function(){ 
    return (this.width == 1 && this.height == 1); 
    } 
    data.src = ""; 
})