This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
{ | |
"listing": { | |
"features": { | |
"bedrooms": { | |
"value": 3 | |
} | |
} | |
} | |
} |
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
const events = [ 'domLoading', 'domInteractive', 'domContentLoadedEventEnd', 'domComplete', 'loadEventEnd' ]; | |
const startEvent = 'navigationStart'; | |
const timing = performance.timing; | |
const compose = (f, g) => x => f(g(x)); | |
const timeFromNavigationStart = event => differenceInSeconds(timing[event], timing[startEvent]); | |
const differenceInSeconds = (t1, t2) => (t1 - t2) / 1000; | |
const sanitizeTime = t => (t > 0) ? t : 'N/A - Has not fired yet - please run console log again'; |
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
const createEventHandlers = (el = document, eventName, handler) => ({ | |
add: () => { el.addEventListener(eventName, handler); }, | |
remove: () => { el.removeEventListener(eventName, handler); } | |
}); | |
/* | |
* In component | |
*/ |
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
/* Modal */ | |
<div className="modal"> | |
<CloseButton /> | |
</div> | |
/* CloseButton */ | |
<button className="close-button">Close</button> |
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
/* Start with building the component */ | |
import React from 'react'; | |
class Value extends React.Component { | |
constructor(props) { | |
super(props); | |
this.state = { isActive: false }; | |
this.onToggle = this.onToggle.bind(this); | |
} | |
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
/* | |
* Backbone view | |
*/ | |
var View = Backbone.View.extend({ | |
modifyDOM: function() { | |
this.$el.html(this.template(obj)); | |
}, | |
render: function() { | |
this.$el.html(this.template(obj)); |
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
// https://github.com/getify/You-Dont-Know-JS/blob/master/this%20%26%20object%20prototypes/ch2.md | |
/* | |
* Called with new? Use the newly constructed object | |
*/ | |
class Pokemon { | |
constructor(hp, mp) { | |
this.hp = hp; | |
this.mp = mp; | |
} | |
} |
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
button.addEventListener('click', function(e) { | |
// Something | |
}.bind(this)); | |
button.addEventListener('click', e => { | |
// Something | |
}); | |
class ViewModel { | |
constructor(prop1, prop2) { |
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
/* | |
* Comparing arrow functions' lexical this binding to ordinary functions | |
*/ | |
function Dog() { | |
// The arrow function binds this to the new Dog instance | |
// It is the same as writing it as | |
// const doSomething = function() { this.bark(); }.bind(this); | |
const doSomething = () => { this.bark() }; | |
doSomething(); | |
} |
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
import React, { Component, PropTypes } from 'react'; | |
export default class Toggle extends Component { | |
constructor(props) { | |
super(props); | |
this.state = { isActive: false }; | |
this.onToggle = this.onToggle.bind(this); | |
} | |
render() { |