登录  /  注册
博主信息
博文 94
粉丝 0
评论 0
访问量 89417
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
【JS】JS作用域、字面量简化总结 【简化为重点】
可乐随笔
原创
701人浏览过

作用域、字面量简化

作用域、作用域链

  • 作用域
  • 作用域:查询变量的工具
  • 作用域链:查询变量的路径(由内向外不可逆)

  • 作用域类型

    1. 块作用域
    1. 函数作用域
    1. 全局使用域

1. 块使用域

  1. // 流程控制,{},if,while,...
  2. {
  3. let name = 'admin'
  4. console.log(name);
  5. }
  6. // 仅限块内,外部不可见
  7. // console.log(name);
  8. console.log('----------------------')

2. 函数作用域

  1. const hello = function(){
  2. //私有成员
  3. const site = 'php.cn'
  4. //私有成员,函数内部可以访问
  5. console.log(site)
  6. }
  7. //访问函数hello
  8. hello()
  9. console.log('----------------------')

3. 全局作用域

  1. // 块,函数之外的都是全局,全局可见
  2. const course = 'JavaScript'
  3. //块
  4. {
  5. console.log(course)
  6. }
  7. console.log('----------------------')

4. 作用域链

  1. const item = '手机'
  2. const scopeChain = function(){
  3. //const item = '电脑'
  4. return function(){
  5. //const item = '相机'
  6. return item
  7. }
  8. }
  9. console.log(scopeChain()())
  10. //函数中的变量和全局中变量不是同一个变量,如果在函数中找不到变量,会向上查找。
  11. //这个就叫作用域链

对象字面量的简化

  1. **class**,只支持简化语法
  2. let product = {
  3. productName: '华为(MateXs2)',
  4. unitPrice: 9999,
  5. getInfo: function(){
  6. return `${this.productName} : ${this.unitPrice} 元`
  7. },
  8. }
  9. console.log(product.getInfo());
  10. const productName = '华为(MateXs2)'
  11. const unitPrice = 9999
  12. product = {
  13. productName: productName,
  14. unitPrice: unitPrice,
  15. getInfo: function(){
  16. return `${this.productName} : ${this.unitPrice} 元`
  17. },
  18. }
  19. console.log(product.getInfo());
  20. console.log('----------------------')

1. 属性简化

  1. product = {
  2. //当属性名与变量名相同时,可只写属性名,不写值变量名
  3. //可以理解为这里引用了上面的变量。
  4. productName,
  5. unitPrice,
  6. getInfo: function(){
  7. return `${this.productName} : ${this.unitPrice} 元`
  8. },
  9. }
  10. console.log(product.getInfo());
  11. console.log('----------------------')

2. 方法简化

  1. product = {
  2. productName,
  3. unitPrice,
  4. //将 冒号和function删除,就完成了简化
  5. //可以理解为:这里定义了一个getInfo()函数
  6. // getInfo: function(){
  7. getInfo() {
  8. return `${this.productName} : ${this.unitPrice} 元`
  9. },
  10. }
  11. console.log(product.getInfo());
  12. console.log('----------------------')
  13. // ! 能不能用箭头函数来简化方法? 不行 NO
  14. product = {
  15. productName,
  16. unitPrice,
  17. //箭头函数,箭头函数没有函数名,拿不到this
  18. getInfo : () => {
  19. return `${this.productName} : ${this.unitPrice} 元`
  20. },
  21. }
  22. console.log(product.getInfo());
  23. console.log('----------------------')
本博文版权归博主所有,转载请注明地址!如有侵权、违法,请联系admin@php.cn举报处理!
全部评论 文明上网理性发言,请遵守新闻评论服务协议
0条评论
作者最新博文
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2024 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号

  • 登录PHP中文网,和优秀的人一起学习!
    全站2000+教程免费学