This set of notes is when I chew oN JavaScript advanced programming collation, to help me understand and architecture knowledge system. After finding the internship, I did not want my previous efforts to be dusted, so I took it out to provide help to my new friends. If there are any mistakes, you are welcome to correct them.

JavaScript introduction

Of JavaScript

  • Core (ECMAScript)

  • Document Object Model (DOM)

  • Browser Object Model (BOM)

ECMAScript

ECMAScript simply defines the basics of the JavaScript language, roughly as follows:

  • grammar

  • type

  • statements

  • The keyword

  • The operator

  • object

The Web browser is just one of its host environments, which provides not only the basic ECMAScript implementation but also language extensions such as DOM. Host environments include Web, Node, and Adobe Flash.

Document Object Model (DOM)

  • DOM1 level: maps document structure

  • DOM2 level:

    • DOM views

    • DOM events

    • DOM style

    • DOM traversal and scope

  • The DOM3 level:

    • Unified approach to loading and saving documents (DOM loading and saving modules)

    • Methods for validating documents (DOM validation module)

Browser Object Model (BOM)

The BOM is really just dealing with browser Windows and frames; But it is customary to count all JavaScript extensions to browsers as part of the BOM. Such as:

  • A new browser window is displayed

  • Zoom and close the browser window

  • Provides the browser details navigator object

  • A Location object that provides details about the page loaded by the browser

  • Screen object that provides details about the resolution of the user’s display

  • Support for cookies

  • Custom objects such as XMLHttpRequest

Use JavaScript in HTML

MIME types

Media Type MIME is a standard for representing the nature and format of a document, file, or byte stream.

Common format: Type /subtype(case insensitive, usually lowercase)

Independent type:

  • Text: Plain text, human readable

  • Image: image

  • Audio: indicates an audio file

  • Video: A video file

  • Application: some binary data

Using JavaScript in HTML:

  • Embedded code

  • External files

External files

Inside the <script> element there are the following attributes:

  • Async: asynchronous script;

  • Charset: Eliminated;

  • Defer: Defer the script;

  • Language: Obsolete

  • SRC: contains external files

  • Type: Indicates the content type of the scripting language

Of the above properties, the ones that need special attention are async asynchronous execution and defer execution. Both of these are asynchronous in nature:

  • Async is asynchronous download, execute immediately;

  • Defer, on the other hand, is an asynchronous download that executes after parsing the HTML page.



The browser rendering process

  • The HTML is parsed into a DOM Tree

    Convert the tag into a DOM tree

  • The CSS resolves to the CSS Rules Tree

    Multi-layer selectors search from bottom to top one by one, which is very efficient and avoids multi-layer situations as much as possible.

  • Building a Render tree

    By synthesizing the above two trees, a rendering tree is formed, including node content and node style. It is important to note that the render tree does not include all nodes in the DOM, only nodes that need to be displayed.

  • Layout calculates the information for each node according to the render tree

  • Painting draws based on calculated information

Foreign knowledge: reflux and redraw

  • Redraw: The rerendering of an area or object

  • Backflow: Rerendering an area or object and influencing its ancestors to redraw with it may cause the top-level ancestor to redraw the entire document.

The cost of repainting is small and the browser does not need to recalculate the style information for it, so it goes straight to the Painting phase.

Because of style or DOM changes, the render tree needs to be regenerated, so the above steps need to be redone, which is of course very expensive.

Backflow must occur redraw, redraw does not necessarily occur backflow

Common methods of causing reflux:

  • Add or remove visible DOM elements

  • Element size change

  • Text content change

  • Browser window size changed

  • Add or remove stylesheets

  • Enable CSS pseudo-classes

  • Manipulating Class attributes

  • Calculate offsetWidth and offsetHeight

  • Set the value of style

Optimize reflux

The optimization strategy of the browser itself: the browser maintains a queue and places the tasks to be backflowed and redrawn in this queue. When the number of tasks in the queue reaches a threshold or after a certain period of time, the browser will execute the tasks in the queue in a batch. The multiple recirculation calculations are then combined into one calculation.

There is some code that forces the browser to perform backflow immediately.

Optimized backflow is taking full advantage of optimized backflow in the browser:

  • Combine multiple DOM changes together

  • Set position to absolute or fixed for an element that requires multiple retakes, so that the element is removed from the document stream and its element redraw does not backflow upwards to affect the ancestor element. For example, animate elements should be set to Absolute as much as possible

  • The nodes are manipulated in memory and finally loaded into the document

  • Since elements with display of None are not in the render tree, it is possible to schedule complex element operations during element hiding so that only two renders are needed to complete the operation.

  • Cache variables when they are frequently fetched that cause the browser to rerender. The related operations are described above

  • Avoid table layouts

  • Avoid multiple inline styles

External knowledge points: DOM, Node, NodeList, HtmlCollection

The DOM (Document Object Model) represents a document as a logical tree, with each node containing an object.

Node is actually an interface from which many DOM API objects inherit, such as:

Document, Element, Attr, CharacterData (which Text, Comment, and CDATASection inherit), ProcessingInstruction, DocumentFragment, DocumentType, Notation, Entity, EntityReference

NodeList is a collection of Node objects, an array-like object, but not an array, forEach() to iterate over; It can also be converted to an Array using array.from ().

