• webp图片优化


      根据对目前国内浏览器占比与 WebP 的兼容性分析,大约有 50% 以上的国内用户可以直接体验到 WebP,如果你的网站以图片为主,或者你的产品基于 Chromium 内核,建议体验尝试。假如你打算在 App 中使用 WebP,除了 Android4.0 以上提供的原生支持外,其他版本以及 iOS 都可以直接使用官方提供的解析库(Android 、iOS )。

      webp图片解决方案

    1、若使用场景是浏览器,可以:
    • JavaScript 能力检测,对支持 WebP 的用户输出 WebP 图片
    • 使用 WebP 支持插件:WebPJS
    2、若使用场景是 App,可以:
    • Android 4.0 以下 WebP 解析库(链接
    • iOS WebP 解析库(链接
    3、转换工具:

      

      网页使用

      1. 按需加载,优雅降级

      利用 JS 判断浏览器是否支持,不支持的浏览器显示普通图片。 

    <img src="init.png" data-src="img.png" data-webp="img.webp">
    var img = new Image();
    img.src = ""; // WebP base64 格式图片
    img.onload = img.onerror = function() {
        var image = document.getElementsByTagName('img');
        for (var i = 0;i<image.length;i++) {
            if(img.width > 0 && img.height > 0){
                // 支持 WebP
                image[i].src = image[i].getAttribute('data-webp');
            }
            else {
                // 不支持 WebP
                image[i].src = image[i].getAttribute('data-src');
            }
        }
    };

      2. 使用 Flash 兼容所有浏览器

      webpjs-0.0.2.min.js + webpjs-0.0.2.swf

      全兼容的解决方法引用webpjs插件

      我们需要下载webpjs-0.0.2.min.jswebpjs-0.0.2.swf,来解决webp图片在不兼容的浏览器通过flash解决:

    //我们可以在网页任何地方放这段代码
    <script type="text/javascript" src="js/webpjs-0.0.2.min.js"></script>

      在不兼容的页面我们可以这样:

    <script>(function(){var WebP=new Image();WebP.onload=WebP.onerror=function(){
    if(WebP.height!=2){var sc=document.createElement('script');sc.type='text/javascript';sc.async=true;
    var s=document.getElementsByTagName('script')[0];sc.src='js/webpjs-0.0.2.min.js';s.parentNode.insertBefore(sc,s);}};
    WebP.src='';})();</script>

      有一点要注意的是,我们做引用webpjs插件要在服务器端才能测试出来。

      

  • 相关阅读:
    C#学生管理系统/学习
    ESC socket通信不通问题
    JavaWeb/ No 'Access-Control-Allow-Origin' header is present on the requested resource
    JavaWeb/ forward跳转到jsp页面后出现中文乱码问题
    JavaWeb/ MVC模式的初次实践
    docker搭建常用应用以及遇到的坑
    突验 8 进程通信
    实验七 信号
    实验6进程基础
    实验5 shell脚本编程
  • 原文地址:https://www.cnblogs.com/pingfan1990/p/4622822.html
Copyright © 2020-2023  润新知