js獲取url參數、圖片轉本地base64跨域問題


獲取url參數是經常需要用的一個方法,url上的參數可以讓我們的程序執行更靈活。

圖片轉本地也是很實用的,因為海報合成通常只支持本地。

下面我們來看看這些功能的實現:

獲取所有參數,采用split拆分法:

var strs;
function GetRequest () {
var url = location.search;//獲取url中“?”符后的字符串
var theRequest = new Object();
if (url.indexOf('?') != -1) {
var str = url.substr(1);
strs = str.split('&');
for (var i = 0;i < strs.length; i++) {
theRequest[strs[i].split('=')[0]] = decodeURI(str[i].split(('=')[1]);
}
}
return theRequest;
}

獲取指定參數名的值:

//獲取url參數
function getQueryString(name){
    let reg = new RegExp("(^|&)" + name + "=([^&]*)(&|$)", "i");
    let r = window.location.search.substr(1).match(reg);
    if (r != null) {
        return unescape(r[2]);
    };
    return null;
 }

var id = getQueryString("id") * 1;

 

圖片轉本地64:

var getBase64ByUrl = function(src, callback, outputFormat) {
    var xhr = new XMLHttpRequest();
    xhr.open('GET', src, true);

    xhr.responseType = 'arraybuffer';

    xhr.onload = function(e) {
      if (xhr.status == 200) {
        var uInt8Array = new Uint8Array(xhr.response);
        var i = uInt8Array.length;
        var binaryString = new Array(i);
        while (i--) {
          binaryString[i] = String.fromCharCode(uInt8Array[i]);
        }
        var data = binaryString.join('');
        var base64 = window.btoa(data);
        var dataUrl = "data:" + (outputFormat || "image/png") + ";base64," + base64;
        callback.call(this, dataUrl);
      }
    };

    xhr.send();
  }


getBase64ByUrl("外鏈圖片地址", function(url) {
  $('.img').attr('src', url);
});

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM