Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/ericrallen/vanilla

Basic jQuery-like JavaScript library created for a series of workshops
https://github.com/ericrallen/vanilla

Last synced: about 1 month ago
JSON representation

Basic jQuery-like JavaScript library created for a series of workshops

Awesome Lists containing this project

README

        

# Vanilla v1.1.1

**Note**: Want to [skip to the Workshop Notes](#workshop-notes)?

Vanilla is a jQuery-like library created for a series of Front-End workshops revolving around JavaScript.

We'll be using it as a way to explain what jQuery is doing under the covers and learn a bit more about how JavaScript works and also to explore es2015 and some of the improvements it brings to writing JavaScript.

This fairly close to final version of the library contains some potential improvements to the way that jQuery handles some of the methods we recreate and some small quality-of-life updates that make the library easy to work with as a developer.

As the Workshop series progresses, we'll be expanding Vanilla out to explore concepts from other frameworks, libraries, etc.

## Concepts We Will Cover in the Workshops

In the workshops we will be coverig a wide array of JavaScript topics with some information that developers of almost every level will find useful. Some slides are geared more towards those less familiar with JavaScript, while others are geared towards those who are very familiar with it but might not know about how it handles some specific method or situation.

We'll be doing our best to make sure that there is something in this for everyone.

**Random assortment of topics that are covered or will *very likely* be covered**:

- Fluent Interface Pattern
- Command Query Separation
- DRY
- Prototypal Inheritance
- `arguments` Object
- Rest Parameters and Spread Operator
- `className` and `classList`
- Array-like Objects
- Enumerable properties
- `.querySelectorAll()`
- Array methods: `split()`, `join()`, `concat()`,`indexOf()`, `.forEach()`, `.every()`, `.some()`
- various methods of iteration (and when certain methods are better than others):
- `for()`
- `for..in()`
- `while()`
- es2015 and transpiling with `babel`
- task automation with `gulp`
- How/Why jQuery does certain things:
- How does method chaining work? (see: Fluent Interface Pattern)
- How does plugin extension work? (see: Prototypal Inheritance)
- Why the `$`?
- What is `$.fn` and why do plugins use it?
- How can plugins override other jQuery methods?
- Mutability
- Recursion

**Random assortment of topics that *might* be covered in future Workshops**:

- `{{ something }}` style template tags
- Two way data binding
- Design/Module patterns
- Creating bower/npm packages

## What Vanilla Does Not Do

Vanilla does not recreate the vast majority of the methods found in jQuery and is not meant to be a replacement as much as a learning exercise.

Vanilla also does not:

- Create a facade over browser inconsistencies
- Integrate polyfills for some missing functionality
- Use a robust selector engine
- Deal with `document`/`window` states like `ready` and `load`
- Deal with event binding and triggering (though this may change in the future)

## What Vanilla Does Do

Vanilla currently recreates the following jQuery methods in an es5 JavaScript file that can be included in a project or an es2015 module that can be imported into any es2015 modules:

- `hasClass()`
- `toggleClass()`
- `addClass()`
- `removeClass()`
- `attr()`
- `data()`
- `extend()`
- `find()`

## Helpful Resources

- jQuery Source Viewer: [http://james.padolsey.com/jquery/](http://james.padolsey.com/jquery/)


## Workshop Notes

#### Table of Contents

1. [Workshop[0]: Classy jQuery](#workshop-0)
1. [Workshop[1]: Objectifying Truthiness](#workshop-1)


### Workshop[0]: Classy jQuery

The first in our series of workshops is an introduction to the basics of how jQuery is designed and how we can recreate that design on our own.

We also delve into jQuery's class convenience methods and recreate them for ourselves.

**Presentation**: [https://slides.com/allenericr/workshop-0-classy-jquery/](https://slides.com/allenericr/workshop-0-classy-jquery/)

**Branch**: `workshop/0`

**Topics**:

- [x] Fluent Interface Pattern (*method chaining*)
- [x] DRY
- [x] Function `arguments`
- [x] Prototypal Inheritance
- [x] Element Node `className` and `classList`
- [x] Array-like Objects
- [x] `document.querySelectorAll()`
- [x] `Array.prototype.split()`, `Array.prototype.join()`, `Array.prototype.indexOf()`, `Array.prototype.forEach()`
- [x] `for()` loops
- [x] `Function.prototype.call()`
- [x] Why `$`?
- [x] Why `$.fn`?
- [x] `jQuery.fn.hasClass()`, `jQuery.fn.addClass()`, `jQuery.fn.toggleClass()`, `jQuery.fn.removeClass()`
- [x] Object Literal


### Workshop[1]: Objectifying Truthiness

The second in our series of workshops is an introduction to the how jQuery deals with attributes, extends objects, and why you should be using `.find()`.

It builds off of knowledge gained in [Workshop[0]](#workshop-0), but does not directly require anything from it.

**Presentation**: [https://slides.com/allenericr/workshop-1-objectifying-truthiness](https://slides.com/allenericr/workshop-1-objectifying-truthiness)

**Branch**: `workshop/1`

**Topics**:

- [x] Command Query Separation
- [x] Boolean Attributes
- [x] Object Property Options
- [x] Shallow vs Deep Merge/Copy
- [x] Mutation
- [x] `Array.prototype.shift()`, `Array.prototype.concat()`
- [x] Why `$.extend`?
- [x] `jQuery.extend()`, `jQuery.fn.attr()`, `jQuery.fn.prop()`, `jQuery.fn.data()`, `jQuery.fn.find()`
- [x] Difference between `jQuery.fn.extend()` and `jQuery.extend()`?
- [x] Ternary Operators
- [x] Recursion
- [x] `for...in()` loops
- [x] `Object.prototype.hasOwnProperty()`, `Object.prototype.keys()`
- [x] Why use `.find()`?
- [x] Truthy and Falsey
- [x] Type Coercion
- [x] `==` vs `===`