天天看點

APP分享h5頁面(vue cli)到微信不能正常請求接口的問題APP分享h5頁面(vue cli)到微信不能正常請求接口的問題

APP分享h5頁面(vue cli)到微信不能正常請求接口的問題

當APP中分享h5連結到微信中時,微信會自動拼接一些參數在h5連結的後面,此時可能會影響vue cli寫的h5中請求接口的觸發成功,以及相關的其他功能操作;

我的處理方法邏輯比較簡單,就是判斷位址是否被添加了微信的參數,然後擷取url取其中自己需要的,在給到location.replace();

微信自動拼接的通常為

朋友圈   &from=timeline&isappinstalled=0

微信群   &from=groupmessage&isappinstalled=0

好友分享 &from=singlemessage&isappinstalled=0
           

識别url

getQueryString: function (name) {//根據字段看網址是否拼接&字元串
	  var reg = new RegExp("(^|&)" + name + "=([^&]*)(&|$)", "i");
	  var r = window.location.search.substr(1).match(reg);
	  if (r != null)
	      return unescape(r[2]);
	  return null;
	}

	// 如果存在相關拼接參數,就重新加載url
			let from = getQueryString('from');
			let appinstall = getQueryString('appinstall');
			let sec = getQueryString('sec');
			let timekey = getQueryString('timekey');
			if (from || appinstall || sec || timekey) {
				let newUrl = window.location.href.split('?')[0];
				let urlParams = getUrlParams();  
				//getUrlParams()為擷取url參數函數
				newUrl = newUrl + "?regularCode=" + regularCode;
				location.replace(newUrl);
			}
           

抓取url參數對象

function getUrlParams () {
        var url = window.location.href.split('#')[0];
        const parseQueryString = url => {
            var json = {};
            var arr = url.substr(url.indexOf('?') + 1).split('&');
            arr.forEach(item => {
                var tmp = item.split('=');
                json[tmp[0]] = tmp[1];
            });
            return json;
        }
        return parseQueryString(url)
    }
           
如此一來,便可以去除目前頁面自動添加的參數,消除其影響,頁面和你在本地寫的一樣了;

繼續閱讀