Send in your resume and get to the interview

1. How long have you been touching the front end

Oneself feel contact front end very long time, but think carefully, answer of feel guilty, although contact time is long, but failed to learn seriously well

2. Basic data types of js

  • There are six basic data types of ES5 (number, string, Boolean, undefined, null, object), the object is complex data types

  • ES6 added a Symbol (this type of object is never equal, which can be used as a Symbol to resolve property name conflicts), and Google 67 added a Bigint.

  • What types of object are included: Data,function,Array, etc

  • Js basic types: String, Number, Boolean, null, and undefined

  • Reference type: object. It contains function, Array, and Date

The difference between “==” and “===”

  • “==” means equal (value equal)
  • “===” denotes identity (both types and values must be equal)

When js is comparing, “==” will perform type conversion first, and then judge whether the value is equal. If it is “===”, the type and value must be equal

4. Differences between Typeof and Instanceof

  • Typeof:The value is string, Boolean, number, function, object, and undefined.

Typeof evaluates null, array, object, and function instances (new+ function) with object. This makes it impossible to determine these data types without the actual data type, so instanceof is used

  • Instanceof:Determines whose instance the object is. Instanceof is the object operator

5. Concept of prototype chain

Stereotypes are used to make one reference type inherit the properties and methods of another reference type.

  • The prototypeA stereotype is a property of the function object that defines the common ancestor of the object produced by the constructor and provides properties and methods that can be inherited by future generations.Prototypes are also objects
  • Prototype is the constructor property (default) and is an empty object
Name ="mm" // Person. Prototype =" male "Person. Prototype = {name:'mm', } function Person(){this.age = 17, This.sex = "female"} var person = new person () console.log(person) console.log(person.Copy the code

– undefined prototype: avoids code redundancy. It is impossible to modify prototype properties by extracting the public part of the prototype and adding it to the object. Property to delete properties, but you cannot delete properties of the stereotype

  • Constructor returns the constructor that builds the object, which can be changed manually
The console. The log (person) constructor) / / return the person the constructor function Car () {} Car. The prototype. The constructor = person var Car = new Car () Console. log(car.constructor) // Manually change to return PersonCopy the code
  • __proto__Object view prototype,__proto__Inside is the prototype
  • Prototype chain
Grand.prototype.lastname="yyy" function Grand(){this.age = 12} var grand = new Grand() Father.prototype = grand function Father () {this. Sex = "female"} var Father = new Father () Son. Prototype = Father function Son () {this. Car = 'w'} var Son = new Son() console.log(son) console.log(son.car) console.log(son.sex) console.log(son.name) console.log(son.__proto__ == Son.prototype) console.log(son.__proto__.__proto__ == Father.prototype) console.log(son.__proto__.__proto__.__proto__ ==  Grand.prototype)Copy the code

Object. Prototype children can change the parent reference value (heap), not the original value

6. How closures work

Closures: Closures allow you to access the scope of an outer function in an inner function. When an internal function is saved externally, a closure is generated. Closures can cause the original scope chain to not be released, causing a memory leak

Function test(){var a = 100 function test1() {console.log(a)} return test1} var out = test() Return var demo function test(){var a = 100 function test1() {console.log(a)} demo = test1} test() demo()Copy the code
  • Excellent: variable safety, reduce memory consumption
  • Missing: Memory leaks

Great writing by the big guy blog.csdn.net/weixin_4358… Blog.csdn.net/weixin_4358…

7. Variable promotion

Js code execution process is divided into two stages

  • 1. Lexical analysis (mainly including analysis variable declaration, analysis function declaration and analysis parameter)
  • 2. Implementation phase

Variable ascension

var a = 100; Console. log(a,b) var b = 200Copy the code

Function increase

A named function can be declared in two ways:

    1. Functional declaration
    1. Function literals
Var foo = function(){} var foo = function(){}Copy the code

Function declarations are promoted slightly differently from variable promotions in that they are promoted to the top of the scope, and the declaration content is promoted to the top with it. Function literals declare that they promote only a variable that has no value, as normal variables do.

Function bar(){console.log(100)} function bar(){console.log(100)} bar is not a function var bar = function(){ console.log(100) }Copy the code
  • In ES6, let and const have no variable promotion, only var has variable promotion
  • All declarations are promoted to the top of the scope.
  • The same variable is declared only once; others are ignored or overwritten.
  • Function declarations take precedence over variable declarations, and the function declaration is promoted along with the part of the function definition.

