Home >Web Front-end >JS Tutorial >What are the three types of objects in JavaScript?

What are the three types of objects in JavaScript?

青灯夜游
青灯夜游Original
2021-06-15 16:40:573458browse

Three types of objects in JavaScript: 1. Internal (set) objects, such as Array, Boolean, Data, Math, Number, Object, RegExp, String objects, etc.; 2. Host object, which executes JS scripts Objects provided by the environment; 3. Custom objects.

What are the three types of objects in JavaScript?

The operating environment of this tutorial: windows7 system, javascript version 1.8.5, Dell G3 computer

JS three objects

In JS, objects can be divided into three types: "internal objects", "host objects" and "custom objects".

As shown in the figure:

Internal object

⑴Number object

##⑵Math: Built-in object

Math object properties

PropertiesDescriptionEReturns the arithmetic constant e, the natural logarithm The base of (approximately equal to 2.718). LN2Returns the natural logarithm of 2 (approximately 0.693). LN10Returns the natural logarithm of 10 (approximately 2.302). LOG2EReturns the base 2 logarithm of e (approximately 1.4426950408889634). LOG10EReturns the base 10 logarithm of e (approximately 0.434). PIReturns pi (approximately equal to 3.14159). SQRT1_2Returns the reciprocal of the square root of 2 (approximately equal to 0.707). SQRT2Returns the square root of 2 (approximately 1.414).

Math object method

MethodDescription abs(x)Returns the absolute value of x. acos(x)Returns the arc cosine of x. asin(x)Returns the arcsine of x. atan(x)Returns the arctangent of x as a number between -PI/2 and PI/2 radians. atan2(y,x)Returns the angle from the x-axis to the point (x,y) (between -PI/2 and PI/2 radians between). ceil(x) Round the number up. cos(x)Returns the cosine of the number. exp(x)Returns the exponent of Ex. floor(x)Round x down. log(x)Returns the natural logarithm of the number (base is e). max(x,y,z,...,n)Returns the highest value among x,y,z,...,n. min(x,y,z,...,n)Returns the lowest value among x,y,z,...,n. pow(x,y)Returns x raised to the y power. random()Returns a random number between 0 ~ 1. round(x)Rounding. sin(x)Returns the sine of the number. sqrt(x)Returns the square root of the number. tan(x)Returns the tangent of the angle.

⑶Boolean object

Boolean object attribute

PropertiesDescriptionconstructorReturns a reference to the Boolean function that created this objectprototype Gives you the ability to add properties and methods to objects.

Boolean object method

MethodDescriptiontoString()Convert the Boolean value to a string and return the result. valueOf()Returns the original value of the Boolean object.

⑷String object

String object attribute

PropertiesDescriptionconstructorA reference to the function that created the objectlengthThe length of the stringprototypeAllows you to add properties and methods to the object

String Object method

Method Description
charAt() Returns the character at the specified position.
charCodeAt() Returns the Unicode encoding of the character at the specified position.
concat() Concatenates two or more strings and returns a new string.
fromCharCode() Convert Unicode encoding to characters.
indexOf() Returns the position where a specified string value first appears in the string.
includes() Find whether the specified substring is included in the string.
lastIndexOf() Search the string from back to front, and calculate the last occurrence of the returned string starting from the starting position (0).
match() Find a match for one or more regular expressions.
repeat() Copy the string a specified number of times, concatenate them together and return.
replace() Find the matching substring in the string and replace the substring that matches the regular expression.
search() Find values ​​that match a regular expression.
slice() Extracts a fragment of a string and returns the extracted part in a new string.
split() Split the string into a string array.
startsWith() Check whether the string starts with the specified substring.
substr() Extracts the specified number of characters from the string from the starting index number.
substring() Extract the characters between two specified index numbers in the string.
toLowerCase() Convert the string to lowercase.
toUpperCase() Convert the string to uppercase.
trim() Remove the whitespace on both sides of the string
toLocaleLowerCase() According to the local The host's locale converts the string to lowercase.
toLocaleUpperCase() Convert the string to uppercase according to the local host's locale.
valueOf() Returns the original value of a string object.
toString() Returns a string.

⑸RegExp object

RegExp object method

Method Description
compile Deprecated in version 1.5. Compile regular expressions.
exec Retrieve the value specified in the string. Returns the found value and determines its position.
test Retrieve the value specified in the string. Returns true or false.
toString Returns the string of the regular expression.