Source: return value of childNodes, querySelectorAll().

  • Dynamic collection: Objects returned by childNodes are dynamic, and changes to the DOM structure are automatically reflected in the saved objects.

  • Static collections: querySelectorAll returns static objects that do not change with the DOM.

The HtmlCollection interface represents a collection of elements in document order. Element is just one of 12 types of nodes.

Source: Methods such as getElementsByTagName(), getElemetsByClassName(), and getElementsByName(), as well as collections of elements such as children, document.links, and Document.forms.

All HtmlCollection objects are dynamic.

Differences: NodeList is quite different from HtmlCollection, mainly because of the difference between Node and Element. Newlines and Spaces in HTML Text count as nodes (Text), not elements.

The basic concept

Syntax, data types, flow control statements, functions

grammar

Identifier convention:

Small hump: theNameTag

annotation

// Single-line comment /* * This is * multi-line * comment */Copy the code

Strict mode

  • Global mode: Add: “Use strict” at the top

  • Local mode: Add: “use strict” at the top of the function

variable

Var, let, const

A declarative way Variable ascension Temporary dead zone Repeat statement The initial value scope
var allow There is no allow Don’t need In addition to the block-level
let Don’t allow There are Don’t allow Don’t need block-level
const Don’t allow There are Don’t allow Need to be block-level
Variable ascension

Variables can be used before declaration, and ES6 states that let and const do not undergo variable promotion.

Temporary dead zone

Related to variable promotion, because let and const do not have variable promotion, the area in a block of code before the variable is declared is dead.

Repeat statement

The initial value

Because const cannot be assigned, it must have an initial value.

scope

Var is defined above the code block and below the function body.

 if(true){ var a = 1; } console.log(a)//1Copy the code

In addition, there is another way to declare variables:

Name = ”; The declared variable is a global variable, no matter where it is declared…

Foreign knowledge point: global variable declaration

  • Declare variables externally

  • Without var, as a fault remedy in non-strict mode, the variable is directly taken as a global variable.

  • Add this variable explicitly to the window directly.

The data type

The typeof operator

  • Undefined: undefined. Variables that are declared to have no initial value and those that are not declared are undefined

  • Boolen:…

  • String:…

  • Object: indicates an object or NULL

  • Number:……

  • Function: includes parenthesis functions

Null type

Null returns a null pointer, so using typeof to detect null returns object. Note that == between null and undefined always returns true (presumably because both can be automatically converted to false)

 null == undefined //true null === undefined //falseCopy the code

Boolean type

Although there are only two literals for Boolean types, all types of values in ECMAScript have values equivalent to these two

The data type The value converted to true Convert to a value of false
Boolean true false
String Non-empty string “(empty string)
Number Any non-zero number (including infinity) 0 and NaN
Object Any object null
Undefined N/A (not applicable) undefined

The Number type

Decimal, octal, hexadecimal declaration method:

var intNum = 55; var octalNum = 055; // The first digit is zero and the default is octal. If subsequent numbers are out of range, zero is ignored. Var hexNum = 0x55; // The first two digits are 0xCopy the code

For arithmetic operations, both octal and hexadecimal numbers are converted to decimal.

MIN_VALUE: 5 e – 324

MAX_VALUE: 1.8 e308

Infinity: Infinity, automatically converted to Infinity or -infinity when the absolute value of a value exceeds the range

NaN: non-numeric, used when an operand that should return a value does not return a value (to avoid an error). Note that NaN is not equal to anything, including itself: NaN == NaN; / / false.

Method of determining NaN: isNaN()

Numerical conversion (transformation function)

It is important to distinguish between a transformation function, which is a function that returns a primitive data type, and a primitive wrapper type of the same name. The latter is a primitive wrapper type (a reference type) that creates an instance of the reference type (Object)

The Number () :

  • Number() can convert all types of variables. Non-string parameters are converted according to the conversion rule, which follows for converting strings

  • Non-numeric characters are present, converted to NaN

  • The empty string is converted to 0

  • Hexadecimal conversion to decimal, octal directly ignores leading zeros.

  • Normal conversion of floating point numbers

ParseInt () :

  • ParseInt () can only convert strings. Here’s how it differs from Number()

  • Ignore the leading whitespace, find the first non-whitespace character to start the calculation, or return NaN if the first non-whitespace character is not a number

  • According to the rules above, the empty string is converted to NaN

  • Ignore the non-numeric character parseInt(‘123sff’) that follows the number; / / 123

  • ECMAScript3 recognizes octal, but ECMAScript5 no longer automatically recognizes octal. A second parameter (base) can be added for identification

    parseInt('070',8);

The parseFloat () :

  • Parse decimal only

  • If conditional permits, decimal is returned.

# # # #

Type String

There is no difference between single and double quotation marks.

String variables are immutable

When assigning a value to a string, a new string variable is created to store the value of the new variable, and the original string variable is destroyed.

Convert to string

ToString () : Almost all variables have toString() except null and undefined.

String() : The String() method can be used when it is uncertain whether a variable is null or undefined.

The Object type

An object is a collection of data and functionality.

The operator

Just a few operators need to be noted

  • An operator

    • Not by bit: ~

    • Bitwise with: &

    • Bitwise or: |

    • Bitwise xor: ^

    • Left: < <

    • Move right with sign: >>

    • Unsigned move right: >>>

  • Boolean operator

    • Logic non:!

    • Logic and: &&

    • Logic or: | |

    The Boolean operators &&, | | and the operator of &, | are very similar. But there are still differences:

    Boolean operators are short-circuited and may not perform subsequent operations.

    var a = 10; //1010 var b = 11; //1011 var c = b; //1011 a|b++; // 10 = 1010; // 10 = 1011; / / 12 b++ performed a | | b++; //10 a converts totrueAfter that, it just returns the value of a, whatever is on the right-hand side. b; //11 b++ is short-circuited and not executedCopy the code

function

All aspects of this chapter are fairly basic and will be further explained in the following chapters.

Variables, scope, and memory issues

Base and reference types

Basic type: Simple data segment

Reference type: An object that may consist of multiple values

  • Basic data types:

    • Undefined

    • Null

    • Boolean

    • Number

    • String: Most languages treat strings as objects, but JavaScript does not.

  • Values of reference types: objects held in memory

Parameter passing

Parameter passing in JavaScript is value passing for both primitive and reference data types.

  • Value passing for primitive data types is well understood as a new copy that assigns the value to the local variable.

  • Passing a value that refers to a data type creates a new copy that holds the memory address of the object. As with reference passing in other languages, changes to this variable are reflected in external variables. The difference, however, is that assigning a new value to this local variable does not affect the value of the external variable.

     var obj = new Object();     obj.name = 'obj'; var func = (obj)=>{ console.log(obj.name); //obj obj = new Object(); obj.name ='obj2'; console.log(obj.name); //obj2 } func(obj) console.log(obj.name); //objCopy the code

Detection of type

The Typeof () function does a good job of class detection for basic data types, but for all reference types and null values, Typeof () can only return Object. This is where the instanceof operator is needed.

arr instanceof Array; //true

Exogenous knowledge point: change of strict model

  • Turn a fault operation (silent failure) into an exception throw

    • You cannot accidentally create global variables

    • Strict mode causes assignment operations that cause silent failures to throw exceptions, such as:

      NaN = 123; // Silent failed in non-strict mode; Throws an exception in strict mode

    • An exception is thrown when a non-deletable property is deleted (this is also a silent failure)

      delete Object.prototype; // Throw an exception

    • Function arguments cannot have the same name (normal mode allows the same name, overwriting occurs and can be accessed via arguments)

    • Octal syntax is disabled

  • Simplify the use of variables

    • Disable the with

    • Eval no longer introduces new variables for upper-level scopes

    • Do not delete declared variables

  • Changes to Eval and Arguments

    • Arguments and eval can no longer be assigned in eval.

    • Arguments no longer stay in sync with Arguments. Arguments and variables are always the same in normal mode.

    • Arguments.callee is no longer supported. Because the effect is small and affects optimization.

  • More secure

    • Function this is no longer cast to object.

      In non-strict mode this refers to a global variable in some cases

    • Disable caller

    • … +

Execution environment and scope

The execution environment

The execution environment defines the additional data that variables have access to and determines their respective behavior. Each execution environment has a variable object associated with it, and all variables and functions defined in the environment are stored in this object

In a Web browser, the global execution environment is Window.

Each function has its own execution environment. When the execution flow enters a function, the environment of the function is pushed into the environment stack (the stack includes its higher environment). After the execution of the function, the function environment is ejected.

The scope chain

When code runs in an environment, it creates a scope chain of variable objects to ensure orderly access to all variables and functions that the execution environment has access to.

Scope chain structure:

  • At the front of the scope chain is always the variable object of the environment in which the code is currently executing.

    • If the object is a function, the function’s active object is a variable object.

  • The next variable object in the scope chain comes from the next containment environment (the high-level containment environment), and so on.

  • The variable object of the global execution environment is always the last item in the scope chain.

    This allows code in the local environment to access variables in the parent scope through the scope chain. When you reference an identifier in an environment, search for the variable along the scope chain. From low to global.

Lengthen the scope chain

Some statements can temporarily add a variable object to the front of the scope chain, but the object is removed after the corresponding code has executed.

  • The catch block of a try-catch statement

  • With statement

Reference types

A reference type is a data structure used to organize data and functionality together, also known as a class.

The Object type

Create instance:

  • New operator

     var person = new Object(); person.name = 'Tom'; person.age = 19;Copy the code
  • Literal syntax:

     var person = {     name = 'Tom'."age"In literal syntax, attribute values can be literal or string}Copy the code

Access properties:

  • Dot notation

  • Square bracket notation: no different from dot notation except that variable access to properties is supported (dynamic)

The base type

Array type

Unlike Array objects in other languages, each item of the Array type can hold any type of data and can be dynamically resized.

Create an array:

var colors = new Array(); //new colors = []Copy the code

The length property of the array is not read-only. You can expand the array by setting length.

The join function

Take an argument, call each item’s toString () function, synthesize an entire string using the argument as a delimiter.

Stack method & queue method

You can use the methods provided by arrays to simulate different data structures.

The stack method

  • Push () : Takes any number of arguments and adds them to the end of the array.

  • Pop () : Gets the value at the end of the array

Queue method

  • push()

  • Shift () : Gets the value at the front of the array

Since the difference between stack and queue is fifO or FIFO, there is no difference between the entry function and whether the ejection function is ejected from the head or from the end.

Reorder method

  • Reverse () : Simply reverses the array

  • Sort () : Sorts the items in ascending order, but using the toString() method of the items.

    But when sorting numbers, sort() does not make a cross-bit comparison. So, the sort() method can take a function as an argument, and we can do custom comparisons.

Operating an array

  • Concat () : Copies a copy of the current array, adding arguments to the end of the copy (can be multiple arguments or an array)

  • Slice () : Creates a new array (copy) based on one or more items of the current array

    • One argument: all array items from the current position to the end

    • Two arguments: start position, end.

    • In the functions provided by the system, -1 usually represents the last one when it comes to indexes.

  • Splice () : Replacement function

    • Parameter 1: Start position. This parameter is mandatory

    • Parameter 2: Number of deletions. This parameter is mandatory

    • Parameter 3… : Inserted content

Location method

  • indexOf()

  • LastIndexOf () : The two functions perform an congruent comparison on each item.

An iterative approach

  • Every () : Returns true only if every item returns true, otherwise false

  • Some () : Returns true if any item returns true, false otherwise

  • Filter () : returns a new array of {items that return true}

  • ForEach () : No return value

  • Map () : returns a new array of {return result}

  • Each of the above functions takes a function as an argument and runs that function on each item in the array, depending on its own conditions. Where, parameters as functions are:

    • item

    • index

    • array

Merge method

  • Reduce () : Takes a function as an argument, executes that function on each item in the array, and takes the return value of that function as an argument to the next function. A function that takes arguments takes four arguments:

    • Prev: The initial value passed in is zero

    • cur

    • index

    • array

  • ReduceRight () : This is to merge the order from back to front.

The Date type

var date = new Date(); // Create Date() directly to get the current time object.Copy the code

Generate the date

  • Date.parse() : Parses Date arguments in string format

    Date.parse('2019/12/31'); / / 1577721600000Copy the code

  • Date.utc () : Parses multiple arguments representing dates

    Date.UTC(2019, 11, 31); / / 1577721600000Copy the code

    It is worth noting that the months in the UTC() function are evaluated from 0, i.e., 0 for January and 1 for February… . If the parameter is out of range, such as the month of “12,” which is handled differently by browsers, Chrome replaces it with the current date.

In addition, Date() in the constructor automatically calls the above two parsing methods, namely:

var date1 = new Date('2019/12/31'); var date2 = new Date(2019, 11, 31); var date3 = new Date(1577721600000); // All the above are equivalentCopy the code

  • Date.now() : Gets a millisecond representation of the current time.

  • Date.tostring () : Gets a description of the current time, and date.tolocalString ()

  • Date.valueof () : a millisecond representation of repeated dates, usually used to compare earlier and later times.

Related methods:

  • Formatting method: to… String.. (a)

  • Time component methods: getTime(), setTime(), getMonth(), getDay()…

The RegExp type

Regular expression format

var expression = / pattern /

flags

  • Pattern: Indicates the content of an expression

  • Mode of flags:

    • G: Global mode

    • I: case insensitive

    • M: Indicates the multi-line mode

Alternative syntax: var expression = RegExp(‘pattern’, ‘flags’);

The advantage of this syntax is that regular expressions can be defined dynamically using external variables.

grammar

Instance methods

  • Exec () : Designed specifically to capture groups.

    • Returns an instance of Array, recording the matched text Array, but with two special properties: index and input

  • Test () : Returns true if the pattern matches this parameter, false otherwise

  • Compile () : Regular expressions can be compiled during script execution or existing expressions can be changed

Constructor properties

Long attribute name Short attribute name instructions
input The $_ The last string to be matched
lastMatch $& The last match
lastPaten + $ The last capture group
leftContext $` The text before lastMatch in the input string
rightContext $' The text after lastmatch in the input string
mutiline $* Boolean value indicating whether all expressions use multi-line mode

The Function object

Functions are objects

Define a function

function sum(num1, num2){
    return num1 + num2;
}Copy the code
var sum = function(num1, num2){
    return num1 + num2;
}Copy the code
var sum = new Function('num1'.'num2'.'return num1 + num2');Copy the code

parameter

  • Parameters: Parameters in a function definition

  • Arguments: arguments passed in at actual runtime

JavaScript parameters are different from those of most other languages, and declaring parameters in the format is a convenience, not a requirement. You can actually call parameters with more or less than these parameters. Arguments end up in arguments

  • In non-strict mode, arguments remain consistent with the parameter, and changing the parameter changes arguments

  • In strict mode, this agreement no longer exists, and you can’t change the value of arguments.

There is no overload

Function parameters no longer need to exist because arguments exist, so overloading mechanisms that rely on parameter differentiation no longer exist.

Function declarations and function expressions

  • Function declaration: function func(params);

  • Function expression: ‘{…… }

Function parsers do not treat the two equally. When the parser loads data into the execution environment, it first reads the function declaration (state promotion) and makes it available before any code is executed. Function expressions are not actually executed until the line of code is executed.

This results in different results for the two functions:

sum(1, 2); // It works because sum is declared as a function and goes through the function declaration enhancement processfunction sum(num1, num2){
    return num1 + num2;
}Copy the code
sum(1, 2); Func is not afunctionIn the code promotion phase, sum is just a variable and has not yet been assigned tofunction
var sum = function(num1, num2){
    renturn num1 + num2;
}Copy the code

JavaScript execution process

Basic knowledge:

  • JavaScript is single-threaded, normally (when a new thread is not actively started

  • —–), a page has only one thread

  • JavaScript is executed asynchronously through an Event Loop

There are three main execution environments

  • The global environment

  • Function of the environment

  • eval()

Each time an environment is entered, a corresponding execution context is created. The JS engine processes these contexts in a stack (function call stack). The bottom of the stack is always the global context, and the top is always the current execution context (combined with the scope chain to understand).

  1. Compilation stage: compiler

    1) Lexical and grammatical analysis:

    Execute after the code has loaded

    2) Precompile phase: Precompile and execute every time you enter a new context

    • Function call stack

    • Create execution context

      1. Creating a variable object

        • Creating arguments objects is only done in a functional environment, not in a global environment

        • Check function declarations in the current context, looking in code order, attribute values are the memory address of the function, can be created, exist overridden

        • Check the variable declarations for the current context, looking them up in code order, and declaring any found variables ahead of time. Nonexistence creates, existence flits

        Note that in the global environment, the window object is the variable object of the global context. All variables and functions are properties and methods of the Window object

      2. Establish scope chains

        • The top stack of the scope chain is always the current scope

        • The bottom of the stack of a scope chain is always the global scope

        • The scope chain ensures orderly access to variables and functions by looking up variables and functions from the top of the scope chain, stopping when they are found, and throwing a reference error if they are not found at all.

      3. Make sure this points to

  2. Execution phase: Engine

    1) Enter the declaration cycle of the execution context

    2) Code execution

    3) Recycling

Function internal properties

There are two special objects inside the function:

  • Arguments: Array-like objects that store arguments passed in. But this object has other properties:

    • Callee: pointer to the function that has this Arguments object. Earlier ESMAScript disallowed the use of named function expressions, which made recursive operations impossible, so the arguments.callee property was added. ESMA5’s strict mode already disables arguments.callee.

  • This: This refers to the environment object in which the function is run.

Properties and methods of a function

Each function contains two attributes: length and prototype

  • Length: indicates the number of parameters that the function wants to receive

  • Prototype: This will be explained later in inheritance

    • apply()

    • call()

      These two functions are used to call parent functions in a specific context (scope).

          var obj = {
              name : "job"
          }
          var func = function(){ console.log(this.name); } func.apply(obj); //jobCopy the code

      The difference is that apply accepts this with an array, and Call accepts this with an argument list

    • Bind () : This method creates an instance of a function whose this value is bound to the value passed to bind

          var obj = {
              name : "job"
          }
          var func = function(){ console.log(this.name); } var a = func.bind(obj); a(); //jobCopy the code

      All three functions are essentially operating on this or the scope or execution environment

Basic packing type

To facilitate manipulation of primitive type values, ECMAScript provides three reference types. Each time a primitive type is read, an object of the corresponding primitive wrapper type is created behind the scenes, allowing us to call methods to manipulate the data:

When a string is read, the following happens:

  • Create an instance of String var STR = new String(‘ ABC ‘);

  • Invokes the specified method on the instance

  • Destroy the instance

The main difference between the application type and the base wrapper type is the declaration cycle, with the former being the current scope and the latter being the current line of code.

And that could explain some of the strange behavior:

var str = 'abc';
str.color = 'red'; str.color; //undefined, because the STR object is different from the above, destroy in time.Copy the code

You can also explicitly create objects of basic wrapper type to do the above, but don’t feel free to do so.

Also, instances of the basic wrapper type created using new are not the same as those created by calling the transformation function of the same name

var value = 2; var num = Number(value); Var obj = new Number(value); // Create a new instance with newCopy the code

Boolean type

Does not have much use and is easily confused with the basic types:

    var trueValue = true;
    var falseObject = new Boolean(false);

    console.log(falseObject&&trueValue); //trueBecause thefalseObject is a pointer to a Boolean that is automatically converted to in a logical operationtrueCopy the code

The Number type

Rewrite toString() to accept a single argument representing the cardinality of a number

Provides some methods for formatting the representation of values:

  • ToFixed () : Takes an argument and returns a rounded number of decimal places as a string.

  • ToExponential () : Returns a string representation of values in exponential representation

  • ToPrecision () : It may return either a fixed or exponential format, which accepts a single parameter representing the number of digits of all numbers.

Type String

  • CharAt () : takes the index argument and returns a character at a given position

  • CharCodeAt () : takes the index argument and returns the character encoding for the given position

  • Concat () : Concatenates multiple strings

  • Split string method: returns a new substring without changing the string

    • Slice () :

    • The substr () :

    • The substring () :

  • String position method: takes a string argument and returns the position in the string (-1 if not found)

    • IndexOf () :

    • LastIndexOf () : Returns the last value

  • Trim () : Creates a copy of the string, removing all pre – and post-whitespace

  • Case conversion:

    • ToLowerCase () :

    • ToUpperCase () :

  • Pattern matching:

    • Match () : Call this method on a string, essentially the same way you call the exec() method on a RegExp object. Accepts a regular expression or RegExp object, returns array, and has two special properties: input and index

    • Search () : Returns the location index or -1

    • Replace () : Takes two arguments, a regular expression (or string) and a string to be replaced on (which can also be a function called on each match).

  • LocaleCompare () : Compares strings, returns 1 for the first argument, -1 for the second argument, and 0 for both

  • FromCharCode () : takes string encoding and converts it to a string.

Single built-in object

Global object

The Global object is a back-pocket object that exists at the bottom of the scope chain and is the external environment for all environments.

The Math object

Only some methods are introduced:

  • Maximum and minimum value:

  • Rounding method:

    • Math.ceil() : Perform rounding up (into one)

    • Math.floor() : Perform round down (completely off)

    • Math.round() : round

  • Random number: random() : returns a random number that is greater than or equal to 0 and less than one.


Object-oriented programming (Object and prototype chain)

Understanding object

Object: An unordered collection of properties that can contain base values, objects, or functions

Attribute types

Data attributes

These features are intended to implement JavaScript engines and cannot be accessed directly from JavaScript. To indicate this, use the [[…]] notation:

  • [[64x]] : Indicates that the system can be redefined without any additional information, including deleting or modifying the property name

  • [[Enumerable]] : Can iterate through a for-in loop

  • [[Writable]] : indicates whether an attribute value can be modified

  • [[Value]] : The attribute Value of this attribute

The default value is true

To set the properties of the property, use Object.defineProperty()

 var person = {} Object.defineProperty(person, 'name', {     writable : false,     value : 'Tom', }) console.log(person.name); //Tom person.name ='Jack'; console.log(person.name); //Tom, failed to modify attributes, error reported in strict modeCopy the code

DefineProperty () specifies the writable and 64x properties, which default to false and cannot be modified.

Accessor properties

Accessor properties do not contain property values. They contain a pair of getter and setter functions (not required) that are called when the accessor property is read and when the accessor property is assigned a value. Accessor properties have the following [[features]]

  • [[64x]] : Works without any additional control system

  • [[Enumerable]] : Can we iterate (for-in)

  • [[Get]] : invoked when reading

  • [[Set]] : called when assigning

The default value for both getter and setter features is undefined.

Defining accessor properties also requires Object.definePropoerty()

 var person = {     _age:0 } Object.defineProperty(person, 'age', {     get: function() {return this._age;     },     set: function(param) { this._age = (param>10&&param<20)? param : this._age; } }) person.age = 12; person.age = 22; console.log(person.age); / / 12Copy the code

Read properties of properties

Object.getOwnPropertyDescriptor()

 var person = {     _age:0 } Object.defineProperty(person, 'age', {     get: function() {return this._age;     },     set: function(param) { this._age = (param>10&&param<20)? param : this._age; } }) var descripor = Object.getOwnPropertyDescriptor(person,'age'); console.log(descripor.configurable); //false, and don't forget that the accessor properties default tofalseCopy the code

Create an object

The factory pattern

Write a function that creates an object. When you need to create an object, you simply call the function. A model applies to a set of similar objects, saving a lot of code.

 var person = function(name, age, job){     var o = new Object();     o.name = name;     o.age = age;     o.job = job;     o.sayName = function(){         console.log(this.name);     }     return o; }Copy the code
Disadvantages:

Unable to determine object type (using Instanceof, isPrototyOf to determine type)

Constructor pattern

 var Person = function(name, age, job){     this.name = name;     this.age = age;     this.job = job;     this.sayName = function(){ console.log(this.name); }} / / noreturnVar per1 = new Person() var per2 = new Person()Copy the code

In fact, a constructor is a function that is treated as a constructor to create an object when used later with the new operator. In addition, the function names of constructors are usually capitalized to distinguish them from normal functions.

Procedure for creating a new instance using the new operator:

  • Create a new object

  • Assigns the constructor’s scope to the new object (so this refers to the new object)

  • Code to execute the constructor (add attributes for the new object)

  • Return a new object

Per1 and per2 respectively hold different instances of Person, both of which have a constructor attribute pointing to Person.

The advantages and disadvantages:
  • Advantages: Objects created through constructor methods can be typed with the instanceof operator

  • Disadvantages: Each method has to be recreated on each instance, which is unnecessary and can result in different scope chains and identifier resolution for functions of the same name on different instances.

The prototype pattern

Each function we create has a Prototype property, which is a pointer to an object containing properties and methods that can be shared by all instances of a particular type. Prototype is a shared repository of different instances of the same object type.

Every time a function (constructor) is created, it automatically generates a Prototype property that points to the prototype object; The prototype object also has a constructor attribute pointing to the original function. Mutual index.

The Prototype attribute of the instance is hidden (internal).

IsPrototypeOf () New check type function

As mentioned earlier, the instanceof operator uses constructor to detect instance types, and the isPrototypeOf() function uses the Prototype pointer to determine types.

In addition, the object.getProtoTypeof () function can return the instance’s prototype internal properties directly.

The prototype for

Whenever code reads an attribute of an object, it performs a search, targeting the attribute with the given name, first searching for the instance itself, and then following the stereotype pointer if none is found.

In the constructor pattern, executing the constructor adds attributes to the instance, whereas in the stereotype pattern, no attributes are added to the instance itself, but a pointer lookup of the stereotype (common repository) still finds the corresponding attributes.

Because of this, prototypes are dynamic. An instance under a stereotype can remain dynamically consistent with the stereotype, and whenever the stereotype is changed, the instance enjoys the change as long as the pointer does not change.

HasOwnProperty () checks whether an attribute is in an instance or a stereotype.

 per1 = new Person(); per1.hasOwnProperty('name'); //trueCopy the code

Properties defined in constructors are unique to the instance, not shared, and exist in the instance itself.

The IN operator and stereotypes

 'name' inper1; //trueCopy the code

Determine whether an instance has a property (either in the instance or in the stereotype)

This, combined with the hasOwnsProperty() function, determines whether an attribute belongs to the stereotype.

For-in Cycling through an instance returns all enumerable ([[Enmuerated]] properties of the instance is true. This includes both the properties of the instance itself and the properties of the instance’s prototype

Object. The keys () method

Keys () takes an object as an argument and returns a string array of all the enumerable properties of that object

Object. GetOwnPropertyNames () method

Also takes an object as an argument and returns all enumerable properties, including constructor.

There are two ways to use prototypes
  • Assigning values for each attribute alone does not change the orientation of the overall stereotype

 function Person(name, age, job){     this.name = name;     this.age = age;     this.job = job; } Person.prototype.toString = function(){         alert('hello')}Copy the code
  • Assign the entire prototype object directly, changing the point of the property pointer. This is faster, but changes the constructor orientation of the prototype Object (the new Object constructor points to the Object).

 function Person(name, age, job){     this.name = name;     this.age = age;     this.job = job; } Person.prototype = {     toString : {         alert('hello')}}Copy the code

When a function is created, a property Object is automatically generated. The constructor of the Object’s constructor points to the original function by default, but if the function is changed, the constructor of the function points to Object instead.

The advantages and disadvantages:
  • The advantages are the ability to share data and functions, as well as dynamic features

  • Cons: Also shared, no private data. At the same time, there is no custom initialization through constructors.

Use a combination of

Combine the advantages of constructors and stereotypes to use both approaches.

Encapsulate all the information in the constructor, and initialize the prototype in the constructor

Similar to the dynamic prototyping pattern that follows…

Dynamic prototype pattern

 function Person(name, age, job){     this.name = name;     this.age = age;     this.job = job; ​     if (this.sayName == undefined) {         Person.prototype.sayName = function(){             console.log(this.name);                      }     } } ​ var per1 = new Person('Tom', 18.'engineer'); per1.sayName(); ​Copy the code

The stereotype is assigned in judgment because the stereotype does not need to be assigned after initialization and will always exist.

The advantages and disadvantages
  • Advantages: Preserves the advantages of both constructors and prototypes, allowing type determination, sharing, private, and so on

Parasitic constructor pattern

This is a special case, similar to the factory pattern, but with the new operator:

function SpecialArray(){ var arr = new Array(); arr.push(... arguments); arr.res =function() {return this.join(', ')}return arr;
}
var colors = new SpecialArray('red'.'green');
console.log(colors.res());
Copy the code

Return (); return ();

  • No return value: a new object instance is created by default

  • Has a return value: returns the given instance

In this parasitic constructor mode, a new object is constructed by parasitizing an existing constructor, which can realize the effect of lossless expansion of system functions.

Secure constructor pattern

Secure objects: Objects that have no public attributes and whose methods do not reference this are suitable for use in some secure environments.

Inheritance and prototype chains

Inheritance is divided into interface inheritance and implementation inheritance in object-oriented languages, and ECMAScript only supports implementation inheritance (through prototype chains).

Prototype chain inheritance

 function Parent(){     this.name = 'parent'; } Parent.prototype.say = function(){     console.log(this.name); } var Child = function(){     this.name = 'Child'; } Child.prototype = new Parent(); ​ var child = new Child(); console.log(child.name); Child.prototype.say(); child.say(); ​Copy the code

Child inherits parent by setting prototype to an instance of parent

The essence of the implementation is to store the methods of the parent object into the prototype of the child object.

 function Parent(){     this.name = 'parent'; } Parent.prototype.say = function(){     console.log(this.name); } var Child = function(){     this.name = 'Child'; } Child.prototype = new Parent(); child = new Child(); child.say(); //childCopy the code

Constructor () {constructor () {constructor () {constructor () {constructor () {constructor () {constructor () {constructor (); Here the prototype assignment “splits” the instances before and after, no longer of the same type.

Determine the relationship between the prototype and the instance
  • The instanceof operator

  • IsPrototypeOf () method: Any prototype that appears in the prototype chain can be said to be the prototype of the instance derived from that prototype chain.

The advantages and disadvantages
  • Advantages: Convenience

  • Disadvantages: Sharing problems with prototypes, and the inability to customize individual instantiations

Borrow constructor inheritance

The idea is to call the parent type’s constructor (apply, call) inside the subtype’s constructor.

function Parent(name){
    this.name = name;
}
function Child(){
    Parent.apply(this, arguments);
}
var child = new Child('Tom');

console.log(child.name);Copy the code
The advantages and disadvantages:

This is not a mature approach at all, because without the use of a prototype chain, inheritance is not worthy of the name.

Combination of inheritance

The widely used inheritance method combines the borrowed constructor method with the prototype chain method, that is, the method defined on the I prototype realizes the reuse of functions, while ensuring that each instance has its own attributes.

function Parent(name){
    this.name = name;
}
Parent.prototype.say = function(){
    console.log(this.name);
}

function Child(name, age){
    Parent.apply(this, arguments);
    this.age = age;
}
Child.prototype = new Parent();
var child = new Child('Tom', 12); console.log(child.age); //12 child.say(); //TomCopy the code

Disadvantages: Repeated declaration of attributes in the parent class, resulting in memory waste.

Primary inheritance

Use object.create () to create a new Object whose prototype points to the parameter passed in.

 var Parent = {     name : "Parent",     say : function(){         console.log(this.name);     } } var child = Object.create(Parent); child.name = 'Child'; console.log(Object.getPrototypeOf(child)); //{name:"Parent", say: ƒ} child. Say (); //Child console.log(child.constructor); / / ƒObject() { [native code] }Copy the code

This method eliminates the need to set up a subclass constructor. Treating an instance as a prototype for a subtype is equivalent to child.prototype = Parent

This method saves a lot of steps compared to the composite method, and also eliminates a lot of functionality:

  • combined

    • There are separate constructors

    • Assign a stereotype of a subtype to an instance of the parent type

    • Because the constructors are complete, the constructor of the subclass instance points to the Child subclass

    • You can use Instanceof

  • The original type

    • Neither a subtype nor a parent type requires a constructor

    • An instance of a parent type acts directly as a stereotype of an instance of a child type (internal attribute)

    • Since no constructors are involved, the constructor of the subclass instance points to Object

    • Instanceof cannot be used

Parasitic inheritance

Disadvantages of combinatorial inheritance

Parasitic inheritance inherits the prototype of the parent class through an intermediate instance, eliminating the need for repeated declarations of the parent class attributes.

Parasitic combinatorial inheritance

conclusion

Although this chapter is extensive and introduces a variety of approaches, it is really a step-by-step guide to one or two mature approaches that are suitable for most situations. The bootstrapping process is helpful for deepening your understanding of the prototype, but there is no need to go back and forth.

There are three important concepts in this chapter:

  • Example: Reference types, including properties and functions, can be generated by various methods, such as literal generation, constructor generation, etc

  • Constructors: functions that are specifically used to generate instances are really functions for a specific purpose (recognize that constructors are functions). It needs to be used with the new operator. New creates a new object, assigns the scope of the object to the constructor (to use this), runs the constructor, and returns the object.

  • Stereotype: is a property of the constructor, an internal property of the instance (not directly accessible) that points to the stereotype object. The stereotype has a property constructor that points to the constructor that owns it, thus forming a closed chain.

When it comes to creating objects, composition is often used. That is, a combination of constructors and prototypes, with the best of both.

     function Person(name){         this.name = name;     }     Person.prototype.say = function(){         console.log(this.name);     }     var person = new Person('Tom');     person.say();Copy the code

When we create a function, its Prototype property object is automatically generated, whose constructor points back to the function.

Constructor: The constructor of the created object points to the constructor; Properties of instance objects are exclusive, not shared

Archetypes: Archetypes are implemented by referring to a chain of archetypes that share data between different instances of the same object, usually defining methods.

When inheriting, it still retains the combinatorial tradition, taking into account the advantages of constructors and prototypes:

     function Person(name){         this.name = name;     }     Person.prototype.say = function(){         console.log(this.name);     } ​     function Child(name){         Person.apply(this, arguments);     }     Child.prototype = new Person(); ​     var child = new Child('Tom');     child.say();Copy the code

You can also use object.create () to get lazy.

Functional expression

To start with, there are two ways to create a function:

  • Function declaration:

    The function person(){} method causes function declarative promotion, that is, the function can be called before it is declared.

  • Function expression:

    Var person = function(){} This method does not declare the function to be promoted, so a null pointer error will be raised if the function is called before.

recursive

Recursive functions are implemented by calling themselves by name within a function

Typically, function expressions and arguments.callee are used to make the calls.

closure

Closure: A function that has access to a variable in the scope of another function.

A common way to create closures is to create another function within a function.

     function person(name){         return function say(){             console.log(name);         }     }     person('Tom') (); //TomCopy the code



Closures can access external function variables for the following reasons:

Normally, when a function is created, its scope chain is automatically generated, and the end of the scope chain is the active object of the current execution environment. When exiting the current environment, the live object has no pointer index and is automatically reclaimed.

When a closure is present, the current environment is exited, but the closure is saved and there is still a pointer to the active object, so…

Closures and variables

Closures hold live objects that are saved when the function exits the scope (at run time), not live objects that were saved when the closure was created.

    function person(){
        var name = 'Tom';
        var say = function(){
            console.log('hey',name);
        }
        name = 'Bob';
        return say;
    }
    person()();Copy the code

When the say function is created, name is Tom, but when you exit the Person scope, name has changed to Bob. Closures access variables through indexes and are dynamic.

This object in the closure

var name = 'Window';

var o = {
    name : 'Object',
    getName : function() {return function() {returnthis.name; } } } console.log(o.getName()()); //WindowCopy the code

Arguments and this each function is automatically called with two special variables: Arguments and this. Internal functions that search for these variables only search for their own live objects, so this and arguments are impervious to closures.

Mimic block-level scopes

function parent(){
    (function(){
        var words = 'Tom'; console.log(words); //Tom })() console.log(words); //ReferenceError } parent();Copy the code

In (the function {… })() forms a block-level scope with its own scope

Private variables

Private variables are formed through the function’s own scope and closure.