bug记录

1.函数内递归循环

return 跳不出函数结果

解决

少写for if循环,因为每次返回的是当前循环
声明bool形参,条件true不写,只判断返回false,标记法

2.js在if语句中的函数声明会不会得到函数提升?

https://blog.csdn.net/qq_36616301/article/details/114892297
https://blog.csdn.net/weixin_44481301/article/details/105786938

总结

在if{}里面声明函数会提升,但是提升的是不完整的,提升到外面只是函数名(undefined),把函数整体当个值看待赋给函数名。提升到内部顶层
当执行到函数这句话时,才是真的函数体。赋值给外部(块级作用域函数只有执行函数声明语句的时候,才会重写对应的全局作用域上的同名变量
块级作用域函数只有执行函数声明语句的时候,才会重写对应的全局作用域上的同名变量。
[注]:es6块级作用域的出现,{}里面声明函数是非法的,但是又不能报错,所以各浏览器为了兼容,自行处理的结果。

  • 企鹅自己在这里总结了几点来解决此类问题
    • if语句内的函数无论是否被执行,同样会被声明到当前作用域的顶部,只不过值不是函数体,你可以理解成披着函数的外衣但是值却是undefined,而在变量声明与函数声明中,毫无疑问,身为函数一等公民的函数声明优先级要高于变量声明。
    • if语句内即{}内被视为一个块级作用域,变量以及函数在此处遵循一般的声明规则
    • 在执行到函数声明时,当前作用域那个函数声明的变量会被赋值为函数体
    • 引用mdn的一句话,函数可以被有条件来声明,这意味着,函数声明可能出现在一个 if 语句里,但是,这种声明方式在不同的浏览器里可能有不同的效果。因此,不应该在生成环境代码中使用这种声明方式,应该使用函数表达式来代替。
    • 切记此方法仅适用于es5
	var a = 1;
	if(true){
	    console.log(a) // 1
	    if (true) {
	        function a() {}
	    }
	    a()
	}
	console.log(a) // a() {}
    console.log(window.a, a);//undefined undefined
    if (true) {
      console.log(window.a, a);//undefined function a(){}
      a = 10;
      console.log(window.a, a); //undefined 10  
      function a() { };//当执行到函数体,才会重写对应的全局作用域上的同名变量
      console.log(window.a, a); //10  10
    };
    console.log(window.a, a); //10 10

3.

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值