天天看点

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)
    }
           
如此一来,便可以去除当前页面自动添加的参数,消除其影响,页面和你在本地写的一样了;

继续阅读