当前位置: 首页 > news >正文

国外做电商网站有哪些方面如何让百度收录

国外做电商网站有哪些方面,如何让百度收录,有网页源码怎么做网站,国内知名建筑设计公司问题引入 下面代码的输出结果不是间隔3秒依次输出 1&#xff0c; 2&#xff0c; 3&#xff0c; 4&#xff0c; 5。而是隔了3秒连续输出6。这是为什么呢&#xff1f; for (var i 1; i < 5; i){setTimeout(function timer() {console.log(i)}, 3000);}先说JS的执行机制和作用…

问题引入

下面代码的输出结果不是间隔3秒依次输出 1, 2, 3, 4, 5。而是隔了3秒连续输出6。这是为什么呢?

  for (var i = 1; i <= 5; i++){setTimeout(function timer() {console.log(i)}, 3000);}

先说JS的执行机制和作用域

首先,JavaScript是单线程环境,代码从上到下依次执行。这种执行方式被称作为是“同步执行”。

但是,JavaScript引进了异步执行机制。所以,任务可以分为两种:一种是同步任务;另一种是异步任务。同步任务是指:在主线程上排队执行的任务,只有前一个任务执行完毕,才能执行后一个任务。异步任务是指:不进入主线程,而进入任务队列的任务,只有当主线程上的任务执行完毕后,才通知任务队列,任务队列中的任务才会进入主线程执行。

问题中的代码:for循环是同步代码,setTimeout是异步代码。在这种情况下,JavaScript依然按照从上到下执行先执行同步的代码,并将异步的代码放入到任务队列中。setTimeout的第二个参数是把执行代码console.log(i)添加到任务队列所需要的毫秒数,等待的时间是相对主程序执行完毕的时间计算的。也就是说,在主程序执行完后,会等待一会时间,再将setTimeout任务插入到任务队列中。

这样,在执行完同步的代码后,再去执行任务队列中的异步代码。这个时候,任务队列中会有5个console.log(i)等待执行。起初,以为每次循环,setTimeout放入到console.log(i)中的i的值是不一样的,但是,JavaScript引擎在开始执行任务队列中代码时,会在当前作用域中寻找变量i,但是当前作用域(也就是setTimeout中)并没有对 i 的定义。这个时候就会从创建该函数的作用域中寻找变量 i,创建该函数的作用域是全局作用域,所以就找到了for循环中的变量 i ,而这时的全局变量 i 的值已经确定为:6.所以最后打印出来的是5个6…

解决方案一:闭包

  for (var i = 1; i <= 5; i++){setTimeout(function timer(i) {console.log(i)}(i), 3000);}

这样会发现打印出来的值是1, 2, 3, 4, 5;但是没有时间间隔就输出。这时因为在function timer()后面添加()表示的是立即执行函数,只要setTimeout调用就执行了,而不是等到定时器到后才执行

  for (var i = 1; i <= 5; i++) {(function (j) {setTimeout(function timer() {console.log(j)}, 3000);     })(i)}

这样会发现打印出来的值是1, 2, 3, 4, 5;会等待3秒再同时输出;与上面不同,这次的setTimeout要等到定时器到后才能执行。

如果想要每次输出后间隔一秒,只需要将传入的 i 和 time 相乘即可:

  for (var i = 1; i <= 5; i++) {(function (j) {setTimeout(function timer() {console.log(j)}, j * 1000);     })(i)}

至于为什么是每隔一秒?因为按照上面写法,每隔setTimeout的定时器依次是 1s,2s,3s,4s,5s。之前说过,定时器计时是相对于主线程运行完毕后开始的,所以相邻输出间隔1s.

为什么闭包可以解决该问题?因为函数是有作用域的。这也是解决方案二可以实现的原因。

解决方案二:拆分结构

  function timer(i) {setTimeout(() => {console.log(i)}, i *1000);}for (var i = 1; i <= 5; i++){timer(i)}

也是解决了 i 的作用域问题。输出也是每隔一秒输出。

解决方案三:let

let声明的变量只在其声明的块或子块中可用,这一点,与var相似。二者之间最主要的区别在于var声明的变量的作用域是整个封闭函数

  for (let i = 1; i <= 5; i++){setTimeout(function timer() {console.log(i)}, i * 1000);}

这样打印的效果也是每隔一秒打印一个数值:1, 2, 3, 4, 5.

http://www.lbrq.cn/news/2377873.html

相关文章:

  • dede网站根目录赣州网站建设公司
  • 乐居房产官方网站百度关键词竞价排名
  • 中国电建市政建设集团有限公司网站seo教程视频
  • 濮阳做网站的价格域名收录查询
  • 做cpa比较做网站吗会员营销
  • 淘宝客优惠券网站怎么做优化设计方法
  • 兴义网站建设网站建设宜昌网站seo
  • 个人网站免费源码石首seo排名
  • 重庆网站服务器建设推荐qq空间秒赞秒评网站推广
  • 做垂直类网站百度关键词推广怎么做
  • 天津网站优化步骤河南网站建设哪家公司好
  • 郑州网站建设搜索优化网站友情链接检测
  • 绥化建设局网站自己的网站怎么推广
  • 电商网站的在线客服怎么做杭州优化公司哪家好
  • 电影网站cpa怎么做网站推广seo方法
  • 短网址还原工具seo服务指什么意思
  • 时时彩网站做号五个常用的搜索引擎
  • 怎样做网站备份搜狗网站收录入口
  • 建网站的程序营销推广与策划
  • 深圳商城网站哪家做的好快速排名工具免费
  • 深圳政府采购中心官网四川整站优化关键词排名
  • 学做衣服上什么网站好推广下载app赚钱
  • 网推团队淘宝seo推广优化
  • 做网站设计所遇到的问题seo推广软件费用
  • 物流网站建设可行性报告营销培训讲师
  • 在中国怎么做国外网站百度云客服人工电话
  • 邢台市网站制作推广游戏怎么拉人最快
  • 海尔建设此网站的目的是什么意思百度业务推广
  • 松江做网站需要多少钱服装品牌策划方案
  • 安居客看房网北京seo编辑
  • Java HashMap高频面试题深度解析
  • RV126平台NFS网络启动终极复盘报告
  • Python数据类型探秘:解锁编程世界的魔法钥匙
  • Linux系统安装Docker及部署Node.js 20.15.0(含pnpm、pm2)完整指南
  • Linux C 进程间通信基本操作
  • 异世界历险之数据结构世界(排序(插入,希尔,堆排))