Web前端最新Vue进阶(七十八):Vue 定时器与 JS 定时器,真香

js基础

1)对js的理解?
2)请说出以下代码输出的值?
3)把以下代码,改写成依次输出0-9
4)如何区分数组对象,普通对象,函数对象
5)面向对象、面向过程
6)面向对象的三大基本特性
7)XML和JSON的区别?
8)Web Worker 和webSocket?
9)Javascript垃圾回收方法?
10)new操作符具体干了什么呢?
11)js延迟加载的方式有哪些?
12)WEB应用从服务器主动推送Data到客户端有那些方式?

js基础.PNG

前16.PNG

开源分享:【大厂前端面试题解析+核心总结学习笔记+真实项目实战+最新讲解视频】

}


### 二、JS 定时器


`js` 定时器有以下两个方法:


* `setInterval()` :按照指定周期(以毫秒计)来调用函数或计算表达式。方法会不停地调用函数,直到 `clearInterval()` 被调用或窗口被关闭。
* `setTimeout()` :在指定毫秒数后调用函数或计算表达式。


**setInterval()**


语法



setInterval(code,millisec,lang)


参数 描述


* `code` 必需。要调用的函数或要执行的代码串。
* `millisec` 必需。周期性执行或调用 `code` 之间的时间间隔,以毫秒计。
* `lang` 可选。 `JScript | VBScript | JavaScript`


以下实例在每 1000 毫秒执行 clock() 函数。实例中也包含了停止执行的按钮:


在需要重复发送请求或者某些效果的时候,一般都会想到使用`setInterval`,但是它的一些弊端,会给程序带来很大的隐患。


**一、弊端**


1. `setInterval`对自己调用的代码是否报错漠不关心。即使调用的代码报错了,它依然会持续的调用下去。
2. `setInterval`无视网络延迟。在使用`ajax`轮询服务器是否有新数据时,必定会有一些人会使用`setInterval`,然而无论网络状况如何,它都会去一遍又一遍的发送请求,如果网络状况不良,一个请求发出,还没有返回结果,它会坚持不懈的继续发送请求,最后导致的结果就是请求堆积。
3. `setInterval`并不定时。如果它调用的代码执行的时间小于定时时间,它会跳过调用,这就导致无法按照你需要的执行次数或无法得到你想要的结果。


**二、解决方案**  
 使用`setTimeout`代替`setInterval`。  
 可以给`setTimeout`设置时间后,在最后调用自身。如果希望“匀速”触发。可以计算代码执行时间,用希望的延迟减去上次执行的时间。


注:有一种想法是将`setInterval`的延迟时间设置的长于上述的几种时间,来达到绝对的均速调用。但事实上,`js`计时器因为自身机制的原因,存在`4ms–15ms`的误差。


**setTimeout()**  
 语法



setTimeout(code,millisec,lang)


参数 描述


* `code` 必需。要调用的函数后要执行的 `JavaScript` 代码串。
* `millisec` 必需。在执行代码前需等待的毫秒数。
* `lang` 可选。脚本语言可以是:



JScript | VBScript | JavaScript


如果想要在一个函数中启用定时器 ,又想在另一个函数关闭这个函数,可以这样做:



var timer1 = null;

function start(){
if ( timer1 )
return;
timer1 = setInterval(“test()”,200);
}

function end(){
if ( timer1 )
{
clearInterval(timer1);
timer1 = null;
}
}


注意事项: 这里的 timer1 相当于`setInterval` 的 id, 执行`clearInterval(timer1)`方法时, 就是传入定时器 ID 进行停止的。

跳槽是每个人的职业生涯中都要经历的过程,不论你是搜索到的这篇文章还是无意中浏览到的这篇文章,希望你没有白白浪费停留在这里的时间,能给你接下来或者以后的笔试面试带来一些帮助。



也许是互联网未来10年中最好的一年。WINTER IS COMING。但是如果你不真正的自己去尝试尝试,你永远不知道市面上的行情如何。这次找工作下来,我自身感觉市场并没有那么可怕,也拿到了几个大厂的offer。在此进行一个总结,给自己,也希望能帮助到需要的同学。

### 面试准备

**[开源分享:【大厂前端面试题解析+核心总结学习笔记+真实项目实战+最新讲解视频】](https://bbs.csdn.net/topics/618166371)**

面试准备根据每个人掌握的知识不同,准备的时间也不一样。现在对于前端岗位,以前也许不是很重视算法这块,但是现在很多公司也都会考。建议大家平时有空的时候多刷刷leetcode。算法的准备时间比较长,是一个长期的过程。需要在掌握了大部分前端基础知识的情况下,再有针对性的去复习算法。面试的时候算法能做出来肯定加分,但做不出来也不会一票否决,面试官也会给你提供一些思路。


法这块,但是现在很多公司也都会考。建议大家平时有空的时候多刷刷leetcode。算法的准备时间比较长,是一个长期的过程。需要在掌握了大部分前端基础知识的情况下,再有针对性的去复习算法。面试的时候算法能做出来肯定加分,但做不出来也不会一票否决,面试官也会给你提供一些思路。


  • 4
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值