We've spent over 20 years working with JavaScript. We've done everything from animations to single page web apps. We've worked through the `document.write` days and lived to tell the tale.
Making web-banners that would display a random banner on each page load was how Toby cut his teeth in JS. Followed by serious work in jQuery and now more mature frameworks like Meteor, Backbone, Ember and React.
We write performant, production ready JavaScript that doesn't compromise on performance and doesn't try and do too much.
Hopefully you enjoy what JavaScript writings we have to share.
If you have any suggestions for things we should write about please do get in contact, or perhaps you would like to work with us?
data:image/s3,"s3://crabby-images/e9098/e90987745e41121cc06f280601e84bc26b53c0fb" alt="Adding a service worker to Jekyll"
Adding a service worker to Jekyll
Here is how we added a service worker to this very site
data:image/s3,"s3://crabby-images/f4670/f467070cb50f13e4c9b6ab1d6c8dfd55c02b53d6" alt="Calculating Instagram Velocity From Your Browser"
Calculating Instagram Velocity From Your Browser
A small script that lets you quickly work out the velocity for posts within a hashtag
data:image/s3,"s3://crabby-images/a6e04/a6e044653a194c446bde9797bd3be5001dba6e46" alt="Getting photo orientation data with JavaScript"
Getting photo orientation data with JavaScript
How we can use exif-js to get image orientation information
data:image/s3,"s3://crabby-images/2383b/2383b033c9c175ed8b84b4ad2bc2990d96068649" alt="FrontEnders - Web Performance"
FrontEnders - Web Performance
Sharing some of my thoughts on a FrontEnders meetup on the topic of Web Performance
data:image/s3,"s3://crabby-images/8cf81/8cf8122717ffa27cf058822d8e681df8161de1f4" alt="Creating a download button for Wistia videos"
Creating a download button for Wistia videos
Here is how you can quickly add an external download button for Wistia videos
data:image/s3,"s3://crabby-images/bc469/bc46945ae94bce99855680043a8efd3eeb5368a8" alt="Some stats from frontend focus"
Some stats from frontend focus
I wanted to play with some array manipulations in JavaScript to compiled some interesting stats
data:image/s3,"s3://crabby-images/25d36/25d365df972891f708851c2254a780c3588eed3b" alt="Removing Kadira from Meteor"
Removing Kadira from Meteor
How to remove Kadira from your Meteor Project (since it is going away)
data:image/s3,"s3://crabby-images/0c3d1/0c3d176b48274b4aaa7b7b0c4c302b0fa085bebb" alt="Meteor @dev was not detected"
Meteor @dev was not detected
Why do you see @dev was not detected in test output when running cucumber tests for Meteor
data:image/s3,"s3://crabby-images/0c3d1/0c3d176b48274b4aaa7b7b0c4c302b0fa085bebb" alt="Key code for Command on OS X"
Key code for Command on OS X
There are a couple of key codes for the OS X Command Key
data:image/s3,"s3://crabby-images/0c3d1/0c3d176b48274b4aaa7b7b0c4c302b0fa085bebb" alt="An experiment in highlighting words"
An experiment in highlighting words
An experiment in highlighting words using only some CSS and JavaScript
data:image/s3,"s3://crabby-images/0c3d1/0c3d176b48274b4aaa7b7b0c4c302b0fa085bebb" alt="Creating an iOS application in 5 minutes using Meteor"
Creating an iOS application in 5 minutes using Meteor
How you can quickly and easily create an iOS app using Meteor
data:image/s3,"s3://crabby-images/0c3d1/0c3d176b48274b4aaa7b7b0c4c302b0fa085bebb" alt="CSS last-of-type as a fix for last-child in Ember applications"
CSS last-of-type as a fix for last-child in Ember applications
A fix for last-child with CSS in Ember applications and others
data:image/s3,"s3://crabby-images/0c3d1/0c3d176b48274b4aaa7b7b0c4c302b0fa085bebb" alt="Making an app in just over an hour with Meteor and Heroku"
Making an app in just over an hour with Meteor and Heroku
Here's how you can quickly get an app together with these tools
data:image/s3,"s3://crabby-images/0c3d1/0c3d176b48274b4aaa7b7b0c4c302b0fa085bebb" alt="Please stop using features by testing for browser"
Please stop using features by testing for browser
An issue that I encountered and why it shouldn't have been
data:image/s3,"s3://crabby-images/0c3d1/0c3d176b48274b4aaa7b7b0c4c302b0fa085bebb" alt="Using Ember's App.reset() to kill off any local data"
Using Ember's App.reset() to kill off any local data
How I resolved an issue with data persisting on the front end
data:image/s3,"s3://crabby-images/0c3d1/0c3d176b48274b4aaa7b7b0c4c302b0fa085bebb" alt="What App.reset() does in Ember"
What App.reset() does in Ember
An in-depth line by line look at what App.reset() does in Ember
data:image/s3,"s3://crabby-images/0c3d1/0c3d176b48274b4aaa7b7b0c4c302b0fa085bebb" alt="Disable a button component with Ember"
Disable a button component with Ember
How to enable or disable a button in realtime using Ember
data:image/s3,"s3://crabby-images/0c3d1/0c3d176b48274b4aaa7b7b0c4c302b0fa085bebb" alt="Accessing Popover Data with Bootstrap 3"
Accessing Popover Data with Bootstrap 3
How I solved this issue with access popover data with Bootstrap 3
data:image/s3,"s3://crabby-images/0c3d1/0c3d176b48274b4aaa7b7b0c4c302b0fa085bebb" alt="Upgrading from Bootstrap's Typeahead to Typeahead.js"
Upgrading from Bootstrap's Typeahead to Typeahead.js
A guide for swapping from Bootstrap Typeahead to Typeahead.js
data:image/s3,"s3://crabby-images/0c3d1/0c3d176b48274b4aaa7b7b0c4c302b0fa085bebb" alt="A fix for window.location.origin in Internet Explorer"
A fix for window.location.origin in Internet Explorer
A straightforward fix for this issue in Internet Explorer
data:image/s3,"s3://crabby-images/0c3d1/0c3d176b48274b4aaa7b7b0c4c302b0fa085bebb" alt="Transliteration with Typeahead.js"
Transliteration with Typeahead.js
How to deal with special characters when using typeahead.js
data:image/s3,"s3://crabby-images/0c3d1/0c3d176b48274b4aaa7b7b0c4c302b0fa085bebb" alt="Typeahead.js The Book!"
Typeahead.js The Book!
I wrote a book about typeahead.js, here's an overview of it
data:image/s3,"s3://crabby-images/0c3d1/0c3d176b48274b4aaa7b7b0c4c302b0fa085bebb" alt="Setting a minimum length for your search in Typeahead.js"
Setting a minimum length for your search in Typeahead.js
How you can set a minimum length for your search in Typeahead.js
data:image/s3,"s3://crabby-images/0c3d1/0c3d176b48274b4aaa7b7b0c4c302b0fa085bebb" alt="Refreshing local data with typeahead.js"
Refreshing local data with typeahead.js
Here's the three step process to follow to refresh local data with typeahead.js
data:image/s3,"s3://crabby-images/0c3d1/0c3d176b48274b4aaa7b7b0c4c302b0fa085bebb" alt="Using Loops in Jasmine"
Using Loops in Jasmine
How to call tests numerous times when testing with Jasmine
data:image/s3,"s3://crabby-images/0c3d1/0c3d176b48274b4aaa7b7b0c4c302b0fa085bebb" alt="Using Bootstrap's typeahead from inside a modal window"
Using Bootstrap's typeahead from inside a modal window
How you can go about using Bootstrap's typeahead in a modal window
data:image/s3,"s3://crabby-images/0c3d1/0c3d176b48274b4aaa7b7b0c4c302b0fa085bebb" alt="Insert Gists without JavaScript"
Insert Gists without JavaScript
How to insert GitHub Gists into your blog posts without JavaScript
data:image/s3,"s3://crabby-images/a5766/a576633083bc2be109529d1ff9a96b285de10b44" alt="Replacing Social Media Buttons with non-JS counterparts"
Replacing Social Media Buttons with non-JS counterparts
How to avoid using JavaScript when adding social media sharing buttons
data:image/s3,"s3://crabby-images/0c3d1/0c3d176b48274b4aaa7b7b0c4c302b0fa085bebb" alt="What Meteor does when you install it"
What Meteor does when you install it
A quick overview of what Meteor does when you install it
data:image/s3,"s3://crabby-images/0c3d1/0c3d176b48274b4aaa7b7b0c4c302b0fa085bebb" alt="Accessing PHP variables from within JavaScript under WordPress"
Accessing PHP variables from within JavaScript under WordPress
How you can access PHP variables in JavaScript in WordPress
data:image/s3,"s3://crabby-images/bce55/bce55e54d4d4823030c55e4cf90befde4453cd14" alt="JavaScript KeyCodes"
JavaScript KeyCodes
Some JavaScript KeyCodes that I find useful to have around