摘要:学堂码匠计时器的第一个参数,包含几种不同的书写方法,可以是函数名,匿名函数,代码字符串,还有一些面试题当中会出现函数调用的书写方式。
HTML5学堂-码匠:计时器的第一个参数,包含几种不同的书写方法,可以是函数名,匿名函数,JS代码字符串,还有一些面试题当中会出现“函数调用”的书写方式。
那么,这些不同的书写方法分别表示什么呢?在计时器中出现的第一个参数,作用域又是在哪里创建的?
计时器第一个参数的不同写法 函数名的书写方法这是最为常见的一种书写方法,该方法表示的是,在固定毫秒之后,将这个函数名的函数添加到执行队列当中,让其执行。
字符串式的书写方法当一个函数有参数时,很多人会采用这样的调用方法。
Tips:参数为文字时,可以用单引号内包双引,或双引号内包单引的方式书写。
setTimeout 和 setInterval 都可以接受字符串(作为第一个参数),但是并不推荐使用这种书写方法。原因在于:为了能够运行,会在代码执行时,将字符串通过eval方法进行转换。
eval方法,其作用就是把字符串当做JS去执行。eval虽然能够解决很多问题,有很大的作用,但是也广为诟病,其性能问题,安全性问题,以及在JS严格模式与非严格模式的不同。
由于这些缺点,使得众多开发者在项目和代码中,尽量规避了对它的使用。
匿名函数的书写方法当函数有参数要传递,而又不能使用字符串式的书写方法,此时,匿名函数的书写方法就派上了用场。
函数调用的书写方法这种书写方法,本身是错误的,几乎在实际开发当中是无法找到的。当然在偶尔会在面试当中以“坑”的形式出现……
此处第一个函数会在执行到计时器这行代码时,立即执行,而返回的是h5course函数的返回值,而非函数本身。如果函数返回默认返回值undefined,setInterval也不会报错。
第一个参数的作用域归属计时器的第一个参数,默认在全局作用域中执行,因此函数内的 this 将会指向window。
Tips:运行结果为true
Tips:运行结果为true
来几道面试真题练练手 如下代码打印结果是什么Tips:答案请见文章底部
码匠 两个字多久会打印出来Tips:答案请见文章底部
请说出如下代码运行情况Tips:答案请见文章底部
总而言之,言而总之当要执行的函数没有参数时,可以直接使用函数名调用
当需要向回调函数中传递参数时,不要使用字符串做参数,使用匿名函数做参数,并在匿名函数内部执行回调函数。
第一参数的函数会在全局作用域中进行执行
第一题:先输出10,之后大概1秒后,同时输出10个10。
第二题:约1000毫秒(即约1秒)
第三题:在函数执行时,两个li的背景颜色立即被设置为了红色,经过大概5000毫秒之后,控制台报错(两个错误),错误内容均为“red is not defined”
生活艰辛,代码不易,但,不要忘记微笑!
梳理JS知识主干,高效率学习JavaScript!版权声明:该图来自“【美】莉兹·克里莫 (author)”的书籍《你今天真好看》
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/88722.html
摘要:运用防抖和节流可以有效降低代码的执行频率,从而解决高频率事件的页面卡顿问题。在阶段布局,最终确定显示的位置和大小。在函数中,首先定义了一个空的定时器变量,用来计算时间间隔。还有一点要注意,在中一定要清楚定时器,不然会影响的条件判断。 啥是节流? 节流是保证在一段时间内,代码只执行了一次。这个一段时间内指的是不管用户操作了几次,最终仅执行一次。比如说一个按钮,用户狂点按钮,但是如果用节流...
摘要:运用防抖和节流可以有效降低代码的执行频率,从而解决高频率事件的页面卡顿问题。在阶段布局,最终确定显示的位置和大小。在函数中,首先定义了一个空的定时器变量,用来计算时间间隔。还有一点要注意,在中一定要清楚定时器,不然会影响的条件判断。 啥是节流? 节流是保证在一段时间内,代码只执行了一次。这个一段时间内指的是不管用户操作了几次,最终仅执行一次。比如说一个按钮,用户狂点按钮,但是如果用节流...
摘要:文末评论送书,学委会用这个抽奖程序来进行严格抽奖,周六晚上点整定时抽奖并视频公布出来,敬请期待。本文讲的函数值传递问题,是写程序经常遇到,特别的是动态参数在高级框架中使用很广泛。 ...
阅读 2295·2021-11-23 09:51
阅读 1838·2021-10-13 09:40
阅读 1295·2021-09-30 10:01
阅读 565·2021-09-26 09:46
阅读 2141·2021-09-23 11:55
阅读 1317·2021-09-10 10:51
阅读 2108·2021-09-09 09:33
阅读 2196·2019-08-29 17:25