for循环中的switch case

今天写代码时遇到一个问题

var 没有块级作用域!

var 没有块级作用域!

var 没有块级作用域!

1
2
3
4
5
6
7
8
9
10
11
12
13
for (var i = 0; i < 3; i++) {
var a = '1'
switch (a) {
case '1':
for (var i=0;i<3;i++){

}
break
case '2':
break
}
console.log(i)
}

本来我想让

a=’1’ 时执行case ‘1’

a=’2’ 时执行case ‘2’

结果偏偏不执行case ‘2’

当然,业务比这复杂得多

经过调试:

  • 第一次循环i=0
  • 然后进入case ‘1’
  • i=4
  • 结束外层循环
  • 所以控制台打印4之后就结束了

实际上是个var没有块级作用域问题,

用let就可以解决,

但这种问题真正在实际复杂应用中就很难发现了,

JS基础真的是很重要,

以后能用let尽量不用var真的时太坑了

canvas 实现图片打码

我的收获

  • 对基础api的掌握
    • ctx.drawImage(img, x, y, img.width, img.height)
    • 获取像素 ctx.getImageData(x1, y1, x2, y2) 返回的对象有三个属性,width、height、data(所有像素的rgba做成的数组)
    • 设置像素ctx.putImageData(imageData, x, y)
    • 创建像素区域,默认黑色透明 ctx.createImageData(width, height)
  • 难点
    • 封装两个方法:取像素点的rgba、设置像素点的rgba
    • 打码:取一块像素区域中的rbga覆盖整个像素区域

canvas 画一个时钟

  • 原来canvas还有作用域这回事儿

  • canvas中的save()和restore()限定了样式的作用范围(包括:fillStyle、strokeStyle、lineWidth、lineCap以及一些变换方法)

  • 用户友好处理,在canvas标签中向用户给出canvas不兼容的提示和处理方法

  • 基本上用这样的套路去绘制

    1
    2
    3
    4
    5
    canvas.save()
    //这里写样式
    canvas.beginPath()
    //这里绘图形
    canvas.restore()
  • 以上是我干完这活儿的全部收获

猴子与打字机

有一个挺有趣的定理:猴子与打字机

猴子和打字机(Monkeys and Typewriters),如果无数多的猴子在无数多的打字机上随机的打字,并持续无限久的时间,那么在某个时候,它们必然会打出莎士比亚的全部著作。猴子和打字机的设想在20世纪初被法国数学家Emile Borel推广,但其基本思想——无数多的人员和无数多的时间能产生任何/所有东西——可以追溯至亚里士多德。 来自:百度百科

es6 精炼

let 和 const

  • let有块作用域
    • 在同一个作用域内,let声明的变量不能重复
    • var 定义的变量会提升
    • let 定义的变量不提升,不能在声明前使用
  • const 有块级作用域
    • 一旦赋值不能改变
    • 声明必赋值
    • let user = {}
      • const PERSON = user
      • user改变,PERSON不会报错,因为PERSON的值是个指针
Your browser is out-of-date!

Update your browser to view this website correctly. Update my browser now

×

// tidio机器人助手