首页 > 编程语言 > 详细

webp实践的javascript检测方案

时间:2014-10-10 16:38:05      阅读:324      评论:0      收藏:0      [点我收藏+]
function hasWebp () {
    // 查看Cookie,如果没有则进行以下逻辑
    var img = new Image();
    img.onload = handleSupport;
    img.onerror = handleNotSupport;
    img.src = ‘data:image/webp;base64,UklGRkoAAABXRUJQVlA4WAoAAAAQAAAAAAAAAAAAQUxQSAsAAAABBxAREYiI/gcAAABWUDggGAAAADABAJ0BKgEAAQABABwlpAADcAD+/gbQAA==‘;
    // 否则根据Cookie执行handleSupport或者handleNotSupport
}
function handleSupport() {
    setCookie(‘swebp‘, ‘true‘, 2592000); // 30天过期
}
function handleNotSupport () {
    setCookie(‘swebp‘, ‘false‘, 2592000);
}

  

下面是 localStorage版本

function detectWebp () {
    if (!window.localStorage || typeof localStorage !== ‘object‘) return;

    var name = ‘webpa‘; // webp available
    if (!localStorage.getItem(name) || (localStorage.getItem(name) !== ‘available‘ && localStorage.getItem(name) !== ‘disable‘)) {

        var img = document.createElement(‘img‘);

        img.onload = function () {
            try {
                localStorage.setItem(name, ‘available‘);
            } catch (ex) {
            }
        };

        img.onerror = function () {
        try {
                localStorage.setItem(name, ‘disable‘);
            } catch (ex) {
            }
        };
        img.src = ‘data:image/webp;base64,UklGRkoAAABXRUJQVlA4WAoAAAAQAAAAAAAAAAAAQUxQSAsAAAABBxAREYiI/gcAAABWUDggGAAAADABAJ0BKgEAAQABABwlpAADcAD+/gbQAA==‘;
    }
}

  

webp实践的javascript检测方案

原文:http://www.cnblogs.com/dachie/p/4016128.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!