微信关闭网页触发事件/

由于未提供博客具体内容,无法给出包含关键信息的摘要。
方式一
<script> 
//初始化开始时间
    var sTime = new Date();
//初始化结束始时间
    var eTime = new Date();
    window.addEventListener('pagehide',
        function () {

            eTime = new Date();

            var sStr = generateTimeReqestNumber(sTime);
            var eStr = generateTimeReqestNumber(eTime);

            console.log(sStr);
            console.log(eStr);
            console.log(console.log(Math.floor((eTime - sTime) / 1000)));

            $.post("http://fin.allinpaysc.com:18002/water/visit",function () { }, "json");

        });
//计算带0的
    function pad2(n) {

        return n < 10 ? '0' + n : n;
    }
//计算时间
    function generateTimeReqestNumber(date) {

        return date.getFullYear().toString() + pad2(date.getMonth() + 1) + pad2(date.getDate()) + pad2(date.getHours()) + pad2(date.getMinutes()) + pad2(date.getSeconds());
    }
</script>
方式二

   <script>
        if (window.addEventListener) {
            window.addEventListener("pagehide", function () { // IOS
                $.post("http://slychat.yizhaosulianyun.com/Home/indexmodel?token=UYDpf4tcVp/5oqAfUrbaXA==", function () { }, "json");
                console.log('页面要关闭了:pagehide');
            })
       } else {
            window.onbeforeunload = function () { // 安卓
                $.post("http://slychat.yizhaosulianyun.com/Home/indexmodel?token=UYDpf4tcVp/5oqAfUrbaXA==", function () { }, "json");
                console.log('页面要关闭了:onbeforeunload');
            }
       }
    </script>

 

### H5微信公众号网页 UniApp 授权实现方法 #### 1. 配置微信公众平台 为了使UniApp应用能够在H5微信公众号网页中正常进行授权,需先在微信公众平台上完成必要的设置。这包括但不限于配置合法的回调域名以及获取所需的API权限。 - 进入微信公众平台的技术文档可以找到详细的接口说明和配置指南[^3]。 #### 2. 初始化授权过程 当用户访问基于UniApp构建的H5页面,系统应当自动触发授权流程。此过程中涉及到的关键步骤是在`onLaunch`生命周期钩子内调用特定函数来启动授权逻辑: ```javascript export default { onLaunch() { this.getInit(); }, methods: { getInit() { // 实现具体的初始化逻辑,比如发起网络请求以获得授权URL等 } } } ``` 这里提到的方法`getInit()`用于处理初次加载所需执行的任务,例如准备并重定向至微信提供的OAuth URL以便收集用户的同意[^2]。 #### 3. 构建授权链接 对于非静默式的用户信息授权(如`snsapi_userinfo`),开发者需要构造一个指向微信服务器的特殊URL,该URL包含了多个必要参数,如应用程序ID (`appid`)、响应类型的声明(`response_type=code`)、重定向URI (`redirect_uri`) 和作用域 (`scope=snsapi_userinfo`) 等。此外,还应加入随机字符串 `state` 参数作为安全措施的一部分。 一旦用户确认了授权请求,则会被重定向回预先设定好的回调地址,并附带有一个临凭证 `code` 。需要注意的是,这个 `code` 只能在五分钟之内有效且仅能被使用一次。 #### 4. 解决重复授权问题 针对某些情况下可能出现的反复弹出授权对话框现象——即用户点击“同意”按钮之后并未成功跳转而是再次显示相同的授权界面——可以通过调整业务逻辑中的状态管理机制加以规避。具体来说,在接收到有效的 `code` 后立即存储起来,并利用它换取更持久性的令牌或直接记录下已完成授权的事实,从而防止后续不必要的重新验证行为发生[^1]。 另外一种解决方案是确保每次打开新窗口之前都检查当前环境是否已经存在未关闭的相关实例;如果确实如此则不必再创建新的授权会话,而是尝试恢复之前的交互上下文。 #### 5. 返回原页面策略 为了让用户体验更加流畅自然,建议设计一套合理的导航规则使得用户可以从授权页面顺利返回到最初所在的视图位置。通常做法是在发起授权前保存当前浏览历史记录或者路径片段,待整个认证环节结束后依据这些数据重建浏览器的历史堆栈结构,进而允许按常规方式退回至上一步操作所在的位置。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

程序007

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值