8. What is deconstruction assignment

Es6 allows you to extract values from arrays or objects in a pattern called deconstructed assignment

  • 1. Assign values to variables
  • 2. The source of the value is an object or array
  • 3. Rules: Generally used in data interaction and Ajax data request according to a certain pattern
Let [a,b,c] = [1,2,3]; Console. log(a,b,c) // let arr = [1,2,3]; console.log(arr[0],arr[1],arr[2]) //2. Let json = {name :'ymm', age:18, job:'web'} let {name,age,job} = json; console.log(name,age,job) // ymm 18 web // 3. Let person = {name: 'ymm', age:18, job:'web'} let {name:n,age:a,job:j} = person; Console. log(n,a,j) // Both obj have the same properties, Let obj1 = {data: 1, name:'ymm'} let obj2 = {data: 1, age:16} let {data:B1d,name} = obj1; let {data:B2d,age} = obj2; Console. log(B1d,B2d,name,age) // undefined and null let [a, B, C,d] = [1, 3,null] console.log(a,b,c,d) // 1 undefined 3 null Let [e, f = "no", g] = [1, null] the console. The log (e, f, g = = null? Let [a,b] = [10,5]; let [a,b] = [10,5]; [b,a] = [a,b]; Console. log(a,b) // 5. Return function fun(){left:20, tops:30 } } let {left,tos} = fun() console.log(left,tops)Copy the code

At the top level of JS, there is a global object window. All properties and methods on the window are global properties and methods. Name and top properties are used by the Window object

9. Use of Promise objects

Represents events that will occur in the future and is used to deliver messages for asynchronous operations

The characteristics of

  • 1. The object status is not affected by external events. Promise indicates that an asynchronous operation has three states pending: the initial state, which is not successful or failed, which is a pity: the operation success state rejected: the operation failure state

Only the result of an asynchronous operation can determine which state is currently in. No other operation can update this state

  • 2. Once the state has changed, it will never change again. This result can be obtained at any time

The advantages and disadvantages

  • Advantages:(1) Express asynchronous tasks synchronously, avoiding layer upon layer nested callback functions; (2)Promise objects provide a unified interface that makes it easier to control asynchronous operations
  • Disadvantages:(1) Promise cannot be cancelled. Once a Promise is created, it will be executed immediately and cannot be cancelled midway; (2) If the callback function is not set, errors thrown inside a Promise will not be reflected externally; (3) When in the pending state, it is impossible to know the current stage of progress (just started or nearly completed)

Creation of Pomise (instantiated by the Promise constructor)

Var promise = new promise (function(resolve,reject){resolve,reject})Copy the code

The Promise constructor contains one argument and a callback with resolve and reject, calling resolve if all goes well and reject if not

Promise. Then (). The catch () : Promise.all() can be called for already instantiated Promise objects: for multiple Promise instances, Wrapper into a new Promise instance Promise.race(): Wraps multiple Promise instances into a new Promise instance Promise.resolve(): converts existing objects into Promise objects Promise.reject(): returns a new Promise instance with the state bit Rejected

10. How does js add an event listener

1. Add directly (directly bind events)

 ele.onclick = function(){}
Copy the code

This approach is compatible with mainstream browsers, but when multiple events are bound, only the last event will be fired

ele.onclick = handler1; ele.onclick = handler2; ele.onclick = handler3; // Only hander3 will be triggeredCopy the code

2. The addEventListener and attachEvent

Event bubbling and event capture

  • Event bubbling is triggered from the innermost to the outermost
  • Event capture is triggered from the outermost layer to the innermost layer
< div id = "div1" > < div id = "div2" > < div id = "div3" > click me < / div > < / div > < / div >Copy the code

Document -> HTML -> Body ->div1->div2-> document-> document-> body->div1->div2->div3

AddEventListener: standard

ele.addEventListener("click",handler1,false);
ele.addEventListener("click",handler2,false);
ele.addEventListener("click",handler3,false);
Copy the code

Execution order is 1-2-3 (handler1 handler2, handler3), the first to add the event to perform the addEventListener () has three parameters, the parameter is an event name (required), the second parameter is the event of executive function (required), three parameters are parameters is bubbling, Is a Boolean value: inside-out (bubble) when false (default), outside-in (capture) when true

