Front-end前端面试的种种

这篇文章里面的问题是来自github上面一个repo的,我在复习前端的适合找到了question list; 当然,他们没有solution, 所以我就试着在回答一些typical的问题,以供自己未来纠正和学习。有兴趣的朋友可以以此为参照进行复习,也欢迎来我的Shawn's Github关注最新的答案进展。

Front-end Knowledge

Forked from h5bp to learn basic front-end knowldge.

Note: This doc is used to document resources and potential answers to the question list. Please refer back to h5bp for original contents.

Table of Contents

  1. General
  2. HTML
  3. CSS
  4. JS
  5. Testing
  6. Performance
  7. Network
  8. Coding
  9. Fun
  10. Angular

General:

  • What did you learn yesterday/this week?
  • What excites or interests you about coding?
  • What is a recent technical challenge you experienced and how did you solve it?
  • What UI, Security, Performance, SEO, Maintainability or Technology considerations do you make while building a web application or site?
  • Talk about your preferred development environment.
  • Which version control systems are you familiar with?
  • Can you describe your workflow when you create a web page?
  • If you have 5 different stylesheets, how would you best integrate them into the site?
  • Can you describe the difference between progressive enhancement and graceful degradation?
  • How would you optimize a website's assets/resources?
  • How many resources will a browser download from a given domain at a time?
    • What are the exceptions?
  • Name 3 ways to decrease page load (perceived or actual load time).
  • If you jumped on a project and they used tabs and you used spaces, what would you do?
  • Describe how you would create a simple slideshow page.
  • If you could master one technology this year, what would it be?
  • Explain the importance of standards and standards bodies.
  • What is Flash of Unstyled Content? How do you avoid FOUC?
  • Explain what ARIA and screenreaders are, and how to make a website accessible.
  • Explain some of the pros and cons for CSS animations versus JavaScript animations.
  • What does CORS stand for and what issue does it address?

