亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

js實現把圖片的絕對路徑轉為base64字符串、blob對象再上傳

2019-11-19 18:12:00
字體:
來源:轉載
供稿:網友

主題:

JavaScript把項目本地的圖片或者圖片的絕對路徑轉為base64字符串、blob對象在上傳。

用處:

從本地選擇圖片上傳,如項目規定只能選擇本項目文件夾下的圖像上傳為頭像等。

主要思想:

使用canvas.toDataURL()方法將圖片的絕對路徑轉換為base64編碼.

具體用法:

在這我們引用淘寶服務器上的一張圖片舉例:

var imgSrc = "https://img.alicdn.com/bao/uploaded/TB1qimQIpXXXXXbXFXXSutbFXXX.jpg";// var imgSrc = "img/1.jpg";  function getBase64(img){//傳入圖片路徑,返回base64  function getBase64Image(img,width,height) {//width、height調用時傳入具體像素值,控制大小 ,不傳則默認圖像大小   var canvas = document.createElement("canvas");   canvas.width = width ? width : img.width;   canvas.height = height ? height : img.height;    var ctx = canvas.getContext("2d");   ctx.drawImage(img, 0, 0, canvas.width, canvas.height);   var dataURL = canvas.toDataURL();   return dataURL;  }  var image = new Image();  image.src = img;  var deferred=$.Deferred();  if(img){   image.onload =function (){   deferred.resolve(getBase64Image(image));//將base64傳給done上傳處理   }   return deferred.promise();//問題要讓onload完成后再return sessionStorage['imgTest']  }  }  getBase64(imgSrc)  .then(function(base64){   console.log(base64);  },function(err){   console.log(err);  });

此時在chrome測試,運行時會報錯!

原因:

我們使用的是淘寶服務器上的圖片,在本地服務器下訪問,結果出現圖片跨域的問題。

處理方案:

一、將圖片放在本地服務器

var imgSrc = "img/1.jpg";//本地項目文件夾下的圖片  function getBase64(img){//傳入圖片路徑,返回base64  function getBase64Image(img,width,height) {   var canvas = document.createElement("canvas");   canvas.width = width ? width : img.width;   canvas.height = height ? height : img.height;   var ctx = canvas.getContext("2d");   ctx.drawImage(img, 0, 0, canvas.width, canvas.height);   var dataURL = canvas.toDataURL();   return dataURL;  }  var image = new Image();  image.src = img;  var deferred=$.Deferred();  if(img){   image.onload =function (){   deferred.resolve(getBase64Image(image));//將base64傳給done上傳處理   }   return deferred.promise();//問題要讓onload完成后再return sessionStorage['imgTest']  }  }  getBase64(imgSrc)  .then(function(base64){   console.log(base64);  },function(err){   console.log(err);  });

二、 跨域

想引用其他服務器下的圖片該如何解決呢?

我們可以使用下面這一句代碼解決跨域。

image.crossOrigin = '';

測試在chrome和firefox,ie9+下生效,在目前safari6以下貌似不支持。

<!DOCTYPE html><html><head> <meta charset="UTF-8"> <title>nick getBase64</title></head><body><div><img id="test" src="" alt=""/></div><script src="http://apps.bdimg.com/libs/jquery/2.1.1/jquery.min.js"></script><script> var imgSrc = "https://img.alicdn.com/bao/uploaded/TB1qimQIpXXXXXbXFXXSutbFXXX.jpg";// var imgSrc = "img/1.jpg";  function getBase64(img){//傳入圖片路徑,返回base64  function getBase64Image(img,width,height) {//width、height調用時傳入具體像素值,控制大小 ,不傳則默認圖像大小   var canvas = document.createElement("canvas");   canvas.width = width ? width : img.width;   canvas.height = height ? height : img.height;    var ctx = canvas.getContext("2d");   ctx.drawImage(img, 0, 0, canvas.width, canvas.height);   var dataURL = canvas.toDataURL();   return dataURL;  }  var image = new Image();  image.crossOrigin = '';  image.src = img;  var deferred=$.Deferred();  if(img){   image.onload =function (){   deferred.resolve(getBase64Image(image));//將base64傳給done上傳處理   }   return deferred.promise();//問題要讓onload完成后再return sessionStorage['imgTest']  }  }  getBase64(imgSrc)  .then(function(base64){   console.log(base64);  },function(err){   console.log(err);  });</script></body></html>

上面是本功能的完整代碼,親們,可以測試咯!

這樣就本地圖片和其他服務器上的圖片都可以處理了!

結語:

想要了解更多的有關上傳頭像功能,可參考《淺析上傳頭像示例及其注意事項