Methods of String objects that support regular expressions

Methods Description FF IE
search Retrieve values ​​that match a regular expression. 1 4
match Find a match for one or more regular expressions. 1 4
replace Replace the substring that matches the regular expression. 1 4
split Split the string into a string array. 1 4

RegExp Object Properties

Properties Description
constructor Returns a function that is a prototype for creating RegExp objects.
global Determine whether the "g" modifier is set
ignoreCase Determine whether it is set The "i" modifier
lastIndex is used to specify the starting position of the next match
multiline Determine whether the "m" modifier is set
source Return the matching pattern of the regular expression

⑹Global: Built-in object

JavaScript global property

Attribute Description
Infinity Represents a positive infinity value.
NaN Indicates whether a value is a numeric value.
undefined Indicates an undefined value.

JavaScript global function

Function Description
decodeURI() Decode an encoded URI.
decodeURIComponent() Decode an encoded URI component.
encodeURI() Encode a string into a URI.
encodeURIComponent() Encode a string into a URI component.
escape() Encode the string.
eval() Evaluates a JavaScript string and executes it as script code.
isFinite() Check whether a value is a finite number.
isNaN() Checks whether a value is a number.
Number() Convert the value of the object to a number.
parseFloat() Parse a string and return a floating point number.
parseInt() Parse a string and return an integer.
String() Convert the value of the object to a string.
unescape() Decode the string encoded by escape().

⑺Date object

Date object properties

Property Description
constructor Returns a reference to the Date function that created this object.
prototype Gives you the ability to add properties and methods to objects.

Date object method

Method Description
getDate() Return the day of the month (1 ~ 31) from the Date object.
getDay() Returns the day of the week (0 ~ 6) from the Date object.
getFullYear() Returns the year as a four-digit number from a Date object.
getHours() Returns the hours (0 ~ 23) of the Date object.
getMilliseconds() Returns the milliseconds (0 ~ 999) of the Date object.
getMinutes() Returns the minutes (0 ~ 59) of the Date object.
getMonth() Returns the month (0 ~ 11) from the Date object.
getSeconds() Returns the number of seconds in the Date object (0 ~ 59).
getTime() Returns the number of milliseconds since January 1, 1970.
getTimezoneOffset() Returns the difference in minutes between local time and Greenwich Mean Time (GMT).
getUTCDate() Returns the day of the month (1 ~ 31) from the Date object based on universal time.
getUTCDay() Returns the day of the week (0 ~ 6) from the Date object based on universal time.
getUTCFulYear() Returns the four-digit year from a Date object based on universal time.
getUTCHours() Returns the hour (0 ~ 23) of the Date object according to universal time.
getUTCMilliseconds() Returns the milliseconds (0 ~ 999) of the Date object according to universal time.
getUTCMinutes() Returns the minutes (0 ~ 59) of the Date object according to universal time.
getUTCMonth() Returns the month (0 ~ 11) from the Date object according to universal time.
getUTCSeconds() Returns the seconds (0 ~ 59) of the Date object according to universal time.
getYear() is obsolete. Please use the getFullYear() method instead.
parse() Returns the number of milliseconds from midnight on January 1, 1970 to the specified date (string).
setDate() Set a certain day of the month (1 ~ 31) in the Date object.
setFullYear() Set the year (four digits) in the Date object.
setHours() Set the hours (0 ~ 23) in the Date object.
setMilliseconds() Set the milliseconds (0 ~ 999) in the Date object.
setMinutes() Set the minutes (0 ~ 59) in the Date object.
setMonth() Set the month (0 ~ 11) in the Date object.
setSeconds() Set the seconds (0 ~ 59) in the Date object.
setTime() The setTime() method sets a Date object in milliseconds.
setUTCDate() Sets the day of the month (1 ~ 31) in the Date object according to universal time.
setUTCFulYear() Sets the year (four digits) in the Date object according to universal time.
setUTCHours() Sets the hour (0 ~ 23) in the Date object according to universal time.
setUTCMilliseconds() Sets the milliseconds (0 ~ 999) in the Date object according to universal time.
setUTCMinutes() Set the minutes (0 ~ 59) in the Date object according to universal time.
setUTCMonth() Set the month (0 ~ 11) in the Date object according to universal time.
setUTCSeconds() The setUTCSeconds() method sets the seconds field of the specified time based on Universal Time (UTC).
setYear() is obsolete. Please use the setFullYear() method instead.
toDateString() Convert the date part of the Date object to a string.
toGMTString() is obsolete. Please use the toUTCString() method instead.
toISOString() Returns the date format of the string using the ISO standard.
toJSON() Returns the date string in JSON data format.
toLocaleDateString() Convert the date part of the Date object into a string according to the local time format.
toLocaleTimeString() Convert the time part of the Date object into a string according to the local time format.
toLocaleString() Convert the Date object to a string according to the local time format.
toString() Convert a Date object to a string.
toTimeString() Convert the time part of the Date object to a string.
toUTCString()