HTML:

  • What does a doctype do?
  • What's the difference between standards mode and quirks mode?
  • What's the difference between HTML and XHTML?
  • Are there any problems with serving pages as application/xhtml+xml?
  • How do you serve a page with content in multiple languages?
  • What kind of things must you be wary of when design or developing for multilingual sites?
  • What are data- attributes good for?
  • Consider HTML5 as an open web platform. What are the building blocks of HTML5?
  • Describe the difference between a cookie, sessionStorage and localStorage.
  • Describe the difference between tag, and give that script block a id. The id will be reference in angular .config routing.
    • Explain "hoisting".
    //Hoisting is JavaScript's default behavior of moving all declarations to the top of the current scope (to the top of the current script or the current function).
    rst = 11;
    console.log(rst);//outputs 11, and it's valid
    var rst;
    
    • Describe event bubbling.
    Event bubbling triggers the innermost elements that has a event handler registered with it. If no event handler registered, it propagates to its parent/outer element.
    Event bubbling directs an event to its intended target, it works like this:
    A button is clicked and the event is directed to the button
    If an event handler is set for that object, the event is triggered
    If no event handler is set for that object, the event bubbles up (like a bubble in water) to the objects parent
    //capturing:
    Different from event bubbling. The event is first captured by outermost elements, then propagates to inner elements.
    
    • What's the difference between an "attribute" and a "property"?
    //Note: we are looking at JavaScript property here.
    //It's bascially the different property items separated by ',' in the javascript object.
    var person = {
        firstname:"John",
        lastname:"Doe",
        age:50,
        eyecolor:"blue"
    };
    //firstname, lastname, age, eyecolor are all properties.
    //About attributes of a Javascript object's perperty: http://xahlee.info/js/javascript_property_attributes.html
    console.log(Object.getOwnPropertyDescriptor(person, "firstname"));
    //Object {value: "John", writable: true, enumerable: true, configurable: true}
    //Property's attribute (property descriptor) tells if a property is: writable, enumerable, configurable.
    
    • Why is extending built-in JavaScript objects not a good idea?
    Native JavaScript objects are implemented according to standard like ES5, ES6. If we choose to change the behavior, there is a chance that we break the rules specified.
    Also, if the later on we need to adapt to later version of ECMAScript, we have to check all the extended objects again.
    When need some extended feature, just build a standalone object.
    
    • Difference between document load event and document ready event?
    //$(document).ready() fires when the HTML finishes loading. It does not care about images, scripts, css ... etc
    //window.onload: a bit slower. It waits for all contents(images, css, scripts ... etc), then fires.
    
    • What is the difference between == and ===?
    === check for object type matching as well.
    vs.
    == check for value only.
    
    • Explain the same-origin policy with regards to JavaScript.
    The same-origin policy restricts how a document or script loaded from one origin can interact with a resource from another origin. It is a critical security mechanism for isolating potentially malicious documents.
    For example, it fails and triggers cross-origin error, if:
     -you try to use different protocol: http vs. https
     -you try to use different port
     -you try to access different host
    It usually happens when I build a simple AngularJS app, and try to build routers onto it.
    A not-so-easy way to walk around, is basically to have a backend server. For example, a EasyPHP software would do the trick, it launches a apache server.
    
    • Make this work:
    duplicate([1,2,3,4,5]); // [1,2,3,4,5,1,2,3,4,5]
    function duplicate(arr){
      var size = arr.length;
      for (var i = 0; i < size; i++) {
        arr.push(arr[i])
      }
      return arr;
    }
    console.log(duplicate([1,2,3,4,5]));
    
    • Why is it called a Ternary expression, what does the word "Ternary" indicate?
    The conditional (ternary) operator is the only JavaScript operator that takes 3 operands. This operator is frequently used as a shortcut for the if statement.
    condition ? expr1 : expr2 
    
    • What is "use strict";? what are the advantages and disadvantages to using it?
     //'use strict' indicates the code should be executed in 'stric mode'. Well, to have a Java mom style. It converts mistakes into errors
    //Disadvantages:
    //More constraints. for example, can access 'this' in global scope. 
    //Cause confusion if some people from the team are originally in normal mode, but cannot adapt to strict mode, especailly when some features are built in strict mode, so it won't work as expected for guys in normal mode.
    //My opinion: I'd use strict mode, because it checks for potential mistakes like if I accidentally initialize a variable without definition. It causes issues. So I prefer to have error checkers. This way, JavaScript won't be able to kill you that easily.
    //Examples:
    "use strict";
    //JavaScript would fail if:
    //try to access 'this' in global scope, where 'this' is defined in a function
    //initialize a variable without define it:
    x = 3.14
    //try to delete a variable
    delete x;
    //duplicating parameter name:
    function x(p1, p1) {};  
    //using Octal numeric literals
    var x = 010;
    //reserved keywords:
    //eval, arguments
    // Assignment to a non-writable property
    var obj1 = {};
    Object.defineProperty(obj1, "x", { value: 42, writable: false });
    obj1.x = 9; // throws a TypeError
    // Assignment to a getter-only property
    var obj2 = { get x() { return 17; } };
    obj2.x = 5; // throws a TypeError
    // Assignment to a new property on a non-extensible object
    var fixed = {};
    Object.preventExtensions(fixed);
    fixed.newProp = "ohai"; // throws a TypeError
    //..
    
    • Create a for loop that iterates up to 100 while outputting "fizz" at multiples of 3, "buzz" at multiples of 5 and "fizzbuzz" at multiples of 3 and 5
    for (var i = 0; i <= 100; i++) {
      if (i % 3 == 0 && i % 5 == 0) {
        console.log(i + " fizzbuzz");
      } else if (i % 3 == 0) {
        console.log(i + " fizz");
      } else if (i % 5 == 0) {
        console.log(i + " buzz");
      }
    }
    
    • Why is it, in general, a good idea to leave the global scope of a website as-is and never touch it?
    global scope variable are generally bad in Javascript. Because you don't know where it appears, and where it's initialized, and where-else it's being used.
    With that said, since it's already broken, it's just safer to not touch it. Because once you change something on it, pieces of the project will break underneath.
    
    • Why would you use something like the load event? Does this event have disadvantages? Do you know any alternatives, and why would you use those?
    Sometimes we want to excute some funtion when window.load is ready.
    Disadvantange: it can be slow if there is lots contents on the page.
    Alternative: use document.ready(), which loads before images,css,javascript are loaded..
    Or, exute javascript function as expression whenever that script is running. (function(){...})();
    
    • Explain what a single page app is and how to make one SEO-friendly.
    Single page app is utilizing routing techniques : have one big container and many differnet sub views. 
    Like in angular, we use ui-view and ui-router to switch inner-views.
    1. Single page may have lots of 'server-can-understand' URLS that's not SEO-friend:
    http://example.com/app#this_is_not_a_real_url_for_this_purpose
    It's better to make it a real URL like:
    http://example.com/app/this_is_a_real_url_for_this_purpose
    2. You need to have the server generate the pages prefilled with the JSON on explicit request
    this is most easily acomplished using PhantomJS or similar.
    http://www.singlepageapplicationseo.com/
    
    • What is the extent of your experience with Promises and/or their polyfills?
    The Promise object is used for deferred and asynchronous computations. A Promise represents an operation that hasn't completed yet, but is expected in the future.
     Promise.prototype.then() and Promise.prototype.catch() 
    
    • What are the pros and cons of using Promises instead of callbacks?
    http://blog.parse.com/learn/engineering/whats-so-great-about-javascript-promises/
    cons of callback: easily to get nested.
    pro of promise: .then() and makes the structure a bit easier to read. helps the error handling.
    
    • What are some of the advantages/disadvantages of writing JavaScript code in a language that compiles to JavaScript?
    like coffee script. 
    some people say: less chars to type, easier to read,  don't need to worry about some missing "{"
    
    • What tools and techniques do you use debugging JavaScript code?
    At this moment, I don't have much experience with unit test tools, but I frequently using console.log() to debug.
    In my native JavaScript project, I build debug print() methods, similar to console.log() to debug.
    
    • What language constructions do you use for iterating over object properties and array items?
    //If it's just a regular array
    var arr = [9,2,3,4,5];
    for (var i = 0; i < arr.length; i++) {
      console.log(arr[i])
    }
    //If that's a javascript object, or still just a regular array, it's easy to use key:value structure:
    arr = {
      a: "aa",
      b: "bb",
      c: "cc"
    }
    for (var key in arr) {
      console.log(arr[key]);
    }
    
    • Explain the difference between mutable and immutable objects.
      • What is an example of an immutable object in JavaScript?
      • What are the pros and cons of immutability?
      • How can you achieve immutability in your own code?
    immutable: Javascript string, number. it always create a new instance then saved to a variable. Any operaetor on string won't change that string itself.
    mutable: array.
    Pro: prevent accidental changes to object.
    Cons: bad performance. It alaways createa new instance.
    achieve immutability in my code:
    Use 3rd party library like : immutable.js
    
    • Explain the difference between synchronous and asynchronous functions.
    They both talks about the case that: One action can only happen after last action is finished.
    synchronous: have to wait on it; cannot move on to other task before it finishes.
    asynchronous: can move on the other tasks. When the original action finishes, it will trigger the call back. Works like a promise. Typical example: http request and .then(function(){...}).
    We run multiple http request to different sources on a web page, and we won't ever wait for one http response before starting another. So it has to be asynchronous.
    
    • http example? Expand a bit on experience with it?
    //Most experience with Angular $http.
    It has a .then function on $http object, where the first function in .then() is success response, and the 2nd is the error response.
    Working as callback function, .then() catches server response and trigger corresponding functions.
    
    • What is event loop?
      • What is the difference between call stack and task queue?
    /*
    event loop:The browser has inner loop, called Event Loop, which checks the event queue and processes events, executes functions etc.
    Quite clear explanation:
    http://www.altitudelabs.com/blog/what-is-the-javascript-event-loop/
     -Javascript: single threaded
     -To excute every single line of javascript, Javascript engine uses call stack.
     -Call stack has blocking issue. So JavaScript engine uses asynchronous call back.
     -Now, we have 3 parties: call stack, event table, event queue.
     1.call stack: stores the regular function calls.
     2.When it's a callback function, register it in the Event Table.
     3.Event Table has a condition that will trigger to move the call back funtion. When it triggers (for example, a wait of 5 seconds), it'll move that callback function into Event Queue. Ready to go!
     4.Now, Event Loop comes to play. It checks the callstack. Only if callstack is empty(), it will poll() off the head of the Event Queue, and add it to callstack.
     5.Ofcourse the callstack will excute whatever that's next.
    So, in conclusion, Event Loop runs indefinitely and checks if call stack if empty(). If so, poll() items from queue and add into call stack.
    */
    

    Testing:

    • What are some advantages/disadvantages to testing your code?
    • What tools would you use to test your code's functionality?
    • What is the difference between a unit test and a functional/integration test?
    • What is the purpose of a code style linting tool?

    Performance:

    • What tools would you use to find a performance bug in your code?
    • What are some ways you may improve your website's scrolling performance?
    • Explain the difference between layout, painting and compositing.

    Network:

    • Traditionally, why has it been better to serve site assets from multiple domains?
    • Do your best to describe the process from the time you type in a website's URL to it finishing loading on your screen.
    • What are the differences between Long-Polling, Websockets and Server-Sent Events?
    • Explain the following request and response headers:
      • Diff. between Expires, Date, Age and If-Modified-...
      • Do Not Track
      • Cache-Control
      • Transfer-Encoding
      • ETag
      • X-Frame-Options
    • What are HTTP actions? List all HTTP actions that you know, and explain them.
    /*
    GET,HEAD,POST,PUT,DELETE,TRACE,OPTIONS,CONNECT,PATCH
    GET:request a representation of the specified resource. Only retrieve data. No other effects.
    HEAD:same as GET request for same info, but only get header, without response body. Useful to retrieve meta-data
    POST:request the server to accept the entity enclosed inthe request. Usually it populates the database, write some conents to the server storage.
    */
    

    Coding:

    Question: What is the value of foo?

    var foo = 10 + '20';
    //'1020' as a string
    

    Question: How would you make this work?

    add(2, 5); // 7
    add(2)(5); // 7
    /*
      Implement:
      If the function has 2 inputs, simply return x + y.
      Otherwise, return another funtion with a 2nd variable y. Then return x+y.
        This works because add(x,y) creates the closure with 'x' ready to use. Then calling the inner funtion with (y), both x, y will be ready.
    */
    function add(x, y){
      if (typeof y != "undefined") {
        return x + y;
      } else {
        return function(y) {
          return x + y;
        };
      }
    };
    
    console.log("add(10,20): " + add(10,20));
    console.log("add(10)(20): " + add(10)(20));
    
    

    Question: What value is returned from the following statement?

    "i'm a lasagna hog".split("").reverse().join("");
    
    //goh angasal a m'i
    /*
      'split("")' separate the string by "", which gives separate chars. Works like Java: str.toCharArray();
      Note: split(" ") will splity by empty space.
      reverse() reverses the array
      join("") merge the array, with "" empty string in between each item in the array.
      Note: join("|") will put a divider in between each array item while merging.
    */
    
    
    

    Question: What is the value of window.foo?

    ( window.foo || ( window.foo = "bar" ) );
    
    //"bar"
    /*
      1. That || first try to pick window.foo, however it's undefined, so it keeps on looking for the next attribute: ( window.foo = "bar" )
      2. ( window.foo = "bar" ) assigns that string 'bar' to window.foo, so window.foo is no longer undefined.
      3. then (window.foo) is assigned to variable/print out.
    
      Note: first attribute before || and the 2nd attribute after does not have logic relationship. We can exchange the 2nd attribute to (window.a = "test") and it will work the same
    
    */
    //test
    var rst = ( window.foo || ( window.foo = "bar" ) );
    console.log(rst);//bar
    
    

    Question: What is the outcome of the two alerts below?

    var foo = "Hello";
    (function() {
      var bar = " World";
      alert(foo + bar);
    })();
    alert(foo + bar);
    
    //alert: Hello World
    //Uncought ReferenceError: bar is not defined
    /*
      First, (function(){...})(); excutes whatever that in the '();'
        foot is in outter scope, it works inside of '();'
      Second, outside of '();', bar is not defined. So it throws the error.
    */
    
    

    Question: What is the value of foo.length?

    var foo = [];
    foo.push(1);
    foo.push(2);
    
    //2;
    

    Question: What is the value of foo.x?

    var foo = {n: 1};
    var bar = foo;
    foo.x = foo = {n: 2};
    
    //foo.x : undefined
    
    
    //line1:
    foo = {n:1}
    
    //line2:
    //bar becomes a copy of foo. 
    
    //line3:
    //foo.x is a reference, it's same a bar.x. For a quick side example:
    var foo = {n: 1};
    var bar = foo;
    
    foo.x = 2;
    console.log(bar); //{n:1, x:2}
    
    //What actaully happens:
    //on the right side, foo = {n:2} is excuted first.
    //foo.x is a reference, it's same as bar.x. Then this reference point is assigned with foo, which is just {n:2}. Then
    foo = {n:2}
    bar = {
      n : 2,
      x : {n : 2}
    }
    //So, ofcourse if we try to access foo.x, it will be undefined.
    
    //The given code works the same as below:
    var foo = {n: 1};
    var bar = foo;
    
    foo = {n: 2};
    bar.x = foo;
    
    
    

    Question: What does the following code print?

    console.log('one');
    setTimeout(function() {
      console.log('two');
    }, 0);
    console.log('three');
    
    //one, three, two
    //Regardless of what milliseconds we set to setTimeout() funtion, that function call
    //is always registered at end of the browser processes. It means it takes # of milliseconds 
    //to excute after all other regular tasks are done.
    
    

    Fun:

    • What's a cool project that you've recently worked on?
    • What are some things you like about the developer tools you use?
    • Do you have any pet projects? What kind?
    • What's your favorite feature of Internet Explorer?
    • How do you like your coffee?

    Angular:

    • basic setup in app.js
    //html:
    
    TEST APP
    
    
    
    
    {{test}}
    //app.js
    angular.module("testApp", [])
    .controller("MainCtrl", ['$scope', function($scope){
      $scope.test = "TEST Angular";
    }]);
    

你可能感兴趣的:(Front-end前端面试的种种)