参考:https://blog.csdn.net/zx19930309/article/details/90375907

    示例代码

    1. function dealImage(base64, w, callback) {
    2. let newImage = new Image();
    3. let quality = 0.8;
    4. newImage.src = base64;
    5. newImage.setAttribute("crossOrigin", 'Anonymous'); //url为外域时需要
    6. let imgWidth, imgHeight;
    7. newImage.onload = function () {
    8. imgWidth = this.width;
    9. imgHeight = this.height;
    10. let canvas = document.createElement("canvas");
    11. let ctx = canvas.getContext("2d");
    12. if (Math.max(imgWidth, imgHeight) > w) {
    13. if (imgWidth > imgHeight) {
    14. canvas.width = w;
    15. canvas.height = w * imgHeight / imgWidth;
    16. } else {
    17. canvas.height = w;
    18. canvas.width = w * imgWidth / imgHeight;
    19. }
    20. } else {
    21. canvas.width = imgWidth;
    22. canvas.height = imgHeight;
    23. }
    24. ctx.clearRect(0, 0, canvas.width, canvas.height);
    25. ctx.drawImage(this, 0, 0, canvas.width, canvas.height);
    26. // 如想确保图片压缩到自己想要的尺寸,如要求在50-150kb之间,请加以下语句,quality初始值根据情况自定
    27. while (base64.length / 1024 > 150) {
    28. quality -= 0.01;
    29. base64 = canvas.toDataURL("image/jpeg", quality);
    30. }
    31. // 防止最后一次压缩低于最低尺寸,只要quality递减合理,无需考虑
    32. // while (base64.length / 1024 < 50) {
    33. // quality += 0.001;
    34. // base64 = canvas.toDataURL("image/jpeg", quality);
    35. // }
    36. callback(base64);//必须通过回调函数返回,否则无法及时拿到该值
    37. }
    38. }
    39. function useImg(base64) {
    40. const str= base64;
    41. console.log(str);
    42. console.log(str.length);
    43. }
    44. let base64= "";
    45. //这就是你压缩之后的字符串
    46. //你可以打桩看一下有多长
    47. console.log(base64.length);
    48. //然后调用压缩方法 第一个参数就是原来的字符串,第二个是宽度,第三个就是回调方法,也就是压缩函数最后面那个callbackbase64
    49. dealImage(base64, 500, useImg);