Convert a Date object to a string according to universal time.

Example:

var today = new Date();var UTCstring = today.toUTCString();
UTC() Returns the number of milliseconds from January 1, 1970 to the specified date according to universal time.
valueOf() Returns the original value of the Date object.

⑻Object object

⑼Array object

⑽Function object

Various error class objects:

⑴Error

⑵EvalError

⑶RangeError

⑷ReferenceError

⑸SyntaxError

⑹TypeError

JS Host Object

⑴ Definition: The host object is to execute JS script Objects provided by the environment.

⑵ Browser object: For JS embedded in a web page, its host object is the object provided by the browser, so it is also called a browser object, such as the objects provided by browsers such as IE and Firefox.

⑶ Note: The host objects provided by different browsers may be different. Even if the objects provided are the same, their implementation methods are also very different! This will cause browser compatibility issues and increase development difficulty.

⑷ Examples of host objects: window, navigator, document, etc.

⑸ Browser extension objects: Active, XML, Debug, Script, VBArray, etc.

JS custom objects

⑴Object literal method (creating objects through JSON)

Disadvantages: Using the same interface to create many objects will generate a large number of of duplicate code.

⑵Factory mode.

①Factory pattern is to put the statement of creating an object in a function, create a specific object by passing in parameters, and finally return the created object.

The function createPerson() can construct a Person object containing all necessary information based on the parameters received.

This function can be called countless times, and each time it will return an object containing 2 properties and a method.

②Disadvantages: Although the factory pattern can create multiple similar objects, it cannot solve the problem of object identification, that is, how to know the type of an object.

⑶Constructor pattern

①Disadvantages: The main problem with using constructors is that each method must be created on each instance.

②In ECMAScript, functions are objects, so every time a function is defined, an object is instantiated.

③In other words, the methods of multiple objects instantiated through the constructor are multiple different methods, but their internal codes and implemented functions are the same, which results in a certain waste of resources. .

⑷Prototype pattern

①In js, each function has a prototype attribute, which is a pointer pointing to an object, called a prototype object.

②Using the prototype pattern allows all instances to share the properties and methods in the prototype object, that is, there is no need to define the information of the object instance in the constructor.

③Disadvantage: The link of passing initialization parameters to the constructor is omitted. As a result, all instances will obtain the same attribute value by default.

The biggest problem with the prototype pattern is caused by its shared nature. All properties in the prototype are shared by many instances

This kind of sharing is very suitable for functions. For properties containing reference types, the problem is more prominent.

④ Therefore, the prototype pattern is rarely used alone.

⑸ Use the constructor pattern and prototype pattern in combination

① Use the constructor pattern and prototype pattern in combination, which is the most common way to create a custom type.

②Constructor pattern is used to define instance properties, while prototype pattern is used to define methods and shared properties.

③ As a result, each instance will have its own copy of the instance attributes, but at the same time it will share references to methods, saving memory to the maximum extent.

⑹Other modes

①Dynamic prototype mode: Only when the constructor is called for the first time, assign the method to the corresponding attribute of the prototype object, processing of other examples The method is the same as the constructor pattern

②Parasite constructor pattern: only encapsulates the code that creates the object, and then returns the newly created object, still using the new operator to call

③Safe constructor pattern: There are no public properties, only private variables and methods, and some get/set methods to deal with private variables.

For more programming-related knowledge, please visit: Introduction to Programming! !

The above is the detailed content of What are the three types of objects in JavaScript?. For more information, please follow other related articles on the PHP Chinese website!

Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn