js 跳转外部页面的方式

js 跳转外部页面的方式

普通跳转不需要携带参数的跳转

window.location='http://supermatchusa.com/activity/turntable/#/pages/index/rule'
window.location.href="bloomer://recharge/coins"

以上两种情况是指普通跳转外部链接且不需要携带参数的情况

下边这一种是携带参数的跳转方式

var url= encodeURIComponent("{\"name\":\"Turntable\",\"webUrl\":\"http://supermatchusa.com/activity/turntable/#/pages/index/winningList\"}")
 window.location="bloomer://com.s.video.bloomer/NetWeb/params?webInfoJson="+url+"&doings=Turntable"

携带参数稍微麻烦一点 首先需要encodeURIComponent()方法加密一下 第二点就是符号之间需要反斜杠 隔离一下 根据自己的地址配置 重点就是http的链接地址会被转义成乱码 获取的地方会拿不到参数

在 JavaScript 中,`window.location.href` 用于实现页面跳转,但其本身是同步操作,并且一旦执行成功,当前页面会立即卸载并跳转到目标地址。因此,无法直接检测跳转是否失败,因为脚本执行会在跳转后停止。不过,可以通过一些间接方式检测跳转是否可能失败,例如通过监听 `beforeunload` 或 `unload` 事件,或者使用超时机制来判断跳转是否未如期发生。 ### 1. 使用 `beforeunload` 事件检测页面是否即将卸载 `beforeunload` 事件会在页面即将卸载前触发,可以用于确认跳转是否开始执行。 ```javascript window.addEventListener('beforeunload', function (e) { console.log('页面即将跳转或关闭'); }); ``` 但此方法无法明确判断跳转是否成功,仅能确认页面开始卸载。 ### 2. 使用超时机制检测跳转是否未发生 可以在调用 `window.location.href` 后设置一个定时器,如果在预期时间内页面跳转,则认为跳转失败。 ```javascript function navigateWithTimeout(url, timeout = 3000) { const originalHref = window.location.href; window.location.href = url; setTimeout(() => { if (window.location.href === originalHref) { console.error('跳转失败或被阻止'); } }, timeout); } ``` 该方法依赖于页面状态的比较,适用于单页应用或局部刷新场景。 ### 3. 在跳转前使用 `fetch` 或 `XMLHttpRequest` 预检目标页面是否可达 虽然无法直接检测外部页面是否可访问(受跨域限制),但可以通过预检目标页面的 HTTP 状态码来判断其是否可达(需目标服务器支持 CORS)。 ```javascript fetch(url, { method: 'HEAD', mode: 'no-cors' }) .then(response => { console.log('目标页面存在'); window.location.href = url; }) .catch(error => { console.error('目标页面不可达或跨域限制', error); }); ``` 注意:由于浏览器安全策略限制,`fetch` 在跨域请求时无法获取详细错误信息,因此此方法不保证完全准确。 ### 4. 结合 `try...catch` 捕获同步异常(较少使用) 虽然 `window.location.href` 不会抛出异常,但如果赋值时出现语法错误或类型错误,仍可被捕获。 ```javascript try { window.location.href = undefined; // 故意传入非法值 } catch (e) { console.error('赋值失败:', e.message); } ``` 此类错误通常与开发错误相关,而非运行时跳转失败。 ### 5. 使用 `window.onerror` 捕获全局错误(适用于脚本加载失败) 如果跳转失败是因为加载脚本或资源失败,可以结合全局错误监听器进行辅助检测。 ```javascript window.onerror = function(message, source, lineno, colno, error) { console.error('全局错误:', message, error); return true; }; ``` ### 总结 由于浏览器的安全机制和页面跳转的同步特性,JavaScript 无法直接检测 `window.location.href` 是否跳转成功。通常采用间接方法,如超时检测、预检请求、事件监听等手段进行判断。实际应用中应结合具体场景选择合适策略。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值