Donald in Mathmagic Land Wolfson
###JavaScript and jQuery Exercises:
- Reading forms – Simple jQuery way to read/use input.
- Manipulating the DOM.
#(______) - produces a jQuery object (where the item in the parentheses is a selector).
This returns an object, which is an element plus extra methods and properties.
The beauty of jQuery – It understands HTML and CSS selectors.
Types of selectors:
- Universal selector (*)
- Elements
- Class
- IDs
- Descendent – #container .box
- Child – #container > .box
- General sibling – #container ~ .box
- Adjacent sibling – #container + .box
- Attribute – input[type=”text”] (VERY POWERFUL)
- Psuedo-classes – a:hover
- Pseudo-elements – .container:before
(Prefer to use single quotes for selectors.)
Once an object has been returned, it can then be operated on by a method:
$(____).click();
Method-chaining
$( ).parent.( ).click( )
.addClass() method takes parapeter of selector element, adds a class that changes the appearance of the element:
$('p').addClass("myClass);
.selected - Class can be semantic.
When you change the DOM, the browser wakes up and bubbles through HTML and changes just the affected elements.
Hoisting - Whenever JavaScript runs into a function declaration, it lifts it to the top of the current script of function.
Methods return an object, which is passed along – Traversal
You don’t really need traversal, could just use IDs and classes, but this is neater.
The big three things you do:
- SELECT.
- TRAVERSAL.
- MANIPULATION.
event.preventDefault();
Buttons were designed around 1995, when forms were a hot new deal. The default behavior sends off information and refreshes the page. Because of backward compatibility, can’t eliminate that behavior, but you can overrule it.
###JavaScript/jQuery Interaction Assignment
Assignment is here.
One attempt at a solution is here.
Flash of highlight is not gratuitous: calls attention to what has changed on the page.
Things that are not ncessarily required, but may use.
Why is the script element at the bottom of the body element? So that the page is fully loaded BEFORE the JavaScript starts to run. To make extra sure that the script won’t run early, can put this at the start of the JavaScript:
$(document).ready(function() {} );
Sometimes, designers will give you CSS for two different states of an element on the page.
/*Interactive styles*/
.complete {
text-decoration: line-through;
color: gray;
}
.toggle(); - Hides/reveals an element without messing with the CSS.
People are trying to make actions on screen reflect the physicality of the real world, so that it feels as though we can use physical intuition. (If tool tips come up too soon or too fast, users feel stupid; if they come up too late/slow, users get bored.)
this refers to what was just selected. Can manipulate this, OR something related to this (e.g. parent, child).
Start to understand the structure of script.
$ - Variable name. By convention, some people start variables that contain a jQuery object with a $.
Characteristif of jQuery that a lot of methods do two different things depending on their situation.
“Tainted input” – Places where code can be input into a page via a form. Big security risk! Can strip out any HTML elements to avoid code.
Google Analytics - How do you know that your idea works? Need data!
MailChimp - Free, can link to Google analystics and use as a destination for forms.
Other tools:
slides.com - For presentations.
Evernote - Can search through handwritten notes.
Never feel victimized by complicated technology!