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

优酷视频网站源码建设银行鞍山网站

优酷视频网站源码,建设银行鞍山网站,在线医生免费咨询,做水产有什么网站JS的变量提升ES6基础 变量var关键字var声明作用域实例一实例二多个变量 变量提升 let关键字暂时性死区全局声明for循环中使用let const关键字 变量 ECMAScript变量时松散类型的#xff0c;意思是变量可以用于保存任何类型的数据。 声明变量#xff1a;var 、const、let … JS的变量提升ES6基础 变量var关键字var声明作用域实例一实例二多个变量 变量提升 let关键字暂时性死区全局声明for循环中使用let const关键字 变量 ECMAScript变量时松散类型的意思是变量可以用于保存任何类型的数据。 声明变量var 、const、let var 可以随意使用而const和let只能在ES6及更晚的版本中使用。 var关键字 作用定义变量注意var是一个关键字 var name; var namekin; name 100;var声明作用域 实例一 var操作符定义的变量会成为包含它的函数的局部变量。 function test(){var name kin;//局部变量 } test(); console.log(name);//报错name变量是在函数内部使用var定义的 函数叫test()调用它会创建这个变量并给它赋值调用之后变量随即被销毁。 实例二 在函数内定义变量时省略var操作符可以创建一个全局变量 function test(){name kin;//全局变量 } test(); console.log(name);//kin注意 虽然可以通过该省略var操作符定义全局变量但不推荐这么做。在局部作用域中定义的全局变量很难维护也会造成困惑。这是因为不能一下子断定省略var是不是有意而为之。在严格模式下如果像这样给未声明的变量赋值则会导致抛出ReferenceError。 多个变量 var name kin;age 12;变量提升 function foo(){console.log(age);var age 26; } foo(); // undefined声明的变量会自动提升到函数作用域顶部 成等价于如下代码 function foo(){var age;console.log(age);age 26; } foo();//undefined提升------把所有变量声明都拉到函数作用域的顶部 function foo(){var age 16;var age 26;var age 36;console.log(age); } foo();//36反复多次使用var声明同一个变量 let关键字 let声明的范围是块作用域var声明的范围是函数作用域。 if(true){var name kin;console.log(name);//kin } console.log(name);//kin对比 if(true){let age 26;console.log(age);//26 } console.log(age);//ReferenceError:age 没有定义age变量不能在if块外部被引用是因为他的作用域仅限于该块内容。 块作用域是函数作用域的子集因此适用于var的作用域限制同样也适用于let。 注意 let也不允许同一个块作用域对一个变量重复声明。 var name; var name;let age; let age;//SyntaxError;标识符age已经声明过了由于同一个块中没有重复声明嵌套使用相同的标识符不会报错。 var name kin; console.log(name);//kin if(true){var name 前端;console.log(name);//前端 }let age 30 console.log(age);//30if(true){let age 26;console.log(age);//26 }暂时性死区 let与var重要的区别 let声明的变量不会再作用域中被提升 var声明 console.log(name)//undefined var name kinlet声明 console.log(age) let age 18 //ReferenceError:age 没有定义在let声明之前的执行瞬间被称为“暂时性死区”在此阶段引用任何后面才声明的变量都会抛出ReferenceError。 全局声明 使用let在全局作用域中声明的变量不会成为window对象的属性。 var name kin; console.log(window.name);//kin let age 26; console.log(window.age);//undefinedfor循环中使用let 使用var在for循环中定义的迭代变量会渗透到循环体外 for (var i0;i5;i){ } console.log(i);//5使用let在循环中定义的迭代变量仅限于循环块内部 for (let i0;i5;i){ } console.log(i);//ReferenceError: i is not defined示例 for (var i0;i5;i){setTimeout(()console.log(i),0) } //你认为输出的结果是0、1、2、3、4 //实际输出5、5、5、5、5 因为在循环退出的时候迭代变量报错的事导致循环退出的值5在之后执行超时逻辑所有的i都是同一个变量。使用let可以解决这个问题 for (let i0;i5;i){setTimeout(()console.log(i),0) } //0 1 2 3 4const关键字 const的行为与let基本相同。 区别 用const声明变量时必须同时初始化变量修改const声明的变量会导致运行时错误 const age 18; age 20 // TypeError : 给常量赋值 //const 也不允许重复声明 const name kin; const name nnn;//SyntaxErrorconst声明的作用域也是块 const name kin; if(true){const name nnn; } console.log(name);//kinok!目前就这些啦大家有问题欢迎评论区讨论呀
http://www.yutouwan.com/news/253177/

相关文章:

  • 重庆新闻频道直播 今天重庆seo博客
  • 上街免费网站建设西安微信商城网站开发
  • 有没有什么做水利资料的网站联盟营销是一种什么的网络营销方式
  • 国家建设工程网查询徐州关键词优化平台
  • 优化的网站做域名跳转毅冰做外贸是哪个网站
  • 网站中留言板怎么做锡林浩特网站建设微信开发
  • 大兴建设网站公司网页界面设计的网络系统有哪些
  • 优秀电商网站长沙建站模板大全
  • 西安网站有哪些手续费成都著名设计师
  • 有什么网站是做名片印刷的企业门户源码
  • 网站销售流程怎么做网页小猪佩奇
  • 无锡企业网站建设费用个人网页生成器
  • 即墨建网站价格内容网站设计范例
  • 企业网站开发计划书展厅展览
  • 上线了如何制作网站手机网页游戏排行榜2021前十名
  • 北京专业网站的建设建网站规则
  • 发布asp.net网站到虚拟主机广州网站建设的地方推荐
  • 免费给人做网站的wordpress评论表情不显示
  • 在工作室上班网站建设会好吗wordpress 婚庆
  • 做网站和视频剪辑用曲面屏wordpress 底部模板
  • 自行建网站 所需费用微信公众号怎么做预约功能
  • 专业做红木家具网站网站网站 后缀gr
  • 成都网站建设四川冠辰温州公司网址公司
  • 如何在网站网站做代理沈阳网页设计招聘
  • 不花钱可以做网站吗网站建设及推广服务的合同范本
  • 教人做衣服得网站有哪些wordpress数字添加链接
  • 网站建设300元wordpress xss漏洞利用
  • pc网站优化排名软件学做网站要学什么软件
  • 什么网站可以接活在家做越南做彩票网站是违法的吗
  • 写作网站的文风定制型网站建设