-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathFreePic2Pdf_bkmk.txt
1203 lines (1203 loc) · 31.9 KB
/
FreePic2Pdf_bkmk.txt
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
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
692
693
694
695
696
697
698
699
700
701
702
703
704
705
706
707
708
709
710
711
712
713
714
715
716
717
718
719
720
721
722
723
724
725
726
727
728
729
730
731
732
733
734
735
736
737
738
739
740
741
742
743
744
745
746
747
748
749
750
751
752
753
754
755
756
757
758
759
760
761
762
763
764
765
766
767
768
769
770
771
772
773
774
775
776
777
778
779
780
781
782
783
784
785
786
787
788
789
790
791
792
793
794
795
796
797
798
799
800
801
802
803
804
805
806
807
808
809
810
811
812
813
814
815
816
817
818
819
820
821
822
823
824
825
826
827
828
829
830
831
832
833
834
835
836
837
838
839
840
841
842
843
844
845
846
847
848
849
850
851
852
853
854
855
856
857
858
859
860
861
862
863
864
865
866
867
868
869
870
871
872
873
874
875
876
877
878
879
880
881
882
883
884
885
886
887
888
889
890
891
892
893
894
895
896
897
898
899
900
901
902
903
904
905
906
907
908
909
910
911
912
913
914
915
916
917
918
919
920
921
922
923
924
925
926
927
928
929
930
931
932
933
934
935
936
937
938
939
940
941
942
943
944
945
946
947
948
949
950
951
952
953
954
955
956
957
958
959
960
961
962
963
964
965
966
967
968
969
970
971
972
973
974
975
976
977
978
979
980
981
982
983
984
985
986
987
988
989
990
991
992
993
994
995
996
997
998
999
1000
1. The JavaScript language 1
1.1 An introduction 2
1.1.1 An Introduction to JavaScript 3
1.1.2 Manuals and specifications 9
1.1.3 Code editors 12
1.1.4 Developer console 16
1.2 JavaScript Fundamentals 20
1.2.1 Hello, world! 21
1.2.2 Code structure 27
1.2.3 The modern mode, "use strict" 33
1.2.4 Variables 37
1.2.5 Data types 47
1.2.6 Interaction: alert, prompt, confirm 57
1.2.7 Type Conversions 64
1.2.8 Basic operators, maths 74
1.2.9 Comparisons 88
1.2.10 Conditional branching: if, '?' 95
1.2.11 Logical operators 105
1.2.12 Nullish coalescing operator '??' 116
1.2.13 Loops: while and for 123
1.2.14 The "switch" statement 137
1.2.15 Functions 143
1.2.16 Function expressions 158
1.2.17 Arrow functions, the basics 168
1.2.18 JavaScript specials 174
1.3 Code quality 183
1.3.1 Debugging in the browser 184
1.3.2 Coding Style 193
1.3.3 Comments 205
1.3.4 Ninja code 213
1.3.5 Automated testing with Mocha 221
1.3.6 Polyfills and transpilers 235
1.4 Objects: the basics 240
1.4.1 Objects 241
1.4.2 Object references and copying 256
1.4.3 Garbage collection 266
1.4.4 Object methods, "this" 277
1.4.5 Constructor, operator "new" 287
1.4.6 Optional chaining '?.' 298
1.4.7 Symbol type 306
1.4.8 Object to primitive conversion 315
1.5 Data types 323
1.5.1 Methods of primitives 324
1.5.2 Numbers 331
1.5.3 Strings 347
1.5.4 Arrays 361
1.5.5 Array methods 378
1.5.6 Iterables 402
1.5.7 Map and Set 414
1.5.8 WeakMap and WeakSet 425
1.5.9 Object.keys, values, entries 436
1.5.10 Destructuring assignment 441
1.5.11 Date and time 456
1.5.12 JSON methods, toJSON 472
1.6 Advanced working with functions 487
1.6.1 Recursion and stack 488
1.6.2 Rest parameters and spread syntax 505
1.6.3 Variable scope, closure 514
1.6.4 The old "var" 533
1.6.5 Global object 542
1.6.6 Function object, NFE 546
1.6.7 The "new Function" syntax 557
1.6.8 Scheduling: setTimeout and setInterval 563
1.6.9 Decorators and forwarding, call/apply 575
1.6.10 Function binding 591
1.6.11 Arrow functions revisited 603
1.7 Object properties configuration 611
1.7.1 Property flags and descriptors 612
1.7.2 Property getters and setters 622
1.8 Prototypes, inheritance 630
1.8.1 Prototypal inheritance 631
1.8.2 F.prototype 644
1.8.3 Native prototypes 653
1.8.4 Prototype methods, objects without __proto__ 663
1.9 Classes 673
1.9.1 Class basic syntax 674
1.9.2 Class inheritance 687
1.9.3 Static properties and methods 705
1.9.4 Private and protected properties and methods 714
1.9.5 Extending built-in classes 726
1.9.6 Class checking: "instanceof" 731
1.9.7 Mixins 739
1.10 Error handling 748
1.10.1 Error handling, "try...catch" 749
1.10.2 Custom errors, extending Error 766
1.11 Promises, async/await 776
1.11.1 Introduction: callbacks 777
1.11.2 Promise 785
1.11.3 Promises chaining 797
1.11.4 Error handling with promises 809
1.11.5 Promise API 817
1.11.6 Promisification 826
1.11.7 Microtasks 833
1.11.8 Async/await 839
1.12 Generators, advanced iteration 850
1.12.1 Generators 851
1.12.2 Async iteration and generators 865
1.13 Modules 877
1.13.1 Modules, introduction 878
1.13.2 Export and Import 891
1.13.3 Dynamic imports 903
1.14 Miscellaneous 909
1.14.1 Proxy and Reflect 910
1.14.2 Eval: run a code string 937
1.14.3 Currying 942
1.14.4 Reference Type 951
1.14.5 BigInt 956
1.14.6 Unicode, String internals 963
2. Browser: Document, Events, Interfaces 967
2.1 Document 968
2.1.1 Browser environment, specs 969
2.1.2 DOM tree 974
2.1.3 Walking the DOM 985
2.1.4 Searching: getElement*, querySelector* 998
2.1.5 Node properties: type, tag and contents 1008
2.1.6 Attributes and properties 1023
2.1.7 Modifying the document 1036
2.1.8 Styles and classes 1061
2.1.9 Element size and scrolling 1072
2.1.10 Window sizes and scrolling 1087
2.1.11 Coordinates 1093
2.2 Introduction to Events 1109
2.2.1 Introduction to browser events 1110
2.2.2 Bubbling and capturing 1126
2.2.3 Event delegation 1137
2.2.4 Browser default actions 1151
2.2.5 Dispatching custom events 1165
2.3 UI Events 1174
2.3.1 Mouse events 1175
2.3.2 Moving the mouse: mouseover/out, mouseenter/leave 1186
2.3.3 Drag'n'Drop with mouse events 1210
2.3.4 Pointer events 1222
2.3.5 Keyboard: keydown and keyup 1231
2.3.6 Scrolling 1242
2.4 Forms, controls 1249
2.4.1 Form properties and methods 1250
2.4.2 Focusing: focus/blur 1259
2.4.3 Events: change, input, cut, copy, paste 1272
2.4.4 Forms: event and method submit 1279
2.5 Document and resource loading 1284
2.5.1 Page: DOMContentLoaded, load, beforeunload, unload 1285
2.5.2 Scripts: async, defer 1296
2.5.3 Resource loading: onload and onerror 1304
2.6 Miscellaneous 1312
2.6.1 Mutation observer 1313
2.6.2 Selection and Range 1323
2.6.3 Event loop: microtasks and macrotasks 1341
3. Additional articles 1352
3.1 Frames and windows 1353
3.1.1 Popups and window methods 1354
3.1.2 Cross-window communication 1363
3.1.3 The clickjacking attack 1375
3.2 Binary data, files 1384
3.2.1 ArrayBuffer, binary arrays 1385
3.2.2 TextDecoder and TextEncoder 1396
3.2.3 Blob 1400
3.2.4 File and FileReader 1409
3.3 Network requests 1417
3.3.1 Fetch 1418
3.3.2 FormData 1428
3.3.3 Fetch: Download progress 1436
3.3.4 Fetch: Abort 1442
3.3.5 Fetch: Cross-Origin Requests 1446
3.3.6 Fetch API 1459
3.3.7 URL objects 1466
3.3.8 XMLHttpRequest 1474
3.3.9 Resumable file upload 1486
3.3.10 Long polling 1490
3.3.11 WebSocket 1500
3.3.12 Server Sent Events 1511
3.4 Storing data in the browser 1519
3.4.1 Cookies, document.cookie 1520
3.4.2 LocalStorage, sessionStorage 1532
3.4.3 IndexedDB 1540
3.5 Animation 1560
3.5.1 Bezier curve 1561
3.5.2 CSS-animations 1573
3.5.3 JavaScript animations 1597
3.6 Web components 1614
3.6.1 From the orbital height 1615
3.6.2 Custom elements 1619
3.6.3 Shadow DOM 1631
3.6.4 Template element 1637
3.6.5 Shadow DOM slots, composition 1640
3.6.6 Shadow DOM styling 1651
3.6.7 Shadow DOM and events 1658
3.7 Regular expressions 1664
3.7.1 Patterns and flags 1665
3.7.2 Character classes 1671
3.7.3 Unicode: flag "u" and class \p{...} 1676
3.7.4 Anchors: string start ^ and end $ 1682
3.7.5 Multiline mode of anchors ^ $, flag "m" 1686
3.7.6 Word boundary: \b 1690
3.7.7 Escaping, special characters 1694
3.7.8 Sets and ranges [...] 1697
3.7.9 Quantifiers +, *, ? and {n} 1703
3.7.10 Greedy and lazy quantifiers 1707
3.7.11 Capturing groups 1718
3.7.12 Backreferences in pattern: \N and \k<name> 1730
3.7.13 Alternation (OR) | 1733
3.7.14 Lookahead and lookbehind 1739
3.7.15 Catastrophic backtracking 1745
3.7.16 Sticky flag "y", searching at position 1752
3.7.17 Methods of RegExp and String 1756
What is JavaScript? 3
What can in-browser JavaScript do? 3
What CAN’T in-browser JavaScript do? 4
What makes JavaScript unique? 5
Languages “over” JavaScript 5
Summary 6
Specification 9
Manuals 9
Compatibility tables 9
IDE 12
Lightweight editors 12
Let’s not argue 12
Google Chrome 16
Firefox, Edge, and others 17
Safari 17
Summary 17
The “script” tag 21
Modern markup 21
External scripts 22
Summary 23
Tasks 23
Statements 27
Semicolons 27
Comments 28
“use strict” 33
Browser console 34
Should we “use strict”? 34
A variable 37
A real-life analogy 38
Variable naming 40
Constants 41
Name things right 42
Summary 43
Tasks 43
Number 47
BigInt 48
String 49
Boolean (logical type) 49
The “null” value 50
The “undefined” value 50
Objects and Symbols 51
The typeof operator 51
Summary 52
Tasks 52
alert 57
prompt 57
confirm 58
Summary 58
Tasks 59
String Conversion 64
Numeric Conversion 64
Boolean Conversion 65
Summary 66
Terms: “unary”, “binary”, “operand” 74
Maths 74
String concatenation with binary + 75
Numeric conversion, unary + 76
Operator precedence 77
Assignment 77
Modify-in-place 79
Increment/decrement 79
Bitwise operators 81
Comma 82
Tasks 82
Boolean is the result 88
String comparison 88
Comparison of different types 89
Strict equality 90
Comparison with null and undefined 91
Summary 92
Tasks 92
The “if” statement 95
Boolean conversion 95
The “else” clause 96
Several conditions: “else if” 96
Conditional operator ‘?’ 96
Multiple ‘?’ 97
Non-traditional use of ‘?’ 98
Tasks 99
|| (OR) 105
OR "||" finds the first truthy value 106
&& (AND) 107
AND “&&” finds the first falsy value 107
! (NOT) 109
Tasks 110
Comparison with || 117
Precedence 118
Summary 118
The “while” loop 123
The “do…while” loop 124
The “for” loop 124
Breaking the loop 127
Continue to the next iteration 127
Labels for break/continue 128
Summary 130
Tasks 130
The syntax 137
An example 137
Grouping of “case” 139
Type matters 139
Tasks 140
Function Declaration 143
Local variables 143
Outer variables 144
Parameters 145
Default values 146
Returning a value 148
Naming a function 150
Functions == Comments 151
Summary 152
Tasks 153
Function is a value 158
Callback functions 160
Function Expression vs Function Declaration 161
Summary 164
Multiline arrow functions 169
Summary 169
Tasks 170
Code structure 174
Strict mode 174
Variables 175
Interaction 175
Operators 176
Loops 177
The “switch” construct 177
Functions 178
More to come 179
The “Sources” panel 184
Console 185
Breakpoints 185
The command “debugger” 186
Pause and look around 186
Tracing the execution 187
Logging 188
Summary 188
Syntax 193
Function Placement 197
Style Guides 198
Automated Linters 198
Summary 199
Tasks 199
Bad comments 205
Good comments 207
Summary 208
Brevity is the soul of wit 213
One-letter variables 213
Use abbreviations 214
Soar high. Be abstract. 214
Attention test 214
Smart synonyms 215
Reuse names 215
Underscores for fun 216
Show your love 216
Overlap outer variables 216
Side-effects everywhere! 216
Powerful functions! 217
Summary 217
Why do we need tests? 221
Behavior Driven Development (BDD) 221
Development of “pow”: the spec 221
The development flow 222
The spec in action 222
Initial implementation 224
Improving the spec 224
Improving the implementation 225
Nested describe 226
Extending the spec 228
Summary 230
Tasks 231
Transpilers 235
Polyfills 235
Summary 236
Literals and properties 241
Square brackets 243
Property value shorthand 245
Property names limitations 246
Property existence test, “in” operator 247
The "for..in" loop 248
Summary 250
Tasks 250
Comparison by reference 257
Cloning and merging, Object.assign 258
Nested cloning 260
Summary 262
Reachability 266
A simple example 266
Two references 267
Interlinked objects 267
Unreachable island 269
Internal algorithms 270
Summary 272
Method examples 277
“this” in methods 278
“this” is not bound 279
Arrow functions have no “this” 281
Summary 281
Tasks 281
Constructor function 287
Constructor mode test: new.target 288
Return from constructors 289
Methods in constructor 290
Summary 290
Tasks 291
The “non-existing property” problem 298
Optional chaining 299
Short-circuiting 300
Other variants: ?.(), ?.[] 301
Summary 302
Symbols 306
“Hidden” properties 307
Global symbols 309
System symbols 310
Summary 310
Conversion rules 315
Hints 315
Symbol.toPrimitive 317
toString/valueOf 317
Further conversions 319
Summary 320
A primitive as an object 324
Summary 326
Tasks 327
More ways to write a number 331
toString(base) 332
Rounding 333
Imprecise calculations 334
Tests: isFinite and isNaN 336
parseInt and parseFloat 338
Other math functions 339
Summary 339
Tasks 340
Quotes 347
Special characters 348
String length 349
Accessing characters 349
Strings are immutable 350
Changing the case 350
Searching for a substring 350
Getting a substring 353
Comparing strings 354
Summary 356
Tasks 356
Declaration 361
Get last elements with “at” 362
Methods pop/push, shift/unshift 363
Internals 365
Performance 366
Loops 367
A word about “length” 368
new Array() 368
Multidimensional arrays 369
toString 369
Don’t compare arrays with == 369
Summary 370
Tasks 371
Add/remove items 378
Iterate: forEach 381
Searching in array 382
Transform an array 384
Array.isArray 390
Most methods support “thisArg” 390
Summary 391
Tasks 392
Symbol.iterator 402
String is iterable 404
Calling an iterator explicitly 404
Iterables and array-likes 405
Array.from 405
Summary 407
Map 414
Iteration over Map 415
Object.entries: Map from Object 416
Object.fromEntries: Object from Map 417
Set 418
Iteration over Set 419
Summary 419
Tasks 420
WeakMap 426
Use case: additional data 426
Use case: caching 428
WeakSet 429
Summary 430
Tasks 430
Object.keys, values, entries 436
Transforming objects 437
Tasks 438
Array destructuring 441
Object destructuring 445
Nested destructuring 448
Smart function parameters 449
Summary 451
Tasks 451
Creation 456
Access date components 457
Setting date components 458
Autocorrection 459
Date to number, date diff 459
Date.now() 460
Benchmarking 460
Date.parse from a string 462
Summary 463
Tasks 464
JSON.stringify 472
Excluding and transforming: replacer 475
Formatting: space 477
Custom “toJSON” 478
JSON.parse 479
Using reviver 480
Summary 481
Tasks 481
Two ways of thinking 488
The execution context and stack 490
Recursive traversals 493
Recursive structures 495
Summary 498
Tasks 498
Rest parameters ... 505
The “arguments” variable 506
Spread syntax 507
Copy an array/object 509
Summary 509
Code blocks 514
Nested functions 515
Lexical Environment 516
Garbage collection 521
Tasks 523
“var” has no block scope 533
“var” tolerates redeclarations 534
“var” variables can be declared below their use 534
IIFE 536
Summary 537
Using for polyfills 543
Summary 543
The “name” property 546
The “length” property 547
Custom properties 548
Named Function Expression 549
Summary 551
Tasks 552
Syntax 557
Closure 557
Summary 558
setTimeout 563
setInterval 564
Nested setTimeout 565
Zero delay setTimeout 567
Summary 568
Tasks 569
Transparent caching 575
Using “func.call” for the context 576
Going multi-argument 578
func.apply 580
Borrowing a method 581
Decorators and function properties 582
Summary 582
Tasks 582
Losing “this” 591
Solution 1: a wrapper 591
Solution 2: bind 592
Partial functions 594
Going partial without context 595
Summary 596
Tasks 596
Arrow functions have no “this” 603
Arrows have no “arguments” 604
Summary 605
Property flags 612
Non-writable 613
Non-enumerable 614
Non-configurable 615
Object.defineProperties 616
Object.getOwnPropertyDescriptors 617
Sealing an object globally 617
Getters and setters 622
Accessor descriptors 623
Smarter getters/setters 624
Using for compatibility 625
[[Prototype]] 631
Writing doesn’t use prototype 634
The value of “this” 635
for…in loop 636
Summary 638
Tasks 638
Default F.prototype, constructor property 645
Summary 647
Tasks 647
Object.prototype 653
Other built-in prototypes 654
Primitives 655
Changing native prototypes 656
Borrowing from prototypes 657
Summary 657
Tasks 657
Brief history 664
"Very plain" objects 664
Summary 666
Tasks 667
The “class” syntax 674
What is a class? 675
Not just a syntactic sugar 676
Class Expression 677
Getters/setters 678
Computed names […] 678
Class fields 679
Summary 680
Tasks 681
The “extends” keyword 687
Overriding a method 689
Overriding constructor 690
Super: internals, [[HomeObject]] 694
Summary 698
Tasks 699
Static properties 707
Inheritance of static properties and methods 707
Summary 708
Tasks 709
A real-life example 714
Internal and external interface 715
Protecting “waterAmount” 716
Read-only “power” 717
Private “#waterLimit” 718
Summary 720
No static inheritance in built-ins 727
The instanceof operator 731
Bonus: Object.prototype.toString for the type 733
Summary 735
Tasks 735
A mixin example 739
EventMixin 741
Summary 743
The “try…catch” syntax 749
Error object 751
Optional “catch” binding 752
Using “try…catch” 752
Throwing our own errors 753
Rethrowing 755
try…catch…finally 757
Global catch 759
Summary 760
Tasks 761
Extending Error 766
Further inheritance 768
Wrapping exceptions 770
Summary 772
Tasks 772
Callback in callback 779
Handling errors 779
Pyramid of Doom 780
Consumers: then, catch 788
Cleanup: finally 789
Example: loadScript 791
Tasks 792
Returning promises 799
Example: loadScript 799
Bigger example: fetch 801
Summary 804
Tasks 804
Implicit try…catch 809
Rethrowing 810
Unhandled rejections 811
Summary 812
Tasks 812
Promise.all 817
Promise.allSettled 819
Promise.race 820
Promise.any 821
Promise.resolve/reject 822
Summary 823
Microtasks queue 833
Unhandled rejection 834
Summary 834
Async functions 839
Await 839
Error handling 842
Summary 844
Tasks 844
Generator functions 851
Generators are iterable 853
Using generators for iterables 854
Generator composition 855
“yield” is a two-way street 857
generator.throw 858
generator.return 859
Summary 860
Tasks 860
Recall iterables 865
Async iterables 866
Recall generators 867
Async generators (finally) 868
Real-life example: paginated data 870
Summary 872
What is a module? 878
Core module features 879
Browser-specific features 884
Build tools 887
Summary 887
Export before declarations 891
Export apart from declarations 891
Import * 892
Import “as” 892
Export “as” 893
Export default 893
Re-export 896
Summary 898
The import() expression 903
Proxy 910
Default value with “get” trap 912
Validation with “set” trap 913
Iteration with “ownKeys” and “getOwnPropertyDescriptor” 914
Protected properties with “deleteProperty” and other traps 916
“In range” with “has” trap 918
Wrapping functions: "apply" 919
Reflect 920
Proxy limitations 923
Revocable proxies 926
References 927
Summary 927
Tasks 928
Using “eval” 938
Summary 938
Tasks 939
Currying? What for? 943
Advanced curry implementation 944
Summary 945
Reference type explained 951
Summary 952
Tasks 953
Math operators 956
Comparisons 957
Boolean operations 957
Polyfills 957
References 958
Surrogate pairs 963
Diacritical marks and normalization 965
DOM (Document Object Model) 970
BOM (Browser Object Model) 970
Summary 971
An example of the DOM 974
Autocorrection 976
Other node types 977
See it for yourself 978
Interaction with console 980
Summary 981
On top: documentElement and body 985
Children: childNodes, firstChild, lastChild 986
Siblings and the parent 988
Element-only navigation 989
More links: tables 990
Summary 991
Tasks 991
document.getElementById or just id 998
querySelectorAll 999
querySelector 1000
matches 1000
closest 1000
getElementsBy* 1001
Live collections 1002
Summary 1003
Tasks 1004
DOM node classes 1008
The “nodeType” property 1010
Tag: nodeName and tagName 1011
innerHTML: the contents 1012
outerHTML: full HTML of the element 1013
nodeValue/data: text node content 1014
textContent: pure text 1015
The “hidden” property 1015
More properties 1016
Summary 1016
Tasks 1017
DOM properties 1023
HTML attributes 1024
Property-attribute synchronization 1025
DOM properties are typed 1026
Non-standard attributes, dataset 1027
Summary 1029
Tasks 1030
Example: show a message 1036
Creating an element 1036
Insertion methods 1037
insertAdjacentHTML/Text/Element 1039
Node removal 1040
Cloning nodes: cloneNode 1041
DocumentFragment 1042
Old-school insert/remove methods 1043
A word about “document.write” 1044
Summary 1045
Tasks 1046
className and classList 1061
Element style 1062
Resetting the style property 1063
Mind the units 1064
Computed styles: getComputedStyle 1064
Summary 1066
Tasks 1067
Sample element 1072
Geometry 1073
offsetParent, offsetLeft/Top 1074
offsetWidth/Height 1075
clientTop/Left 1076
clientWidth/Height 1077
scrollWidth/Height 1078
scrollLeft/scrollTop 1079
Don’t take width/height from CSS 1080
Summary 1081
Tasks 1082
Width/height of the window 1087
Width/height of the document 1088
Get the current scroll 1088
Scrolling: scrollTo, scrollBy, scrollIntoView 1088
scrollIntoView 1089
Forbid the scrolling 1089
Summary 1090
Element coordinates: getBoundingClientRect 1093
elementFromPoint(x, y) 1096
Using for “fixed” positioning 1096
Document coordinates 1097
Summary 1098
Tasks 1098
Event handlers 1110
Accessing the element: this 1112
Possible mistakes 1112
addEventListener 1113
Event object 1116
Object handlers: handleEvent 1117
Summary 1118
Tasks 1119
Bubbling 1126
event.target 1127
Stopping bubbling 1129
Capturing 1129
Summary 1132
Delegation example: actions in markup 1139
The “behavior” pattern 1140
Summary 1142
Tasks 1142
Preventing browser actions 1151
The “passive” handler option 1152
event.defaultPrevented 1153
Summary 1155
Tasks 1156
Event constructor 1165
dispatchEvent 1165
Bubbling example 1166
MouseEvent, KeyboardEvent and others 1166
Custom events 1167
event.preventDefault() 1168
Events-in-events are synchronous 1169
Summary 1170
Mouse event types 1175
Events order 1175
Mouse button 1176
Modifiers: shift, alt, ctrl and meta 1176
Coordinates: clientX/Y, pageX/Y 1177
Preventing selection on mousedown 1178
Summary 1179
Tasks 1179
Events mouseover/mouseout, relatedTarget 1186
Skipping elements 1188
Mouseout when leaving for a child 1190
Events mouseenter and mouseleave 1193
Event delegation 1195
Summary 1201
Tasks 1201
Drag’n’Drop algorithm 1210
Correct positioning 1212
Potential drop targets (droppables) 1213
Summary 1216
Tasks 1217
The brief history 1222
Pointer event types 1222
Pointer event properties 1223
Multi-touch 1223
Event: pointercancel 1224
Pointer capturing 1225
Summary 1227
Teststand 1231
Keydown and keyup 1233
Auto-repeat 1235
Default actions 1235
Legacy 1236
Mobile Keyboards 1236
Summary 1237
Tasks 1237
Prevent scrolling 1242
Tasks 1242
Navigation: form and elements 1250
Backreference: element.form 1252
Form elements 1253
References 1255
Summary 1255
Tasks 1256
Events focus/blur 1259
Methods focus/blur 1260
Allow focusing on any element: tabindex 1261
Delegation: focusin/focusout 1262
Summary 1263
Tasks 1263
Event: change 1272
Event: input 1272
Events: cut, copy, paste 1273
Summary 1274
Tasks 1274
Event: submit 1279
Method: submit 1280
Tasks 1280
DOMContentLoaded 1285
window.onload 1287
window.onunload 1287
window.onbeforeunload 1288
readyState 1289
Summary 1291
defer 1296
async 1298
Dynamic scripts 1299
Summary 1299
Loading a script 1304
Other resources 1305
Crossorigin policy 1306
Summary 1307
Tasks 1308
Syntax 1313
Usage for integration 1314
Usage for architecture 1315
Additional methods 1317
Summary 1318
Range 1323
Range properties 1326
Range selection methods 1327
Range editing methods 1327
Selection 1329
Selection properties 1330
Selection events 1330
Selection methods 1332
Selection in form controls 1333
Making unselectable 1336
References 1337
Summary 1337
Event Loop 1341
Use-case 1: splitting CPU-hungry tasks 1342
Use case 2: progress indication 1344
Use case 3: doing something after the event 1345
Macrotasks and Microtasks 1345
Summary 1347
Tasks 1347
Popup blocking 1354
window.open 1354
Example: a minimalistic window 1355
Accessing popup from window 1356
Accessing window from popup 1356
Closing a popup 1357
Moving and resizing 1357
Scrolling a window 1358
Focus/blur on a window 1358
Summary 1358
Same Origin 1363
Windows on subdomains: document.domain 1364
Iframe: wrong document pitfall 1365
Collection: window.frames 1366
The “sandbox” iframe attribute 1367
Cross-window messaging 1368
Summary 1370
The idea 1375
The demo 1375
Old-school defences (weak) 1377
X-Frame-Options 1379
Showing with disabled functionality 1379
Samesite cookie attribute 1381
Summary 1381
TypedArray 1386
TypedArray methods 1389
DataView 1389
Summary 1390
Tasks 1391
TextEncoder 1397
Blob as URL 1401
Blob to base64 1402
Image to blob 1403
From Blob to ArrayBuffer 1404
From Blob to stream 1404
Summary 1404
FileReader 1409
Summary 1411
Response headers 1420
Request headers 1420
POST requests 1421
Sending an image 1422
Summary 1423
Tasks 1424
Sending a simple form 1428
FormData Methods 1428
Sending a form with a file 1429
Sending a form with Blob data 1430
Summary 1431
The AbortController object 1442
Using with fetch 1443