Skip to content

Latest commit

 

History

History
298 lines (250 loc) · 12 KB

File metadata and controls

298 lines (250 loc) · 12 KB

#Front-end Job Interview Questions

This repo contains a number of front-end interview questions that can be used when vetting potential candidates. It is by no means recommended to use every single question here on the same candidate (that would take hours). Choosing a few items from this list should help you vet the intended skills you require.

Rebecca Murphey's Baseline For Front-End Developers is also a great resource to read up on before you head into an interview.

Note: Keep in mind that many of these questions are open ended and could lead to interesting discussions that tell you more about the person's capabilities than a straight answer would.

  1. Original Contributors
  2. General Questions
  3. HTML Questions
  4. CSS Questions
  5. JS Questions
  6. jQuery Questions
  7. Coding Questions
  8. Fun Questions

####Original Contributors:

The majority of the questions were plucked from an oksoclap thread created originally by Paul Irish (@paul_irish) and contributed to by the following individuals:

[⬆]

####General Questions:

  • What did you learn yesterday/this week?
  • Depends on person. Me: vertical align by line-height
  • What excites or interests you about coding?
  • Depends on person. Me: I like bring life to interfaces
  • Talk about your preferred development environment. (OS, Editor, Browsers, Tools etc.) Windows (because of IE), webstorm, chrome, terminal

  • Can you describe your workflow when you create a web page? Write html -> add css -> add JS Run web storm and chrome

  • Can you describe the difference between progressive enhancement and graceful degradation? progressive enhancement - from less functionality growing to full functional graceful degradation - made full functional and then made fallbacks

    • Bonus points for describing feature detection check is feture is exist, use fallback if not
  • Explain what "Semantic HTML" means. Html consist of only of information, all styling is on css

  • How would you optimize a websites assets/resources? Minimize Http calls, Use cdn, Set expires headers Use gzip Put css on top Put scripts on bottom Make Javascript and css external Minify Javascript and css avoid redirects reduce dom size dont scale images on client

  • Why is it better to serve site assets from multiple domains?

    • How many resources will a browser download from a given domain at a time? depends on browser 2 - 8
  • 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?

    • Suggest the project utilize something like EditorConfig (http://editorconfig.org)
    • Conform to the conventions (stay consistent)
    • issue :retab! command Me: change settings in my IDE
  • Write a simple slideshow page

    • Bonus points if it does not use JS.
  • What tools do you use to test your code's performance?

    • Profiler, JSPerf, Dromaeo Google dev tools
  • If you could master one technology this year, what would it be? Advanced algorithm's

  • Explain the importance of standards and standards bodies. Without standards you cant be sure that you code or design works as you expect to.

  • What is FOUC? How do you avoid FOUC? Flash of unstyled content. Put css in head. You can also made loader (but i did not like it)

[⬆]

####HTML Questions:

  • What's a doctype do?

It tells the browser which version of HTML (or XML) it needs to use while rendering the page.

  • What's the difference between standards mode and quirks mode?

"Quirks" mode is used for legacy browsers, while "standards" mode follows the W3C specification.

  • What are the limitations when serving XHTML pages? More strict that classic HTML, XHTML does not have good browser support.
    • Are there any problems with serving pages as application/xhtml+xml? IE 8 and older does not handle it
  • How do you serve a page with content in multiple languages? From html point of view use UTF. mostly server side problem.
    • What kind of things must you be wary of when design or developing for multilingual sites? right to left languages
  • What are data- attributes good for? Store custom data in Dom node
  • Consider HTML5 as an open web platform. What are the building blocks of HTML5? LocalStorage, video, data-*, canvas
  • Describe the difference between cookies, sessionStorage and localStorage. cookies only 4kb and send allways sessionStorage 5mb for session localstorege 5mb

[⬆]

####CSS Questions:

  • Describe what a "reset" CSS file does and how it's useful. set default's to main elements (like marhin, paddings, border to 0)

  • Describe Floats and how they work. Align element on right or left side, and text will flow around it

  • What are the various clearing techniques and which is appropriate for what context?

  • Explain CSS sprites, and how you would implement them on a page or site. Css sprite is set of small images stored in one image. background property will help you

  • What are your favourite image replacement techniques and which do you use when?

  • CSS property hacks, conditionally included .css files, or... something else?

  • How do you serve your pages for feature-constrained browsers?

    • What techniques/processes do you use?
  • What are the different ways to visually hide content (and make it available only for screen readers)? media queries

  • Have you ever used a grid system, and if so, what do you prefer? foundation

  • Have you used or implemented media queries or mobile specific layouts/CSS? Used

  • Any familiarity with styling SVG?

  • How do you optimize your webpages for print? media query

  • What are some of the "gotchas" for writing efficient CSS?

  • What are the advantages/disadvantages of using CSS preprocessors? (SASS, Compass, Stylus, LESS)

    • If so, describe what you like and dislike about the CSS preprocessors you have used.
  • How would you implement a web design comp that uses non-standard fonts?

    • Webfonts (font services like: Google Webfonts, Typekit etc.)
  • Explain how a browser determines what elements match a CSS selector?

  • Explain your understanding of the box model and how you would tell the browser in CSS to render your layout in different box models. box model it's how you calc size of box box-sizing can help you set different aproaches

[⬆]

####JS Questions:

  • Explain event delegation event delegation it's when parant recieve a event
  • Explain how this works in JavaScript depends on how it's call
  • Explain how prototypal inheritance works
  • How do you go about testing your JavaScript? QUnit Jasmine and bunch of staff
  • AMD vs. CommonJS?
  • What's a hashtable? datasctructure
  • Explain why the following doesn't work as an IIFE: function foo(){ }();.
    • What needs to be changed to properly make it an IIFE?
  • What's the difference between a variable that is: null, undefined or undeclared?
    • How would you go about checking for any of these states?
  • What is a closure, and how/why would you use one?
  • What's a typical use case for anonymous functions? callback
  • Explain the "JavaScript module pattern" and when you'd use it.
    • Bonus points for mentioning clean namespacing.
    • What if your modules are namespace-less?
  • How do you organize your code? (module pattern, classical inheritance?)
  • What's the difference between host objects and native objects?
  • Difference between:
function Person(){} var person = Person() var person = new Person()
  • What's the difference between .call and .apply?
  • explain Function.prototype.bind?
  • When do you optimize your code?
  • Can you explain how inheritance works in JavaScript?
  • When would you use document.write()?
    • Most generated ads still utilize document.write() although its use is frowned upon
  • What's the difference between feature detection, feature inference, and using the UA string
  • Explain AJAX in as much detail as possible
  • Explain how JSONP works (and how it's not really AJAX)
  • Have you ever used JavaScript templating?
    • If so, what libraries have you used? (Mustache.js, Handlebars etc.)
  • Explain "hoisting".
  • Describe event bubbling.
  • What's the difference between an "attribute" and a "property"?
  • Why is extending built in JavaScript objects not a good idea?
  • Why is extending built ins a good idea?
  • Difference between document load event and document ready event?
  • What is the difference between == and ===?
  • Explain how you would get a query string parameter from the browser window's URL.
  • Explain the same-origin policy with regards to JavaScript.
  • Describe inheritance patterns in JavaScript.
  • Make this work:
[1,2,3,4,5].duplicate(); // [1,2,3,4,5,1,2,3,4,5]
  • Describe a strategy for memoization (avoiding calculation repetition) in JavaScript.
  • Why is it called a Ternary expression, what does the word "Ternary" indicate?
  • What is the arity of a function?
  • What is "use strict";? what are the advantages and disadvantages to using it?

[⬆]

####jQuery Questions:

  • Explain "chaining".
  • Explain "deferreds".
  • What are some jQuery specific optimizations you can implement?
  • What does .end() do?
  • How, and why, would you namespace a bound event handler?
  • Name 4 different values you can pass to the jQuery method.
    • Selector (string), HTML (string), Callback (function), HTMLElement, object, array, element array, jQuery Object etc.
  • What is the effects (or fx) queue?
  • What is the difference between .get(), [], and .eq()?
  • What is the difference between .bind(), .live(), and .delegate()?
  • What is the difference between $ and $.fn? Or just what is $.fn.
  • Optimize this selector:
$(".foo div#bar:eq(0)")
  • Difference between 'delegate()' and 'live()'?

[⬆]

####Code Questions:

~~3.14

Question: What value is returned from the above statement? Answer: 3

"i'm a lasagna hog".split("").reverse().join("");

Question: What value is returned from the above statement? Answer: "goh angasal a m'i"

( window.foo || ( window.foo = "bar" ) );

Question: What is the value of window.foo? Answer: "bar" only if window.foo was falsey otherwise it will retain its value.

var foo = "Hello"; (function() { var bar = " World"; alert(foo + bar); })(); alert(foo + bar);

Question: What is the outcome of the two alerts above? Answer: "Hello World" & ReferenceError: bar is not defined

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

Question: What is the value of foo.length? **Answer: 2

var foo = {};
foo.bar = 'hello';

Question: What is the value of foo.length? **Answer: undefined

[⬆]

####Fun Questions:

  • What's the coolest thing you've ever coded, what are you most proud of?
  • What are your favorite parts about the developer tools you use?
  • Do you have any pet projects? What kind?
  • What's your favorite feature of Internet Explorer?

[⬆]