js中如果遇到低版本安卓设备调用setTimeout不生效解决办法

更新日期: 2019-11-27阅读: 1.5k标签: 定时器

工作中会遇到低版本安卓设备调用setTimeout不生效,既不会报错,里面的函数也不会执行,这里po一个解决办法,如果不执行则执行安卓自己封装的原生的setTimeout方法:sdk.setTimeout。

注明:此方法为我们老大所写,放在这里惠存一下。

基本方案
/*******/
(function(window){
    Promise.race([
        new Promise((resolve)=>{
            window.setTimeout(()=>{
                resolve(window.setTimeout)
            },0)
        }),
        new Promise((resolve)=>{
            sdk.setTimeout(()=>{
                resolve(sdk.setTimeout.bind(sdk))
            },100)
        })
    ]).then((fn)=>{
        window.setTimeout = fn
    })
})(window)


window.setTimeout(()=>{
    cosole.log('hello world')
},1000)








进阶方案
/*******/

(function(window){
    const st = window.setTimeout.bind(window)
    let callList = []
    window.setTimeout = function(cb, duration){
        callList.push(cb)
        return st(cb, duration)
    }
    Promise.race([
        new Promise((resolve)=>{
            window.setTimeout(()=>{
                resolve(()=>{
                    return st
                })
            },0)
        }),
        new Promise((resolve)=>{
            sdk.setTimeout(()=>{
                resolve(()=>{
                    callList.forEach(fn=>{
                        sdk.setTimeout(fn, duration)
                    })
                    window.clearTimeout = sdk.clearTimeout.bind(sdk)
                    return sdk.setTimeout.bind(sdk)
                })
            },100)
        })
    ]).then((fn)=>{
        window.setTimeout = fn()
    })
})(window)

原文:https://www.cnblogs.com/beileixinqing/archive/2020/02/27/12373370.html


链接: https://www.fly63.com/article/detial/7954

js中setTimeout和setInterval的深入理解:它们之间的区别,原理,“异步“等

这篇文章将带你深入理解js中定时器是如何工作的,setTimeout和setInterval的原理是什么?

为什么尽量别用setInterval

在开发一个在线聊天工具时,经常会有过多少毫秒就重复执行一次某操作的需求。“没问题”,大家都说,“用setInterval好了。”我觉得这个点子很糟糕。

你可能不知道的setInterval的坑

之前印象中一直记得setInterval有一些坑,但是一直不是很清楚那些坑是什么。setInterval会无视代码的错误、setInterval会无视任何情况下定时执行、、setInterval不能确保每次调用都能执行

setInterval和setTimeout的区别以及setInterval越来越快问题的解决方法

setInterval()和setTimeout()方法都是js原生的定时方法,当然它们两个的作用也是不同的,并且最近在做上下滚动公告栏的时候,发现了setInterval()非常令人抓狂的问题,那就是用setInterval()做的定时滚动会随着浏览器页面切换变得无法控制!为什么会说无法控制呢

如何通过setTimeout理解JS运行机制详解

setTimeout()函数:用来指定某个函数或某段代码在多少毫秒之后执行。它返回一个整数,表示定时器timer的编号,可以用来取消该定时器。JavasScript引擎是基于事件驱动和单线程执行的,JS引擎一直等待着任务队列中任务的到来

node-schedule 全局内关闭定时器

用Cron表达式完成定时器,全局内关闭定时器需要获取到定时器的引用,scheduleJob存在第四个参数,然而readme中没有提及,可知API

js 随机点名

主要是利用定时器,点击开始IDE时候不断的执行,并同时生成随机数,利用数组的下标完成展示。主要用到的知识点:setInterval,Math.random()

js定时器setTiemout、setInterval

JS提供了一些原生方法来实现延时去执行某一段代码,下面来简单介绍一下setTiemout、setInterval、setImmediate、requestAnimationFrame。JS提供了一些原生方法来实现延时去执行某一段代码,下面来简单介绍一下。

Js定时器越走越快的问题

之前在项目中写了定时器来做循环播放,但是总是会有越走越快的问题,开始是以为前后的HTML代码拼接的有问题,时间紧急的情况下反复改了很多也没什么效果,后来发现是js定时器的问题,在这里记录一下。

JS 定时器的4种写法及介绍

JS提供了一些原生方法来实现延时去执行某一段代码,下面来简单介绍一下setTiemout、setInterval、setImmediate、requestAnimationFrame。setTimeout: 设置一个定时器,在定时器到期后执行一次函数或代码段

点击更多...

内容以共享、参考、研究为目的,不存在任何商业目的。其版权属原作者所有,如有侵权或违规,请与小编联系!情况属实本人将予以删除!