“JavaScript Advanced Programming” Red Book second Reading (Hands-on)
Chapter 1 — What is JavaScript
DOM abstracts the entire page as a set of hierarchical nodes.
BOM is used to support accessing and manipulating the browser window.
Chapter 2 — JavaScript in HTML
- 2.1 < script > element
The element | describe |
---|---|
async | Start downloading scripts immediately, but do not block other page actions, such as downloading resources or waiting for other scripts to load, only for external script files; |
charset | Use SRC to specify the code character set. It is rarely used and most browsers do not care about its value. |
crossorigin | Configure CORS(Cross-source resource sharing) Settings. CORS is not used by default. |
defer | The script is executed after the document is parsed and displayed. This takes effect only for external script files. |
integrity | The runtime connects the received resource with the specified cryptographic signature to verify the integrity of the sub-resource (SRI, Subresource Intergrity). Can be used to ensure that the Content Delivery Network (CDN) does not provide malicious Content. |
src | An external file containing the code to execute; |
type | Represents the content type (also known as MIMI type) of the scripting language in the code. This value is always “text/javascript”. If this value is module, the code is treated as an ES6 module, and only then can the import and export keywords appear in the code. |
2.1.3 Loading scripts Asynchronously
The async property and defer, both of which can be applied to external scripts, tell the browser to start downloading immediately.
<html>
<head>
<title>Execute scripts asynchronously</title>
<script async src="main.js> main1.js></script><! -- may be executed before the first script -->
</head>
<body>
</body>
</html>
Copy the code
2.1.4 Dynamically Loading Scripts
let script = document.createElement('script');
script.src = 'gibberish.js';
script.async = false;
document.head.appendChild(script);
Copy the code
Chapter 3 — Language Basics
Var declarations are hoisted, hoist all variable declarations to the top of the function scope, and are destroyed when the function exits.
// hoist
function foo(){
console.log(age);
var age = 21;
}
foo();
// The upper part of ↑ is equivalent to the lower part of ↓ after promotion
function foo(){
var age;// Put all variable declarations at the top of the function scope
console.log(age);
age = 21;
}
foo();
Copy the code
The scope of the let declaration is block scope, and the scope of the var declaration is function scope.
/ / let statement
function f1(){
let n = 5;
if(true) {let n = 10;
}
console.log(n); // 5 The outer code block of variables declared with let is not affected by the inner code block.
/ / var statement
function f1(){
var n = 5;
if(true) {var n = 10;
}
console.log(n); // 10 Use var to define variable n. The last output value under block scope is the result of the inner code block.
Copy the code
A const declaration scope is also a block scope and must be initialized at the same time.
const age = 'kuishou';
if(true) {const name = 'zhangsan';
}
console.log(age);//kuisou
console.log(name);//undefined block scope can only get the result of the current layer of code block.
Copy the code
Note: in normal use, const takes precedence over let.
- 3.4 Data Types
Typeof operator: Used to distinguish functions from other objects
**** difference between null and undefined:
Undefined: a variable is declared but not initialized (with no value). Undefined is derived from null.
Null type: Represents an empty object pointer.
Boolean type: To convert a value of another type to a Boolean, call the Boolean() conversion function.
let message = "Hello kuishou";
if(message){
console.log("Message has been cast to a Boolean");
}Flow-control statements such as //if automatically convert other types to Booleans
Copy the code
Number type: Integer and floating point values ranging from number.min_value to number.max_value.
let Number = 68; / / integer
let octalNum1 = 070;// octal 56
let octalNum3 = 08;// An invalid octal number is treated as an 8
let folatNum1 = 0xA;// Hexadecimal 10
let folatNum2 = 0x1f;// Hexadecimal 31
let floatNum1 = 1.1;
let floatNum2 = 0.1;
let floatNum3 = 1.;// Valid, but not recommended
let floatNum4 = 1. // There is no number behind the decimal point
let floatNum5 = 10.0 // After the decimal point is 0, which is treated as an integer
let floatNum6 = 3.153 e7;// Take 3.153 as the coefficient, multiply 10 to the seventh power;
Copy the code
NaN (Not a Number) : meaning ‘Not a Number ‘, indicating that the operation intended to return a Number failed.
IsNaN () : takes an argument of any type and checks if it is not a number
console.log(isNaN(NaN));//true
console.log(isNaN(10));/ / false, 10 is value
console.log(isNaN("10"));//false can be converted to an array
console.log(isNaN("blue"));//true, cannot be converted to a numeric value
console.log(isNaN(true));//false, which can be converted to the value 1
let num1 = Number("Hello kuishou");//NaN string "Hello kushou" will prompt NaN if it cannot find the corresponding value
let num2 = Number(""); / / 0
let num3 = Number("000011"); / / 11
let num4 = Number(true); / / 1
Copy the code
Number, parseInt(), parseFloat()
ParesInt () function: recognizes different integer formats (decimal, octal, hexadecimal)
let num1 = parseInt("1234blue");/ / 1234
let num2 = parseInt(""); //NaN
let num3 = parseInt("0xA"); //10 is interpreted in hexadecimal
let num4 = parseInt(22.5); / / 22
let num5 = parseInt("70"); //70 is interpreted as decimal
let num1 = parseInt("10".2); //2
let num2 = parseInt("10".8); //8, in decimal notation
let num3 = parseInt("10".10); //10, in decimal notation
let num4 = parseInt("10".16); //16 is resolved in hexadecimal format
Copy the code
String type: Can be marked with double quotation marks (“), single quotation marks (‘), or back quotation marks (‘).
let Name = "kuishou";
let Name = 'lingxiu';
let Name = `jianlin`;
Copy the code
ToSting () : Converts to a string.
let num = 10;
console.log(num.toString(2));//1010, convert to binary
let num = "kuishou";
console.log(String(num)); //kuishou
Copy the code
Template literals: evaluated strings, with newline characters reserved. Strings can be defined across lines.
let myMultLineString = `first line\nsecond line`;
let myMultLineTemplatLiteral = `first line second line`;
console.log(myMultLineString); //first line
// second line
console.log(myMultLineTemplatLiteral); //first line second line
console,log(myMultLineString == myMultLineTemplatLiteral); //true
// Template literals are especially useful when defining templates, such as this HTML template:
let `
`
Copy the code
String interpolation: You can insert one or more values in a contiguous definition.
let value = 5;
let exponent = 'second';
// The old way of writing
let interpolatedString =
value + ' to the ' + exponent + ' power is ' + (value * value);
// The current way of writing
let interpolatedTemplateLiteral =
`${ value } to the ${ exponent } power is ${ value * value }`;
console.log(interpolatedString); // 5 to the second power is 25
console.log(interpolatedTemplateLiteral); // 5 to the second power is 25
// Templates can also insert their own previous values:
let value = ' ';
function append(){
value = `${value}abc`
console.log(value);
}
append(); // ABC, the first time display ABC
append(); //abcabc = ABC
append(); //abcabcabc, add ABC before abcabc for the third time
Copy the code
Template literals tag functions: Use tag functions to customize interpolation behavior.
let a = 8;
let b = 9;
function simpleTag(strings,aValExpression,bValExpression,sumExpression){
console.log(strings);// ["", "+ "," = ", "]
console.log(aValExpression);/ / 6
console.log(bValExpression);/ / 9
console.log(sumExpression);/ / 15
return 'foobar';
}
let untaggedRealut = `${a} + ${b} = ${a+b}`;
let taggedRedult = simpleTag`${a} + ${b} = ${a+b}`;
console.log(untaggedResult); // "6 + 9 = 15"
console.log(taggedResult); // "foobar"
Copy the code
Symbol type: Ensures that object attributes use unique identifiers without the risk of conflicts. Is used to create unique tokens that can then be used as non-string object attributes.
let o = {
[Symbol('fool')]:'foo val'[Symbol('bar')]:'bar val'
}
console.log(o); //{Symbol(fool): "foo val", Symbol(bar): "bar val"}
let barSymbol = Object.getOwnPropertySymbols(o)
.find((symbol) = > symbol.toString().match(/bar/));
console.log(barSymbol); //Symbol(bar)
Copy the code
Symbol of symbols | attribute |
---|---|
Symbol.asyncItertor | A method that returns an object to AsyncItertor by default, used by the for-await-of statement. |
Symbol.hasInstance | A method that determines whether a constructor object recognizes an object as an instance of it. |
Symbol.isConcatSpreadable | A Boolean value, if true, means that the object should be flattened with array.protype.concat () for its Array elements. |
Symbol.iterator | A method that returnsObject’s default iterator, used by the for-of statement |
Symbol.match | A regular expression that the method usesRegular expressionTo match the string. |
Symbol.replace | A regular expression method, the methodreplaceThe matching character in a string |
Symbol.search | A regular expression method that returns a match in a stringIndex of a regular expression |
Symbol.species | The value of a function that is used to createA derived objectConstructor of |
Symbol.spilt | A regular expression method that splits a string at the index position that matches the regular expression. |
Symbol.toPrimitve | A method that converts an object to the corresponding original value. |
Symbol.toStringTag | A string used to create the default string description of the object. |
Symbol.unscopables | All and inherited attributes of an object are excluded from the With environment binding of the associated object. |
Object type: Create your own Object by creating instances of Object type, and then add attributes and methods to the Object.
Object instance | attribute |
---|---|
constructor | The function used to create the current object. |
hasOwnProperty(propertyName) | Used to determine whether a given attribute exists on the current object instance (not the stereotype). |
isPrototypeOf(object) | Used to determine whether the current object is a prototype of another object. |
propertyIsEnumerable(propertyName) | Used to determine whether a given attribute can be used. |
toLocaleString() | Returns a string representation of an object that reflects the localized execution environment in which the object resides. |
toString() | Returns a string representation of an object. |
valueOf() | Returns a string, numeric, or Boolean representation of an object. |
- 3.5 Unary Operators (operators that operate on only one value)
Bit operators: Signed integers use the first 31 bits of the 32 bits to represent the integer value, and the 32nd bit to represent the symbol of the value. This bit is called the sign bit, and its value determines the format of the rest of the value.
Boolean operators: logic and && (short-circuit operator), logic, or | |, logic!
Multiplicative operators: multiplication *, division /, modulus %
Index operator: math.pow (base, exponent)
The additive operators are addition + and subtraction –
Relational operators: less than <, greater than >~~~
- 3.6 the statement
If statement:
if(i>18) {console.log("Come of age!);
}else if(i>22){
soncole.log("Graduated from college!);
}else{
console.log("Looking for a job!);
}
Copy the code
Do-while statement: post-test statement
let i = 0;
do{
i += 2;
console.log(i);
}while(i<10);
Copy the code
Whilel statements: Test statements first
let i = 0;
while(i<10){
i += 2;
console.log(i);
}
Copy the code
For statement:
for(let i = 0; i<10; i++){console.log(i);
}
Copy the code
For-in statement: for(Property in Windows) statment, used to enumerate non-signed key properties in an object. Each loop assigns the variable property one of the properties of the Windows object as its value until all properties have been enumerated.
for(const propName in windows){
console.log(propName);
}PropName is assigned a Windows object property as a value each time the loop is executed until all Windows properties have been enumerated.
Copy the code
For-of: for(const el of [1,3,5,7]) iterates through the elements of an iterable until all elements are iterated over.
for(const el of [1.3.5.7.9]) {console.log(el);// output 1,3,5,7,9
}
Copy the code
For in and for of
var a = ["a"."b"."c"."d"."e"];
for (var idx in a) {// It is recommended to loop through object properties.
console.log( idx );
}
// 0 1 2 3 4 for.. In loops over the key/index of array A.
for (var val of a) {// It is recommended to iterate over groups of numbers
console.log( val );
}
// "a" "b" "c" "d" "e" and for.. Of loops over the value of a.
Copy the code
① At the bottom, for… The of loop asks iterable for an iterator, and then calls the iterator repeatedly to assign its resulting value to the loop iteration variable. — JavaScript you Don’t Know — Volume 2
(2) the for… Of can terminate prematurely with a break, continue, or return and throw an exception. — JavaScript you Don’t Know — Volume 2
The difference between break and continue:
Break statement: breaks out of the current loop and executes the next statement after the loop;
let num = 0;
for(let i = 1; i<10; i++){if(i%5= =0) {break;
}
num++;
}
console.log(num);// The result is 4, why?
// Because the body of the loop increases to the point where I can be modulo by 5, the body of the loop has already jumped out, and num does not continue +1
Copy the code
Continue statement: After exiting the loop, go back to the top of the loop and restart execution.
let num = 0;
for(let i = 1; i<10; i++){if(i%5= =0) {console.log(num);
continue;
}
num++;
console.log(num);
}
console.log(num);// The result is 8, why?
// Because the loop body is incremented to the point where I can be modelled by 5, the continue pops out and goes back to the top of the loop again.
// Since 0%5 and 1%5 are both equal to 1, the final result is 8.
Copy the code
A switch statement:
switch(i){
case 25:
console.log("25");
borek;
case 35:
console.log("35");
borek;
case 45:
console.log("45");
borek;
case 55:
console.log("55");
borek;
default:
console.log("Outher");
}
Copy the code
With statement: Used to set the scope of code in a particular object
var sMessage ="hello kuishou";
with(sMessage){
alert(toUpperCase());//
}
Copy the code
- 3.7 the function
Diff () function: settle the difference between two values.
function diff(num1,num2){// Diff () is used to calculate the difference between two values
if(num1<num2){
return num2 - num1;
}else{
returnnum1-num2; }}Copy the code
SayHi () function: Merges passed arguments, separated by commas.
Chapter 4 — Variables, scopes, and memory
- 4.1 Transferring Parameters
function addTen(num){
num +=10;
return num;
}
let count = 20;
let result = addTen(count);
console.log(count);/ / 20
console.log(result);/ / 30
function setName(obj) {
obj.name = "kuishou";
obj = new Object(a); obj.name ="jianlin";
}
let person = new Object(a); setName(person);console.log(person.name);//kuishou
Copy the code
- 4.2 Execution context and scope.
Each context has an associated variable object on which all variables and functions defined in that context reside.
var color = "blue";
function changeColor(){
if(color === "blue"){
color = 'red';
}
}
changeColor(); // This function has two objects in scope: red can be displayed in a global variable
console.log(color);//red
Copy the code
-
4.3 Garbage Collection
Determining that a variable will no longer be used, freeing it up and periodically cleaning it up, is an ‘undecided’ problem.
There are two marking strategies: tag cleaning and reference counting.
Tag cleanup process: When a variable is declared, it is marked as a variable that exists in context. When the garbage collector runs, the tagged variable is the variable to be deleted. The garbage collector then does a memory cleanup, destroying all tagged values and reclaiming their memory.
functiontest(){
vara = 10 ; / / is marked, enter the environment varb =20 ; / / is marked} test();// The execution is completeA and B are then marked out of the environment and recycled.Copy the code
Reference counting: Count the number of times each value is referenced. If a variable is referenced once, the number of references +1. The variable is overwritten by another value, referencing -1; When the reference value is 0, its memory is reclaimed.
functiontest(){
vara = {} ; // The number of references to a is 0
varb = a ; // The number of references to a increases by 1, which equals 1
varc =a; // The number of references to a is increased by 1, which is 2
varb ={}; // The number of references to a is reduced by 1 to 1
}
Copy the code
Chapter 5 — Basic reference types
- 5.1 the Date type
let now = new Date(a);console.log(now);//Tue Mar 23 2021 18:03:19 GMT+0800
Copy the code
- 5.2 RegExp Regular expression
// g: global mode, which looks for the entire content of the string instead of ending with the first match.
// I: case insensitive, which means that the case of pattern and string are ignored when searching for matches.
// m: multi-line mode, which indicates that the search will continue at the end of a line of text.
// y: sticky mode, which means that only strings starting and after lastIndex are found.
// u: Unicode mode, enable Unicode matching.
// s: dotAll mode, indicating metacharacters. Matches any character (including \n or \r).
// Matches all "at" in the string
let pattern1 = /at/g;
// Matches the first "bat" or "cat", ignoring case
let pattern2 = /[bc]at/i;
// Matches all three-character combinations ending in "at", regardless of case
let pattern3 = /.at/gi;
// Matches the first "bat" or "cat", ignoring case
let pattern1 = /[bc]at/i;
// Match the first "[BC]at", ignoring case
let pattern2 = /\[bc\]at/i;
// Matches all three-character combinations ending in "at", regardless of case
let pattern3 = /.at/gi;
// Matches all ".at", ignoring case
Copy the code
- 5.3 Original value Packaging type
Boolean type
let falseObject = new Boolean(false);
let result = falseObject && true;
console.log(result);//true
Copy the code
The Number type
let num = 10;
console.log(num.toString(2));//1010, convert to binary
console.log(num.toFixed(2));//10.00, returns a numeric string of 2 decimal places
console.log(num.toExopnential(1));// $(+1); // $(+1)
console.log(num.toString(1));// + 1 + 1; // + 1 + 1
Copy the code
Type String
let stringValue = new String("Hello kuishou");
console.log(stringValue.length);//13, the string contains 13 characters, one space is two bytes
let stringValue = "Hello kuishou";
console.log(stringValue.slice(3));//llo kuishou, starting with 0 bits left, returns all strings after 3
console.log(stringValue.slice(3.7));//llo, starting at 0 bits on the left, returns all strings in the range from 3 to 7
console.log(stringValue.slice(-3));Hou, starting from the right, returns all strings before -3
console.log(stringValue.slice(3, -4));//llo kui, starting from the right, returns all strings in the range 3-7
console.log(stringValue.indexOf("o"))//4, starting from the left, locate the letter O
console.log(stringValue.lastIndexOf("o"))//11, starting from the left, locate the letter O
console.log(stringValue.indexOf("o".6));//11, start the search from position 6 (character k), find o in position 11
console.log(stringValue.lastIndexOf("o".6));//4, start the search backwards from position 6 (character k), find o at position 4
Copy the code
Trim () method: Create a copy of the string, remove all Spaces before and after, and return the result.
let stringValue = " hello world ";
let trimmedStringValue = stringValue.trim();
console.log(stringValue); // " hello world "
console.log(trimmedStringValue); // "hello world"
Copy the code
Repeat () method: takes an argument, copies the string the number of times specified in the argument, and then concatenates the results of all copies.
let stringValue = "na ";
console.log(stringValue.repeat(16) + "batman");
// na na na na na na na na na na na na na na na na batman
Copy the code
- 5.4 Math
let max = new Math.max(1.2.3.4.5);
console.log(max);//
let min = new Math.min(1.2.3.4.5);
console.log(min);
Copy the code
** math.round ()** The method performs rounding
Math.ceil() method: always round up the nearest integer.
Math.floor() method: always round down to the nearest integer.
Math.round() method: Perform rounding.
Math.fround() method: Returns the closest single-precision (32-bit) floating-point representation of the value.
console.log(Math.ceil(25.9));//26, round up
console.log(Math.ceil(25.5));/ / 26
console.log(Math.ceil(25.4));/ / 26
console.log(Math.ceil(25.1));/ / 26
console.log(Math.floor(25.9));//25, round down
console.log(Math.floor(25.5));/ / 25
console.log(Math.floor(25.4));/ / 25
console.log(Math.floor(25.1));/ / 25
console.log(Math.round(25.9));//26, rounded off
console.log(Math.round(25.5));/ / 26
console.log(Math.round(25.4));/ / 25
console.log(Math.round(25.1));/ / 25
console.log(Math.fround(25.9));//25.899999618530273, returns the closest single precision floating-point value
console.log(Math.fround(25.5));/ / 25.5
console.log(Math.fround(25.4));/ / 25.399999618530273
console.log(Math.fround(25.1));/ / 25.100000381469727
Copy the code
** math.random ()** Generates random numbers.
let num = Math.floor(Math.random()*10+1);
console.log(num);// Random number in the range of 1 to 10
/ * -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- - * /
function selectFrom(lowerValue,upperValue){
let choices = upperValue - lowerValue + 1;
return Math.floor(Math.random() * choices + lowerValue);
}
let num = selectFrom(2.10);
console.log(num); // Random number in the range of 2 to 10
/ * -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- - * /
let colors = ["red"."green"."blue"."black"."brown"];
let color = [selectFrom(0,colors.length-1)];
console.log(color);
Copy the code
Chapter 6 — Collection application types
- 6.1 the Object
Object is suitable for storing and exchanging data between applications.
Object literals: A short form of object definition intended to simplify the creation of objects that contain a large number of attributes.
let person ={// Object literal representation
name : "kuishou".age : 21.sex : "Male"
};
function displayInfo(args){
let output = "";
if(typeof args.name == "string"){
output += "Name:" + args.name + "\n";
}
if(typeof args.age == "number"){
output += "Age: " + args.age + "\n";
}
alert(output);//Name:kuishou Age:21
}
displayInfo({
name: "kuishou".age: 21
});
displayInfo({
name: "lingxiu"
});
Copy the code
-
6.2 Array Array
Create an array
let colors = new Array(a);let colors = new Array("red"."blue"."black");
let colors = ["red"."green"."black"];
Copy the code
// array.from () splits and merges arrays
console.log(Array.from("kuishou"));//["k", "u", "I ", "s", "h", "o", "u"], split array
const s = new Set().add(1).add(2).add(3).add(5).add(4);
console.log(Array.from(s));//[1, 2, 3, 5, 4], merge array
const m = new Map().set(1.2).set(3.4);
console.log(Array.from(m));//[[1,2],[3,4]], merge two-dimensional arrays
// array.of () converts a set of arguments to an Array
console.log(Array.of(1.2.3.4.5));//[1, 2, 3, 4, 5]
console.log(Array.of(red,black,green));//["red", "black","green"]
// Array index
let colors = ["red"."yellow"."blue"];
console.log(colors[0]); //red, display the first item
colors[2] = "yellow";// Modify the third item blue
colors[3] = "green"; // Add the fourth item, array length +1
console.log(colors.length);//4, display the array length
Copy the code
Iterator methods: keys() returns an array index,values() returns an array element, and entries() returns index/value pairs.
const b = ["red"."blue"."green"."black"];// Note that const is initialized during console declarations, meaning that it cannot be reused after being used once.
const bKeys = Array.from(b.keys());
console.log(bKeys); / / [0, 1, 2, 3]
const bValues = Array.from(b.values());
console.log(bValues); // ["red", "blue", "green", "black"]
const bEntries = Array.from(b.entries());
console.log(bEntries); // [[0, "red"],[1, "blue"],[2, "green"],[3, "black"]]
Copy the code
Stack method: Posh () pushes in, pop() pops out, following the last in, first out principle.
let colors = ["red"."green"];
let count = colors.push("blue"."black");// Push two terms
console.log(count); //4,push receives the parameters and returns the latest length of the array
let item = colors.pop(); // Pop up the last item
console.log(item); //black
Copy the code
Queue method: Shift () removes the first item in the array and returns the array length; Posh () adds data to the end of the array; Follow the first-in, first-out principle.
let colors = ["red"."green"];
let count = colors.push("blue"."black");// Push two terms
console.log(count); //4,push receives the parameters and returns the latest length of the array
let item = colors.shift(); // get the first item
console.log(item); //red
Copy the code
Sort method: reverse() sort in reverse; Sort () contains a comparison function to determine which value should come first.
let values = [1.2.3.4.5]
let count = values.reverse();
console.log(count); //[5, 4, 3, 2, 1
console.log(count.sort()); //[1, 2, 3, 4, 5]
function compare(value1,value2){/ / descending
if(value1 < value2){
return 1;
}else if(value1 > value2){
return -1;
}else{
return 0; }}let values = [0.1.5.10.15.20];
console.log(values.sort(compare));//[20, 15, 10, 5, 1, 0]
function compare(value1,value2){/ / ascending
if(value1 < value2){
return -1;
}else if(value1 > value2){
return 1;
}else{
return 0; }}let values = [20.15.10.5.1.0];
console.log(values.sort(compare));//[0, 1, 5, 10, 15, 20]
Copy the code
Concat () creates a new array after the existing one; Slice () creates a heart array containing one or more elements of the original array; Splice () inserts a new element into the array, passing two arguments to delete. The first argument is the position of the element, and the second argument is the number of deletions.
//concat() can create a new array from an existing one
let colors = ["red"."green"."blue"];
let colors2 = colors.concat("yellow"["black"."brown"]);// Pass yellow and the array ["black","brown"], not even by default
console.log(colors); // ["red", "green", "blue"]
console.log(colors2); / / / "red", "green", "blue", "yellow", "black", "brown"], forming a new array
let colors = ["red"."blue"."green"];
let newColors = ["black"."brown"];
let moreNewColors = {
[Symbol.isConcatSpreadable] : true.length : 2.0 : "pink".1 : "cyan"
};
newColors[Symbol.isConcatSpreadable] = false;
// Forces the array not to be flattened
let colors2 = colors.concat("yellow",newColors);
// Force the array flat
let colors3 = colors.concat(moreNewColors);
console.log(colors); //["red", "blue", "green"]
console.log(colors2); / / / "red", "blue", "green", "yellow," [" black ", "brown"]], don't draw the array output two-dimensional array
console.log(colors3); / / / "red", "blue", "green", "pink", "cyan"], draw array output a one-dimensional array
Slicie () is used to create a new array containing one or more elements of the original array
let colors = ["red"."green"."blue"."black"."pink"];
let colors2 = colors.slice(1); // Start with index 1(green) and read all values after 1
console.log(colors2); //["green", "blue", "black", "pink"]
let colors3 = colors.slice(1.4); // Start with index 1(green) and end with index 3(black)
console.log(colors3); //["green", "blue", "black"]
let colors = ["red"."green"."blue"];
let removed = colors.splice(0.1); // Delete the first line
console.log(colors); //["green", "blue"]
removed = colors.splice(1.0."yellow"."orange"); // Insert two elements in position 1
console.log(colors); //["green", "yellow", "orange", "blue"]
removed = colors.splice(1.1."red"."peuple"); // Insert two values and delete one element
console.log(colors) //["green", "red", "peuple", "orange", "blue"]
Copy the code
Iterating method: three parameters (array element, element index, array itself),
* This method returns true only when every() searches the array for elements that match certain criteria and the function passed in returns true for each item.
* Some () searches an array for elements that match a certain condition. This method returns true as long as one of the functions passed in returns true.
* filter() returns the items that meet the criteria as a new array.
* The results returned by map() form a new array.
* forEach() runs each function passed in, with no return value, traversing.
let numbers = [1.2.3.4.5.4.3.2.1];
let everyResult = numbers.every((item,index,array) = > item > 2);
console.log(everyResult);//false
let someResult = numbers.some((item,index,array) = > item > 2);
console.log(someResult);//true
let filterResult = numbers.filter((item,index,array) = > item > 2);
console.log(filterResult);//[3, 4, 5, 4, 3]
let mapResult = numbers.map((item,index,array) = > item * 2);
console.log(mapResult);//[2, 4, 6, 8, 10, 8, 6, 4, 2]
Copy the code
Merge method: takes four arguments: the last merge value, the current item, the index of the current item, and the array itself.
* reduce() iterates from the first item to the last
* reduceRight() traverses from the last item to the first
let values = [1.2.3.4.5];
let sum = values.reduce((prev,cur,index,array) = > prev + cur);
console.log(sum);Prev = 1, cur = 2; The second execution prev is 3, cur is 3; Prev is 6 for the third execution, cur is 4; So sum is 15
let sum = values.reduceRight(function(prev,cur,index,array){
return prev + cur;
});
console.log(sum);//15, merge from right to left.
Copy the code
- 6.4 the Map
Map is a new collection type that uses object attributes as keys and attributes to reference values.
* Get (), set()
* size() gets the number in the map
* delete(), clear() delete
const m1 = new Map([// Initialize the map with a nested array
["key1"."val1"],
["key2"."val2"],
["key3"."val3"]]);console.log(m1.size);
const m = new Map(a); m.set("firstName"."Matt")
.set("lastName"."Frisbie");
console.log(m.has("firstName"));//true
console.log(m.get("firstName"));//Math
console.log(m.size);/ / 2
m.delete("firstName");// Delete only one key/value pair
console.log(m.has("firstName"));//false
console.log(m.get("lastName"));//Frisbie,get gets the lastName key, returns the Frisbie value
console.log(m.size);//1, after deletion, length -1
m.clear("firstName");// Clears all key/value pairs in this mapping instance
console.log(m.has("firstName"));//false
console.log(m.get("lastName"));//undefined
console.log(m.size);
Copy the code
Differences between Map and Object:
Memory: Map stores 50% more key/value pairs than Object.
Insert performance: The insert speed does not increase linearly with the number of key/value pairs;
Lookup speed: Object is faster when used as an array.
Delete performance: Map delete() operations are faster than insert and lookup.
Chapter 7 — Iterators and Generators
Iterator: An object that defines a sequence and returns a value on termination. Two return values: value and done. An interface that can be implemented by any object and supports continuous retrieval of every value produced by the object.
for (let i = 1; i <=10; i++){console.log(i);
}//1 2 3 4 5 6 7 9 10
let collection = ['foo'.'bar'.'baz'];
for(let index = 0; index < collection.length; ++index){console.log(collection[index]);
}//foo bar baz
collection.forEach((item) = > console.log(item));//foo bar baz
Copy the code
Iterable protocol: Supports self-identification and the ability to create objects that implement Iterator interfaces.
/ / the for - cycle
let arr = ['foo'.'bar'.'baz'];
for(let el of arr){
console.log(el);//foo bar baz
}
// Array destruct
let arr = ['foo'.'bar'.'baz'];
let [a,b,c] = arr;
console.log(a,b,c);//foo bar baz
// Extend the operator
let arr = ['foo'.'bar'.'baz'];
let arr2 = [...arr];
console.log(arr2);//["foo", "bar", "baz"]
//Array.from()
let arr = ['foo'.'bar'.'baz'];
let arr3 = Array.from(arr);
console.log(arr3);//["foo", "bar", "baz"]
//Set constructor
let arr = ['foo'.'bar'.'baz'];
let set = new Set(arr);
console.log(arr3);//["foo", "bar", "baz"]
//Map constructor
let arr = ['foo'.'bar'.'baz'];
let pairs = arr.map((x,i) = > [x,i]);
console.log(pairs);//[["foo", 0], ["bar", 1], ["baz", 2]]
let map = new Map(pairs);
console.log(map);// {"foo" => 0, "bar" => 1, "baz" => 2}
Copy the code
Iterator: A disposable object used to iterate over the iterable associated with it.
// Iterable
let arr = ['foo'.'bar'];
// Iterator factory function
console.log(arr[Symbol.iterator]);//values() { [native code] }
/ / the iterator
let iter = arr[Symbol.iterator]();
console.log(iter);//Array Iterator {}
// Perform iteration
console.log(iter.next());//{value: "foo", done: false}
console.log(iter.next());//{value: "bar", done: false}
console.log(iter.next());//{value: undefined, done: true}
Copy the code
Generator: Allows you to define a function that contains a free iterative algorithm and maintains its own state automatically, with the ability to pause and resume code execution within a function block. A generator is a function whose name is preceded by an asterisk (*) to indicate that it is a generator.
// Generator function declaration
function* generationFn(){}
// Generator function expression
let generationFn = function* (){}
// a generator function that acts as an object literal method
let foo = {
* generationFn(){}}// a generator function that acts as a class instance method
class Foo{*generationFn(){}}// a generator function as a static method of the class
class Bar{
static* generationFn(){}}// The generator puts back the specified value
function* generationFn(){
return 'foo';
}
let generatorObject = generationFn();
console.log(generatorObject);//generationFn {<suspended>}
console.log(generatorObject.next());//{value: "foo", done: true}
/** * yield interrupts execution */
function* generationFn(){
yield 'foo';
yield 'bar';
return 'baz';
}
let generatorObject = generationFn();
console.log(generatorObject.next());//{value: "foo", done: false}
console.log(generatorObject.next());//{value: "bar", done: false}
console.log(generatorObject.next());//{value: "baz", done: true}
Copy the code
Chapter 8 — Objects, Classes, and Object-oriented programming
- 8.1 Understanding Objects
Literal-oriented writing:
let person = {
name: "kuishou" ,
age:21.job:"Front-end development".sayName(){
console.log(this.name); }};Copy the code
- 8.1.1 Defining multiple Attributes
Object.defineproperties () defines multiple attributes at once with multiple descriptors.
let book = {};
Object.defineProperty(book,{
year_: {value:2021
},
edition: {value:1
},
year: {get(){
return this.year_;
},
set(newValue){
if(newValue > 2020) {this.year_ = newValue;
this.edition += newValue - 2020; }}}});Copy the code
- 8.1.2 Reading Attributes
Object. GetOwnProprttyDescriptor () to specify the attribute feature descriptor
let book = {};
Object.defineProperties(book,{
year_: {value:2021
},
edition: {value:1
},
year: {get:function(){
return this.year_;
},
set:function(newValue){
if(newValue > 2020) {this.year_ = newValue;
this.edition += newValue - 2020; }}}})let descriptor = Object.getOwnPropertyDescriptor(book,"year_");
console.log(descriptor.value); / / 2021
console.log(descriptor.configurable); //false
console.log(descriptor.enumerable); //undefined
console.log(typeof descriptor.get); //undefined
Copy the code
- 8.1.3 Merging Objects: Copy all the local properties of the source object to the target object.
Object.assign() performs a shallow copy of each source Object.
let dest , src , result;
// Override attributes
dest = {id: 'dest'};
result = Object.assign(dest,{id:'src1'.a:'foo'}, {id:'src2'.b:'bar'});
console.log(result);//{id: "src2", a: "foo", b: "bar"}
/** * Short for attribute value */
let name = 'Matt';
let person = {
name
};
console.log(person);//{name: "Matt"}
/** * object destruct */
let person ={
name:'Matt'.age:'21'
};
let {name:personName,age:personAge} = person;
console.log(personName);//Matt
console.log(personAge);/ / 21
Copy the code
-
8.2 Creating An Object
-
8.2.1 Factory pattern: A process for abstracting specific objects.
function createPerson(name,age,job){
let o = new Object(a); o.name = name; o.age = age; o.job = job; o.sayName =function(){
console.log(this.name);
};
return o;
}
let person1 = createPerson("kuishou".21."Front-end development");
let person2 = createPerson("lingxiu".20."Back-end development");
Copy the code
- 8.2.1 Constructor pattern: Used to create objects of a specific type.
function Person(name,age,job){
this.name = name;
this.age = age;
this.job = job;
this.sayName = function(){
console.log(this.name);
};
}
let person1 = createPerson("kuishou".21."Front-end development");
let person2 = createPerson("lingxiu".20."Back-end development");
person1.sayName();//kuishou
person2.sayName();//lingxiu
Copy the code
- 8.3 inheritance
function SuperType(){
this.property = true;
}
SuperType.prototype.getSuperValue = function(){
return this.property;
}
function SubType(){
this.subproperty = false;
}
/ / inherit the SuperType
SubType.prototype = new SuperType();
SubType.prototype.getSuperValue = function(){
return this.subproperty;
};
let instance = new SubType();
console.log(instance.getSuperValue());
Copy the code
- 8.4 class
There are two ways to define a class:
/ / the class declaration
class Person {}
// Class expression
const Animal = class {};
Copy the code
Function declarations can be promoted; class definitions cannot.
Class constructors: Not defining a constructor is equivalent to defining a constructor as an empty function.
Inheritance: You can inherit not only from a class, but also from ordinary constructors.
Abstract base class: can be inherited by other classes. When it is not instantiated, use new and target to check whether it is an abstract base class.
Chapter 9 — Agency and Reflection
- 9.1 the agent
The ability to intercept and embed additional behavior into the base operation; Target Target object; Handler proxy object (Reflect also works)
const target = {
id: 'target'
};
const handler = {};
const proxy = new Proxy(target, handler);
// The id attribute accesses the same value
console.log(target.id); // target
console.log(proxy.id); // target
// Assigning a target attribute is reflected on both objects
// Because both objects access the same value
target.id = 'foo';
console.log(target.id); // foo
console.log(proxy.id); // foo
// Assigning a proxy attribute is reflected on both objects
// Because the assignment is passed to the target object
proxy.id = 'bar';
console.log(target.id); // bar
console.log(proxy.id); // bar
The hasOwnProperty() method is in two places
// both apply to the target object
console.log(target.hasOwnProperty('id')); // true
console.log(proxy.hasOwnProperty('id')); // true
/ / Proxy. The prototype is undefined
// Therefore, the instanceof operator cannot be used
console.log(target instanceof Proxy); // TypeError: Function has non-object prototype
'undefined' in instanceof check
console.log(proxy instanceof Proxy); // TypeError: Function has non-object prototype
'undefined' in instanceof check
Strict equality can be used to distinguish agents from targets
console.log(target === proxy); // false
Copy the code
Chapter 10 — Functions
- 10.1 Arrow Function
let arrowSum = (a,b) = > {// Arrow function
return a+b;
};
let functionExpressionSum = function (a,b) {// A normal function
return a+b;
}
console.log(arrowSum(6.8));/ / 14
console.log(functionExpressionSum(6.8));/ / 14
Copy the code
- 10.2 Inside the Function
Arguments object: is an array-like object (the first argument is arguments[0], the second argument is arguments[1]).
function doAdd(){
if(arguments.length==1) {console.log(arguments[0] +10);
}else if(arguments.length==2) {console.log(arguments[0] +arguments[1]);
}
}
doAdd(10);/ / 20
doAdd(20.30);/ / 50
let trueFactorial = factorial;
factorial = function(){
return 0;
};
console.log(trueFactorial(5));/ / 120
console.log(factorial(5));/ / 0
Copy the code
This object: In standard functions, this refers to the context object that calls the function as a method.
window.coloe = 'red';
let o ={
color:'bule'
};
function sayColor(){
console.log(this.coolor);
}
sayColor();//'red'
o.sayColor = sayColor;
o.sayColor();//'blue'
In arrow functions, this refers to the context in which the arrow function is defined.
windows.color = 'red';
let o ={
color:'blue'
};
let sayColor = () = > console.log(this.color);
sayColor();//'red'
o.sayColor = sayColor;
o.sayColor();//'red'
Copy the code
- 10.3 Recursion: A function calls itself by name.
Arguments.callee a pointer to an executing function.
function factorial(num){
if(num<=1) {return 1;
} else {
return num*arguments.callee(num-1); }}const factorial = (function f(num){
if (num<=1) {return 1;
} else {
return num*f(num-1); }});Copy the code
- 10.4 Closures: A function that references a variable in the scope of another function, usually implemented in a nested function. The essence is that the active object that contains the function lengthens its scope chain.
function createComparisonFunction(propertyName){
return function(object1,object2){
let value1 = object1[propertyName];
let value2 = object2[propertyName];
if(value1 < value2){
return -1;
} else if(value1 > value2){
return 1;
}else{
return 0; }}; }Copy the code
- 10.5 Module mode: Private variables and privileged methods are created through custom types.
let singleton ={
name:value,
method(){
// The code for the method}};let singleton = function(){
// Private variables and functions
let privateVariable = 10;
function privateFunction(){
return false;
}
// Privileges, public methods, and attributes
return {
publicProperty: true.publicMethod(){
privateVariable ++;
return privateFunction
}
}
}
Copy the code
Chapter 11 — Scheduling and asynchronous functions
- 11.2 Promises: A proxy for an outcome that doesn’t yet exist.
/** ** what is Promise? * (1) Syntactically: A Promise is a constructor * (2) functionally: A Promise object encapsulates an asynchronous operation and fetches its result. * Promise basic distant flow * (1) create a new Promise object * (2) perform an asynchronous action task * (3) Return resolve() on success, reject() on failure * (4) Resolved state through then() to call onResolved(); The rejected state calls onReject() * (5) back then()/catch() and forms a new Promise object */
// Failed processing
function double(value,success,failure){
setTimeout(() = > {
try{
if(typeofvalue ! = ='number') {throw 'Must provide number as firdt argument';
}
success(2 * value);
}catch(e){ failure(e); }},1000);
}
const successCallback = (x) = > console.log('Success: ${x}');
const failureCallback = (e) = > console.log('Failure: ${e}');
double(3,successCallback,factorialCallack);
double('b',successCallback,factorialCallack);
// Nested asynchronous callback
function double(value,success,failure){
setTimeout(() = > {
try{
if(typeofvalue ! = ='number') {throw 'Must provide number as firdt argument';
}
success(2 * value);
}catch(e){ failure(e); }},1000)}const successCallback = (x) = > {
double(x,(y) = > console.log('Success: ${} y'));
};
const failureCallback = (e) = > console.log('Failure:${e}');
double(3,successCallback,failureCallback);
Copy the code
How the state of a Promise object changes:
1. Declare the state of a Promise object
let p = new Promise((resolve,reject) = > {
/ / resolve function
resolve('OK');//pending =>fulfilled(resolve)
/ / reject function
reject('Error');//pending => rejected
// Throw an error
throw 'Something's wrong';
});
console.log();
//Promise specifies multiple success/failure callbacks. Will they all be called?
// When a Promise changes to the corresponding state, it is called
let p = new Promise((resolve,reject) = > {
resolve('OK');
});
// Specify the callback
p.then(value= > {
console.log(value);
});
// Specify the callback
p.then(value= > {
alert(value);
});
Copy the code
Three states: pending, resovle, and reject
/** * A promise is a proxy for a result that does not yet exist. This is a big pity, which can be called "resolve" and "rejected". Three states are irreversible, namely, the most initial state of the contract. This is a big pity: this is a big pity, which is settled someday. This is a big pity: this is a big pity, which is settled sometimes. This is a big pity, which is settled sometimes. Status indicates whether the contract is complete. * /
let p = new Promise(() = > {});
setTimeout(console.log,0,p);
let p1 = new Promise((resolve,reject) = > resolve());
setTimeout(console.log, 0 ,p1)//Promise {<fulfilled>: undefined}
let p2 = new Promise((resolve,reject) = > reject());
setTimeout(console.log, 0 ,p2)//Promise {<rejected>: undefined}
Copy the code
Promise.prototype.then() adds a callback to the Promise instance when the state changes.
// The then method returns a new Promise instance.
getJSON("/post/1.json").then(
post= > getJSON(post.commentURL)
).then(
comments= > console.log("resolved:",comments),
err= > console.log("rejected:",err)
);
Copy the code
Promise.prototype.catch() is the callback function for when an error occurs.
const somrAsyncThing = function(){
return new Promise(function(resolve,reject){
resolve(x + 2);// An error is reported because x is not declared
});
};
somrAsyncThing().catch(function(error){
console.log('error',error);
}).then(function(){
console.log('error');
});
Copy the code
Promise. Prototype. Finally () whatever Promise object finally state, will perform the operation.
let p1 = Promise.resolve();
let p2 = Promise.reject();
let onFinally = function(){
setTimeout(console.log, 0.'Finally! ')
}
p1.finally(onFinally);//Finally
p2.finally(onFinally);//Finally
Copy the code
Promise.all() takes an iterable and returns a new term to be resolved after the set of terms has all been resolved.
const p1 = new Promise((resolve,reject) = > {
resolve("hello");
}).then(result= > result);
const p2 = new Promise((resolve,reject) = > {
throw new Error('error');
}).then(result= > result);
Promise.all([p1,p2])
.then(result= > console.log(result))
.catch(e= > console.log(e));
Copy the code
Promise.race() wraps multiple Promise instances into a new Promise instance.
const p = Promise.race([p1,p2,p3]);// The transition of P will change as long as one instance changes the state first
const p = Promise.race([
fetch('/resource-that-may-take-a-while'),
new Promise(function(resolve,reject){
setTimeout(() = > reject(new Error('request timeout')),5000)})]); p.then(console.log).catch(console.error);
Copy the code
- 11.3 Asynchronous functions: Designed to solve the problem of using asynchronous structures to organize code
The async keyword is used to declare asynchronous functions and is the syntactic sugar for Generator functions.
async function foo(){}
let bar = async function(){};
let baz = async() = > {};class Qux{
async qux(){}}let p = new Promise((result,reject) = > setTimeout(result,1000.3));
p.then((x) = > console.log(x));/ / 3
Copy the code
The await keyword is used to suspend the execution of the step function code and the wait period is resolved.
async function foo(){
let p = new Promise((resolve,reject) = > setTimeout(resolve,1000.3));
console.log(await p);
}
foo();/ / 3
// Stop and resume execution
async function foo(){
console.log(2);
await null;
console.log(4);
}
console.log(1);
foo();
console.log(3);
/ / 1
//2, after printing 2, null adds a task to the message queue due to the arait keyword, exits foo()
//3. Print 3 and go back to foo() again.
/ / 4
async function foo(){
console.log(2);
console.log(await Promise.resolve(8));
console.log(9);
}
async function bar(){
console.log(4);
console.log(await 6);
console.log(7);
}
console.log(1);
foo();
console.log(3);
bar();
console.log(5);
Copy the code
Write a Promise:
// See the built-in error
// 1).ReferenceError: The referenced variable does not exist
console.log(a); //Uncaught ReferenceError: a is not defined
// 2).TypeError: The data type is incorrect
b = {}
b.xxx()//VM274:2 Uncaught TypeError: b.xxx is not a function
//3).rangeError: The data value is not in the allowed range
function fn(){
fn()
}
fn()//ncaught RangeError: Maximum call stack size exceeded
//4).SyntaxError: SyntaxError
const c = "" '"
// Create a Promise object
const p = new Promise((resolve, reject) = > {
setTimeout(() = > {
const time = Date.now();
if(time % 2= =0){
resolve('Successful data, time='+time);
}else{
reject('Failed data, time='+time); }},1000);
})
p.then(
value= > {
console.log('Successful callback'+value);
},
reason= > {
console.log('Failed callback, time='+reason); })The Promise object encapsulates an asynchronous operation and returns its result
new Promise((resolve, reject) = > {
setTimeout(() = > {
resolve('Success data')
reject('Failed data')// This part will have no effect and the promise will only return one result per call
},1000)})//Promise.then()
new Promise((resolve, reject) = > {
setTimeout(() = > {
resolve('Success data')},1000)
}).then(
value= > {
console.log('onResolved()1',value)//onResolved()1
}
).catch(
reason= > {
console.log('onReject()1',reason)
}
)
/** * syntax sugar: a very sweet, convenient way to pass values */
//Promise.resolve()
// Produces a promise value with a success value of 1
const p1 = new Promise((resolve, reject) = > {
resolve(1)})const p2 = Promise.resolve(2);/ / syntactic sugar
const p3 = Promise.reject(3);/ / syntactic sugar
p1.then(value= > {console.log(value)});
p2.then(value= > {console.log(value)});
p3.catch(reason= > {console.log(reason)});
// promsie.all () is successful only if all are resolve, otherwise reject is returned
const p1 = new Promise((resolve, reject) = > {
resolve(1)})const p2 = Promise.resolve(2);/ / syntactic sugar
const p3 = Promise.reject(3);/ / syntactic sugar
const pAll = Promise.all([p1,p2,p3])// 3 is the result of a failure
pAll.then(
values= > {
console.log('all onReasoned()',values);
},
reason= > {
console.log('all onRejected()',reason);//all onRejected() 3})// promise.race () returns the result as long as there is a resolve/reject
// In the asynchronous case, p1, P2,p3 goes first
const p1 = new Promise((resolve, reject) = > {
resolve(1)})const p2 = Promise.resolve(2);
const p3 = Promise.reject(3);
const pRace = Promise.race([p1,p2,p3])
pRace.then(
value= > {
console.log('race onResolve()',value)
},
reason= > {
console.log('race onRejected()',reason)
}
)
/** * promise.then () returns a Promise. What determines the result? (1) If a new promise is thrown, reject it. (2) If a new promise is thrown, reject it. (3) If a new promise is thrown, reject it. * ② If a non-PROMISE value is returned, the new promise becomes resolved, and value is the returned value * ③ If a new promise is returned, the result of the new promise will be programmed with the result */
new Promise((resolve, reject) = > {
resolve(1);//onResolved1() 1 onResolved2() undefined
// reject(1);//onRejected1() 1 onResolved2() undefined
}).then(
value= > {
console.log('onResolved1()',value);
return 2
// return Promise.resolve(3)
// return Promise.reject(4)
// throw 5
},
reason= > {
console.log('onRejected1()',reason);
}
).then(
value= > {
console.log('onResolved2()',value);
},
reason= > {
console.log('onRejected2()',reason); })/** * How does Promise concatenate multiple action tasks? * (1) Promise's then() returns a new promise, which can be opened as a chain call to then(). * (2) concatenate multiple synchronous/asynchronous tasks */ via chained calls to THEN
new Promise ((resolve, reject) = > {
setTimeout(() = > {
console.log("Perform Task 1 (asynchronous)");
resolve(1)},1000);
}).then(
value= >{
console.log("Result of Performing Task 2:",value);
console.log("Perform Task 2 (Synchronization)");
return 2;
}
).then(
value= > {
console.log("Results of Task 3:",value)
}
)
/** * promise * (1) When using promise's then chain invocation, the failed callback can be specified at the end. * (2) Any previous exception is passed to the last failed callback. * Break the promise chain? * (1) When using a promise's then chain call, interrupt in the middle and no longer call the following callback function * (2) : return a Promise object in a pending state */
new Promise ((resolve, reject) = > {
resolve(1)
}).then(
value= >{
console.log("onRsolved1()",value);
}
).then(
value= > {
console.log("onRsolved2()",value)
}
).then(
value= > {
console.log("onRsolved3()",value)
}
).catch(
reason= > {
console.log('onReasoned4()',reason)
}
)
Copy the code
Macro and micro tasks:
/** * 1. The queue used to store callback functions contains two different specific queues * 2. Macro queue: Used to hold macro tasks (callbacks) to be executed, such as DOM event callbacks, Ajax callbacks, timer setTime callbacks * 3. Microtuple: Used to hold microtasks (callbacks) to be executed, such as promise callbacks, MutaionOberver callbacks * 4.JS will be executed separately from the two queues, * (1).js engine must first execute all initial synchronization task code. * (2). Before the first macro task is ready to be pulled out, all the micro tasks should be pulled out and executed one by one. * /
setTimeout(() = > {// Macro task 3
console.log("callback1()")
Promise.resolve(3).then(// Microtask 4
value= > {
console.log("onResolve3()",value)
}
)
},0)
setTimeout(() = > {// Macro task 5
console.log("callback2()")},0)
Promise.resolve(1).then(// Microtask 1
value= > {
console.log("onResolve1()",value)
}
)
Promise.resolve(2).then(// Microtask 2
value= > {
console.log("onResolve2()",value)
}
)
//onResolve1() 1
//onResolve2() 2
//callback()
//onResolve3() 3
//callback()
setTimeout(() = > {
console.log(1)},0)
new Promise((resolve) = > {
console.log(2)
resolve()
}).then(() = > {
console.log(3)
}).then(() = > {
console.log(4)})console.log(5)
//2 5 3 4 1
Copy the code
Async and await functions
/** * 1. Async * returns a promise object. * The result of the promise object is determined by the return value executed by the async function. * 2. Await expression * Await expression the expression to the right of await is usually a Promise object, but can be some other value. * If the expression is a PROMsie object, await returns the promise success value, * if the expression is some other value, Return this value directly as await. * * /
async function fn1(){
return 1
// throw 2
// return Promise.reject(3)
}
const result = fn1()
result.then(
value= > {
console.log('onResolved',value);//onResolved 1
},reason= > {
console.log('onRejected',reason)
}
)
function fn2(){
return new Promise((resolve, reject) = > {
setTimeout(() = > {
reject(6)},1000)})}function fn4(){
return 6;
}
async function fn3(){
const vlaue = await fn2();
console.log('value',value)
}
fn3()
Copy the code
Chapter 12 – BOM
- 12.1 Windows object
At the heart of the BOM is a Windows object, which has two identities: a Global object in ECMAScript and a JavaScript interface to a browser window.
Differences between BOM and DOM:
DOM: document object model, describes the method and interface to process web content (Windows.document).
BOM: The browser object model, which describes the methods and interfaces (Navigater, History, Screen, Location, Windows) to interact with the browser.
Chapter 13 — Client detection
- Capability detection: Detects whether the browser has a feature
- User agent detection: Determines the browser by the user agent string.
Chapter 14 – DOM
DOM represents a document made up of several layers of nodes, a DOM tree.
Element Traversal API Traversal
ChildElementCount, which returns the number of elements (excluding text nodes and comments).
FirstElementChild, which points to the child of the firstElement type.
LastElementChild, which points to a child of the lastElement type.
PreviousElementSibling refers to the sibling of the previousElement type.
NextElementSibling, which points to the sibling of the latter Element type.
Chapter 15 — DOM Extension
-
15.1 the Selectors API
-
QuerySelector () returns the first descendant element matching the pattern, or null if there is no match.
/** * DOM programming */ var script = document.createElement("script"); var code = "function sayHi(){alert('h1'); }"; try{ script.appendChild(document.createTextNode("code")); }catch(ex){ script.text = "code"; } document.body.appendChild(script);//<script>dode</script> //querySelector() takes the CSS selector argument and returns the first descendant element matching the pattern. let myDiv = document.querySelector("#myDiv"); //querySelect() takes the CSS selector argument and returns all matching nodes. let ems = document.querySelectorAll("p strong");// Get all elements that are children of the
element
//DOM object to Jquery object var box = document.getElementsByClassName('.box'); var jq = $(box); // Get the 0 th position of all divs var domeObject = $('div') [0]; //Jquery objects are converted to DOM objects myvideo.play();// Call directly Copy the code
Chapter 17 — Events
- 17.1 Event Flow: Indicates the sequence in which a page receives events.
- Three stages of event propagation:
- ① Event capture stage: Events are propagated from the Document node to the target node from top to bottom.
- ② Target stage: reach the event target of the event object, find the target node after completion and stop.
- (3) Event bubbling stage: The event propagates from the target node to the Document node from bottom to top.
Chapter 20 — Streams API
-
20.2 Cross contextual messaging: an ability to perform the delivery of messages between different contexts. The core is the postMessage() method.
-
The postMessage() method takes three arguments: the message (data), the document source (Origin), and the Windows Object Agent in the document (Souce).
-
let iframeWindow = document.getElementById("myframe").contentWindow; iframeWindow.postMessage("A secret"."http://www.xxxx.com");// Specify the source www.xxx.com, and x 'sends a message to the inline pane Copy the code
-
Streams API
-
Readable stream: A stream that reads blocks of data through a public interface and is processed by the consumer, using the getReader() method to acquire the lock for the stream
async function* ints(){ // Produce an increasing integer every 1000 milliseconds for(let i = 0; i<5; ++i){ yieledawait new Promise((resovle) = > setTimeout(resovle,1000,i)); }}const resdableStream = new ReadableStream({ async start(controller){ for await (let chuck of ints()){ controller.enqueue(chunk); } controller.close } }) Copy the code
-
Writable stream: A stream that writes blocks of data through a public interface. Producers write data to the stream.
-
Transformation stream: Contains both readable and writable streams, whose contents can be examined and modified as needed.
-
20.11 Web components
-
A set of tools for enhancing DOM behavior, including shadow DOM, custom elements, and HTML templates.
-
The shadow DOM is created and added to a valid HTML element using the attachShadow() method.
/** * reads the drag and drop element */
let droptarget =document.getElementById("droptarget");
function handleEvent(event){
let info = "",
output = document.getElementById("output");
Files, i,len;
event.preventDefault();
if(event.type == 'drop'){
file = event.dataTransfer.failes;
i = 0;
len = failes.length;
while(i<len){
info += `${files[i].name} (${files[i].type}.${files[i].size} bytes)<br>`;
i++;
}
output.innerHTML = info;
}
}
droptarget.addEventListener("dragenter",handleEvent);
droptarget.addEventListener("dragover",handleEvent);
droptarget.addEventListener("drop",handleEvent);
// chain call
function person(){
}
person.prototype.getName=function(name){
this.name = name;
return this;
}
person.prototype.getAge=function(age){
this.age = age;
return this;
}
const a = new person().getName('kuishou').getAge('21')
console.log(a);
Copy the code
Chapter 23 — Parsing and serialization
- 23.2 a JSON object
- Serialization: The stringify() method takes a filter as its first argument, which can be an array or a function; The second argument is an option to indent the resulting JSON string.
- Parse () : The parse() method, also called the resurrection function, takes two parameters, the key and the value. You can take an extra argument, and the function is called once for each key/value pair.
Chapter 24 — Network Requests and Remote resources
- GET request: Used to query certain information from the server.
- POSE request: Used to send information to the server that should be saved.
- Fetch API: The browser sends a request to a given URL, reads the response, and processes the status code
- Web Socket: Full duplex, bidirectional communication with the server over a long-term connection. When JavaScript creates the Web Socket, an HTTP request is sent to the server to initiate the connection, and when the server responds, the Upgrade header used for the connection switches from HTTP to the proprietary server using the Web Socket protocol.
Chapter 26 — Modules
- Essentially a key/value entity,
- ES6 modules are executed in strict mode by default and do not share global namespaces.
Chapter 27 — Worker threads
- JavaScript is single-threaded, and in order to solve the concurrency problem, JavaScript proposes three types of worker threads
- Dedicated worker threads: Let the script create a separate JavaScript thread to perform the delegated task.
- Shared worker threads: Created threads can be used in multiple contexts, including different pages.
- Service worker thread: Intercepts, redirects, and modifies requests made by the page, acting as an arbiter of requests.