URLSearchParams无效

本文介绍了一种在Vue2开发的微信H5页面中解决URLSearchParams兼容性问题的方法。针对iOS设备上出现的页面加载不完全、前端请求失败的问题,通过引入url-search-params-polyfill库来确保URLSearchParams在所有目标设备上的正常工作。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

现象:

最近在vue2开发微信H5页面,在大部分的android、iOS、浏览器都是正常的,但有个别iOS打开页面没有反应,只是加载了静态内容。查看后台日志,发现没有请求,于是猜测是前端请求出现问题。经过排查,发现URLSearchParams没有识别到。

原因:

网上说URLSearchParams的兼容性并不完全,如果使用可以自己安装

处理方法:

可以参考url-search-params-polyfill - npm,国内安装建议用cnpm

cnpm install url-search-params-polyfill --save

在main.js引入

import 'url-search-params-polyfill'

// 导出BOM并下载Excel debugger; // 尝试使用Aras标准方法获取当前项 var partItem = null; try { // 方法1: 从窗口名称获取(适用于表单) partItem = top.aras.getItemFromWindowName(window.name); // 如果未获取到,尝试方法2: 从ActiveView获取(适用于列表视图) if (!partItem && top.aras.uiActiveView) { var activeItem = top.aras.uiActiveView.GetItem(); if (activeItem && activeItem.node) { partItem = top.aras.newIOMItem(); partItem.loadAML(activeItem.node.outerHTML); } } // 如果仍未获取到,尝试方法3: 从URL参数获取 if (!partItem) { var urlParams = new URLSearchParams(window.location.search); var itemId = urlParams.get('id'); var itemType = urlParams.get('type'); if (itemId && itemType) { partItem = top.aras.newIOMItem(itemType, itemId); partItem.load(); } } } catch (e) { console.error("获取当前项时出错:", e); } // 检查partItem是否有效 if (!partItem || !partItem.getID) { top.aras.AlertError("无法获取当前零件信息:partItem为空或无效"); console.error("partItem is null or invalid", partItem); return; } // 获取当前对象ID var partID = partItem.getID(); // 检查ID是否有效 if (!partID) { top.aras.AlertError("获取的零件ID为空"); console.error("partID is empty", partItem); return; } // 创建方法项调用后端 var methodItem = this.newItem("Method", "server-bom-export"); methodItem.setProperty("partID", partID); // 执行服务器方法 var resultItem = methodItem.apply(); if (resultItem.isError()) { top.aras.AlertError("导出失败: " + resultItem.getErrorString()); return; } // 获取返回的文件数据 var fileData = resultItem.getProperty("file_data"); var fileName = resultItem.getProperty("file_name"); // 检查文件数据是否存在 if (!fileData || !fileName) { top.aras.AlertError("服务器返回的数据不完整"); return; } // 解码Base64数据 const byteCharacters = atob(fileData); const byteNumbers = new Array(byteCharacters.length); for (let i = 0; i < byteCharacters.length; i++) { byteNumbers[i] = byteCharacters.charCodeAt(i); } const byteArray = new Uint8Array(byteNumbers); // 创建Blob并下载 const blob = new Blob([byteArray], {type: "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet"}); const link = document.createElement('a'); link.href = URL.createObjectURL(blob); link.download = fileName; link.style.display = 'none'; document.body.appendChild(link); link.click(); document.body.removeChild(link);报错无法获取当前零件信息:partItem为空或无效,那么客户端方法如何能获取当前对象类呢
最新发布
07-18
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值