RemoveEventListener () is a delete event handler that also takes three arguments: the name of the event to process, the function that acts as the event handler, and a Boolean (called in capture phase if the Boolean argument is true, or in bubble phase if the argument is false)

When used together, the parameters must be the same (do not directly pass the same function.) attachEvent: IE

ele.attach("click",handler1);
ele.attach("click",handler2);
ele.attach("click",handler3);
Copy the code

Three methods of execution order is 3-2-1 (handler3 handler2, handler1), finally add event to perform the attach () takes two parameters, the event name and event handlers (IE8 and earlier version only supports the bubbling events) deattach () takes two parameters, Event name and event handler

When used together, the parameters must be the same (do not directly pass in the same function name).

11. Memory leaks

What is a memory leak: refers to the heap memory program has dynamic allocation procedure not release or for some reason cannot be freed, wastes the system memory, cause the program to run at a slower pace and even system crash serious consequences, such as short answer: due to negligence or error program fails to release the memory is no longer used, resulting in waste of memory.

Memory leak scenario

  • closure
  • Unexpected global variables (the use of an undeclared variable creates a new variable in the global object) – add ‘use strict’ to the js file and turn on strict mode to solve this problem
Function fun(){this.a = "test"} fun() // a should be a reference to the internal scope variable of funCopy the code
  • Timers and callback functions setInterval or setTimeout are not cleared when they are not needed. As a result, the timer callback function and its internal dependent variables cannot be reclaimed, resulting in memory leaks.

    Solution: Call clearInterval or clearTimeout when interval or timeout is not needed

  • DOM leak

  • Console (Console. log objects cannot be garbage collected)

12. Cross-domain solutions

Cross-domain causes

The same origin policy of the browser is restricted. Same-origin means that the protocol, domain name, and port number of two pages in the same domain are the same.

What is cross-domainWhen a URL has a different protocol, domain name, or port number, it is cross-domain

Cross-domain solutions

  • Set the doucument. Domain ()
  • Cross-document communication API: window.postmessage ()
  • JSONP
  • CORS

Blog.csdn.net/qq_38128179…

Decorators in ES6

A Decorator is a class-related syntax for annotating or modifying classes and their methods. A decorator is a function named @ +. It can precede the definition of classes and class methods

@testable
class myClass{
  // ...
}
function teatable(target){
	target.isTestable = true;
}
myClass.isTestable // true
Copy the code

Testable. Modifies myClass behaviour and adds the stable attribute to the stable stable stable method. Testable functions target parameters are myClass itself

14. How to write observer mode

The observer pattern is a type of software design pattern in which a target manages all observer objects that are dependent on it and actively notifies it of changes in its own state. (The corresponding processing function is automatically executed when the data is changed)

In Vuejs, watch listens when the v-Model value changes

Blog.csdn.net/lm278858445…

What is the publisher/subscription mode (subscriber, dispatch center, publisher)? Subscribers register the events they want to subscribe to with the dispatch center. When the event is triggered, the publisher publishes the event to the dispatch center (with context), and the dispatch center schedules the subscribers to the processing agent of the dispatch center.

Segmentfault.com/a/119000001…

15. How does Webpack build open source projects

Blog.csdn.net/cdnight/art…

Projects today are generally integrated internally

16. Common git commands

Git config --global user.name "" 4. Git add Add the file to your repository. Type Single file add (2)git add./ All files add (3)git add. SRC commit files in a folder 5. Git commit -m 'version description' commit files to repository (commit to local server) 6 Git diff git diff git diff git diff difference Git log --pretty=oneline git log -- oneline git log --pretty=oneline git log Git reset --hard head^ version rollback git reset --hard version rollback git reset --hard version rollback git reflog version rollback 12.git stash Used to temporarily save and restore changes, save current work progress, and restore the workspace and staging area to before the change. Git branch check the current branch. Git branch check the current branch. Git branch check the current branch Git branch -d name git branch -d name Git branch -d name Git remote rm + name git remote rm + name git remote rm + name git remote rm + name git push: Git fetch: fetching the specified branch of the remote library to the local library without merging git merge: To capture the remote branch, and the current branch to mergeCopy the code

17. What does Vuex do? There are those core concepts

Vuex is a state management mode developed specifically for VuejS application management