以上就是本文的全部內容,希望本文的內容對大家的學習或者工作能帶來一定的幫助,同時也希望多多支持武林網!

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
狠狠躁夜夜躁久久躁别揉| www.国产精品一二区| 亚洲精品98久久久久久中文字幕| 久久精品影视伊人网| 精品香蕉一区二区三区| 国产精品丝袜久久久久久不卡| 国产亚洲欧洲在线| 欧美丰满少妇xxxx| 91老司机在线| 久久亚洲精品视频| 日韩女优人人人人射在线视频| 国产精品国产三级国产专播精品人| 欧美乱大交xxxxx| 亚洲精品大尺度| 国产精品99一区| 日韩av电影在线网| 日韩中文视频免费在线观看| 亚洲欧洲自拍偷拍| 亚洲黄色www网站| 欧美日韩国产第一页| 欧美激情免费看| 高清欧美性猛交| 日韩一区二区三区国产| 一区二区福利视频| 78m国产成人精品视频| 91久久久国产精品| 不卡av电影在线观看| xxxx欧美18另类的高清| 亚洲精品av在线播放| 91chinesevideo永久地址| 欧美日韩中文字幕在线| 17婷婷久久www| 日韩电视剧免费观看网站| 97超级碰在线看视频免费在线看| 亚洲国产一区二区三区四区| 日日摸夜夜添一区| 国产精品中文字幕久久久| 成人黄色短视频在线观看| xvideos亚洲| 久久久国产精品亚洲一区| 国产亚洲成av人片在线观看桃| 成人免费自拍视频| 欧美成人国产va精品日本一级| 亚洲自拍偷拍色片视频| 亚洲石原莉奈一区二区在线观看| 欧美色播在线播放| 色哟哟入口国产精品| 午夜精品福利在线观看| 亚洲v日韩v综合v精品v| 一本色道久久88综合亚洲精品ⅰ| 国产精品入口日韩视频大尺度| 国产亚洲欧美视频| 国产在线拍偷自揄拍精品| 久久久99久久精品女同性| 国产精品男女猛烈高潮激情| 毛片精品免费在线观看| 538国产精品一区二区免费视频| 日本中文字幕久久看| 欧美性生活大片免费观看网址| 日本欧美精品在线| 精品国产乱码久久久久久天美| 中文日韩电影网站| 欧美日韩国产精品专区| 精品久久久免费| 久久成人av网站| 欧美日韩精品国产| 狠狠色狠狠色综合日日五| 亚洲社区在线观看| 亚洲欧洲美洲在线综合| 欧美裸体男粗大视频在线观看| 欧美国产视频一区二区| 九九九热精品免费视频观看网站| 欧美老女人www| 日韩精品电影网| 久久777国产线看观看精品| 成人中心免费视频| 亚洲在线www| 国产精品网红福利| 欧美日韩第一视频| 国产精品女主播视频| 久久久久久久电影一区| 国产91在线高潮白浆在线观看| 久久久视频精品| 国产精品亚洲美女av网站| 国产在线98福利播放视频| 91国产视频在线| 欧美成人黑人xx视频免费观看| 视频在线一区二区| 亚洲www永久成人夜色| 亚洲精品国产精品自产a区红杏吧| 色樱桃影院亚洲精品影院| 国产美女扒开尿口久久久| 国产精品综合久久久| 国产综合福利在线| 91国产高清在线| 亚洲加勒比久久88色综合| 欧美猛交免费看| 欧美专区国产专区| 欧美最猛性xxxxx免费| 久久6免费高清热精品| 中文字幕一精品亚洲无线一区| 美女撒尿一区二区三区| 欧美激情日韩图片| 亚洲xxxx3d| 亚洲国产精品视频在线观看| 日本韩国欧美精品大片卡二| 97视频人免费观看| 久久久久久久久久国产精品| 亚洲综合av影视| 国产精品亚洲片夜色在线| 国产精品日韩久久久久| 日韩精品在线免费| 久久久人成影片一区二区三区| 久久久久久久久久国产精品| 久久精品国产久精国产思思| 91免费福利视频| 51ⅴ精品国产91久久久久久| 国产成人精品视频| 日本电影亚洲天堂| 精品视频中文字幕| 深夜福利国产精品| 亚洲午夜性刺激影院| 91精品视频在线免费观看| 欧美激情亚洲自拍| 成人黄色av网站| 久久九九全国免费精品观看| 狠狠久久五月精品中文字幕| 亚洲男人天堂九九视频| 欧美在线视频观看免费网站| 国产精品久久久久国产a级| 91国产视频在线| 91免费看视频.| 欧美成人一区在线| 美日韩精品视频免费看| 亚洲国产精品久久| 亚洲最大福利视频网| 欧美成人精品激情在线观看| 日韩av有码在线| 精品久久中文字幕| 国产精品视频网址| 色婷婷综合成人av| 国产中文欧美精品| 国产精品69久久| 国产精品无av码在线观看| 欧美成人精品一区二区| 亚洲精品久久久久久久久久久久| 亚洲精品久久久久国产| 国产美女精品视频免费观看| 中文字幕不卡av| 亚洲欧洲自拍偷拍| 欧美久久久精品| 日韩欧美视频一区二区三区| 精品一区二区亚洲| 91在线观看免费观看| 91国产中文字幕| 亚洲一区二区日本| 九九久久国产精品| 成人免费xxxxx在线观看| 久久精品久久久久久国产 免费| 日本欧美一二三区| 国产日韩精品一区二区| 日韩经典中文字幕| 欧美性一区二区三区| 精品久久香蕉国产线看观看亚洲|