Live Note

Remain optimistic

原型模式

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
let LoopImages = function (imageArr, container) {
this.imageArr = imageArr
this.container = container
}
LoopImages.prototype = {
createImage: function () {
console.log("create image")
},
changeImage: function () {
console.log("change image")
},
}

let SlideLoopImg = function (imageArr, container) {
LoopImages.call(this, imageArr, container)
}
SlideLoopImg.prototype = new LoopImages() // 继承
SlideLoopImg.prototype.changeImage = () => {
// 重写
console.log("slide loop change image")
}

// for test
let slideImage = new SlideLoopImg(["1.jpg", "2.jpg"], "slide")
console.log(slideImage.container)
slideImage.changeImage()

原型继承

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
/**
* copy object
*/
function prototypeExtend() {
let F = function () {}
// let F = new Function()

for (let i = 0; i < arguments.length; i++) {
for (let j in arguments[i]) {
F.prototype[j] = arguments[i][j]
}
}

return new F()
}

// for test
let car = prototypeExtend(
{
speed: 20,
fast: function () {
this.speed++
console.log("is faster")
},
},
{
slow: function () {
this.speed--
console.log("is slower")
},
},
{
stop: function () {
this.speed = 0
console.log("is stop")
},
},
{
currentSpeed: function () {
console.log(this.speed)
},
}
)

car.fast()
car.fast()
car.fast()
car.fast()

car.currentSpeed()
car.stop()

car.currentSpeed()

邻接表

存储方式:表头存放节点,相邻节点存放于之后的链表中。
** 使用 Map 模拟 **

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
class Graph {
constructor() {
this.point = []
this.map = new Map()
}

addPoint(point) {
this.point.push(point)
this.map.set(point, [])
}

// 无向
addEdge(pointA, pointB) {
this.map.get(pointA).push(pointB)
this.map.get(pointB).push(pointA)
}

print() {
for (let item of this.point) {
console.log(item + " -> " + this.map.get(item).join(","))
}
}
}

Test

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
var graph = new Graph()
var topArr = ["A", "B", "C", "D", "E", "F", "G", "H", "I"]
for (let item of topArr) {
graph.addPoint(item)
}

graph.addEdge("A", "B")
graph.addEdge("A", "D")
graph.addEdge("A", "E")
graph.addEdge("A", "H")
graph.addEdge("F", "G")
graph.addEdge("I", "B")
graph.addEdge("I", "C")

graph.print()

教育部关于同意复旦大学章程部分条款修改的批复 教政法函〔2019〕18 号

重点修改如下:

序言第一段

“国人自主创办”改为“中国人自主创办”。

序言第二段

删去“学校的办学理念是其校歌所传颂的……思想自由……强调以学术精神滋养师生,坚守价值,治学严谨,为学有恒。学校始终秉持团结、服务与牺牲的精神,强调学校、师生的社会责任和国家使命。”增加“敦行爱国奉献……海纳百川、追求卓越。学校倡导‘文明、健康、团结、奋发’的校风和‘刻苦、严谨、求实、创新’的学风,强调坚持理想、探究真理、正谊明道、守护文明。”

Read more »

codePointAt()

JavaScript-16 的格式储存,每个字符固定为两个字节。需要四个字节储存的字符,JavaScript 会认为那是两个字符。
ES6 提供了 codePointAt 方法,能够正确处理四个字节储存的字符,返回一个字符的码点。

String.fromCodePoint()

识别 UTF-32 字符。

includes()、startsWith()、endsWith()

1
2
3
4
5
6
7
var s = "hello world"
s.startWith("hello") //true
s.endsWith("d") //true
s.includes("o") //true

s.startsWith("world", 6) //true;
s.includes("hello", 6) //false

repeat()

1
2
3
4
5
6
7
8
9
10
11
"x".repeat(3) //'xxx'
"na".repeat(0) //''

"na".repeat(2.9) //取整 -> 'nana'

"na".repeat(Infinity) //Error
"na".repeat(-1) //Error

"na".repeat(-0.9) //''
"na".repeat(NaN) //''
"na".repeat("3") //'nanana'
Read more »

属性名表达式

JavaScript 定义属性有两种方法:

1
2
obj.foo = true
obj["a" + "bc"] = 123

ES6 允许字面量定义对象时使用第二种方法:

1
2
3
4
5
6
7
8
let propKey = "foo"
let obj = {
[propKey]: true,
["a" + "bc"]: 123,
["he" + "llo"]() {
return "hi"
},
}
Read more »