JavaScript Basic Concept
24 Jul 2017 | Front-end JavaScript0. Webpage
-
Mostly used framework to implement responsive page layout: Bootstrap, now we have Bootstrap4
-
Html5: specify the doc type. HTML become HTML5: Put this on the top of html file
<!DOCTYPE html>
- input element can have many attributions:
- type, includes: date, email, password etc and text by default
- id of tag, unique identifier
- value
- name
- title
- any custom attributions like location, organization
- Local storage, Cookie session storage
- Cookie: all browser information in client side
- Local storage and session storage. session-temp; local-permanent
- CSS file reference should be on the top of page, javascript can be at bottom. better user experience, may need more loading time,
- Dynamic page, we need js
- JavaScript: Loosely-typed language: assign data type automatically
1. Object
- Objects are containers for named value.
- Object definition
- Most simplest way:
var user = {“name”:xy", “age”:18};
- Using new keyword:
var user = new Object(); user.name = "xy";
-
Using object constructor:
function user(name, age, phone) { this.name = name; ... } var user1 = new user("xy",...);
- Notice here: If you try to call the user() without the new keyword. It returns undefined, because the user() is not returning anything, previously it was the new keywords which was returning you the object.
- Most simplest way:
- Objects are addressed by reference.
- See an example:
var user = {“name”: “xy”, “age”:18}; var user1 = user;
User1 is not a copy of user, it is the user itself, so any changes to user1 will reflect user.
- See an example:
- Object Properties
2. Object Properties
var name = user.name;
var name = user[“name”]
for (key in user) { alert(key + “ ”+ user[key]); }
- Add prop:
var userObj = { "username":"xy"; "place":"nj"; }; userObj.addr = "Chi"; for(key in userObj){ //output document.write(userObj[key]); } document.write(userObj.place);
delete user.name;
//remove name property from user object- functions as prop:
var user = { “firstname” : “xx”, “lastname” : "yy", “fullname” : function () { return this.firstname + “ “+this.lastname; } } user.fullname();
3. functions
- Create function
function display(username="xy", place="nj"){ return username+','+place; } document.write(display()); document.write(display("xy1","ny"));
function abc(){ var username = "xy", place = "nj"; var display = function(){ return username +","+ place; } return display; } document.write(abc()()); //or var fn = abc(); document.write(fn());
- anonymous function
function(){ return 'anonymous function'; }
var fn = function(){ return 'anonymous function'; } document.write(fn()); //output anonymous function document.write(fn); //output all function body //anonymous function Can be passed as parameter to another function function display(fnName){ return fnName; } document.write(display(fn())); //output anonymous function
- Self invoking function
(fn = function(){ return 'anonymous function'; })();
4. Prototype
- Every JavaScript function has a prototype property
- Primarily for inheritance
- Methods and properties added to function’s prototype property will be available to all instances of that function
- An example:
var user = new Object();
user Inherit from the Object.prototype. - Adding new properties to existing prototype:
user.prototype.fullname = function() { return this.firstname + “,“+this.lastname};
-
We want define arr.display();
var arr = ['ar',"br","cr"]; Array.prototype.display = function(){ //display array console.log(this); return this.concat(this); } arr.display(); console.log(arr.display()); //display arr twice in a array: ["ar", "br", "cr", "ar", "br", "cr"]
5. Math
- Math.min()/Math.max()
- Math.round(4.5) //output:5, round to the nearest integer value
- Math.ceil(); //round up
- Math.floor() //round down
6. Array
- Arrays are also special type of objects, Arrays uses numbered indexes and object uses named indexes
- arr.length
- arr[arr.length]=”aa”;
- array.push(‘99’); //add the element at the end of the array
- array.pop(); //remove the last element
- arr.shift() //remove the first element of an array
- delete arr[1];
- arr.splice(arr.indexOf(“aElement”));
- array.splice(2,1); //remove a particular element, eg: from index 2, remove 1 element
- array.indexOf(2); // find the index of given element value
- array.indexOf(2,4);//start from 4
7. String
- Can use single / double quotes to enclose the string.
- str.length
- escape the string, eg:
var username = “argopan\”kumar”;
str.indexOf("oneElement");
test_str.match(“ar”)
//Used to find an occurrence of a substring in a string.- Both indexOf and match are case sensitive
str.toUpperCase(); /str.toLowerCase();
str.replace(new RegExp(',', 'g'), '');
,str.replace(‘username’, 'ar);
str.substring(0,5);
8. Date
var date_str = new Date();
//Created using new Date();date_str.getFullYear();
// return current yeardate_str.setFullYear(2010)
// set yeardate_str.getDay();
// return current daydata_str.setDate(10);
date_str.setDate(date_str.getDate() + 2);
//Adding 2 days to the current daydate_str.setFullYear(date_str.getFullYear() + 2);
//Adding 2 years to the current year
9. HTML DOM(document object model)
- getElementById, document.getElementsByTagName, getElementsByClassName
- Changing content: .innerHTML
- Changing Attributes: .className
- Changing Style: .style
- Event binding: onclick
- EventListeners:
document.getElementById("‘my_div’").addEventListener(“click”, test_fn);
,removeEventListener(“click”, test_fn);
window.onload = function(){...}
make sure to load DOM element first- Popup boxes: alert, confirm box, prompt box
10. Timeout/Interval
- timeout, interval
setTimeout(function(){ document.write('hello'); },1000);
setInterval(function(){ document.write('hello'); },1000);
var interval_var = setInterval(function(){ document.write('hello'); },1000); setTimeout(function(){ clearInterval(interval_var); },5000);
11. Arguments
- arguments,
function(){
//return:["ar", "br", "cr", callee: ƒ, Symbol(Symbol.iterator): ƒ]
console.log(arguments);
//return a slice: ["ar", "br", "cr"]
console.log(Array.prototype.slice.call(arguments));
}
abc('ar',"br","cr");
12. promise
doc here, very helpful.
-
let promise = doSomething(); promise.then(successCallback, failureCallback); //or doSomething().then(successCallback failureCallback);
-
doSomething() .then(result => doSomethingElse(result)) .then(newResult => doThirdThing(newResult)) .then(finalResult => { console.log(`Got the final result: ${finalResult}`); }) .catch(failureCallback);
-
let myFirstPromise = new Promise((resolve, reject) => { setTimeout(function(){ resolve("Success!"); // Yay! Everything went well! }, 250); }); myFirstPromise.then((successMessage) => { console.log("Yay! " + successMessage); }, failureCallback);
-
function abc(){ var promise = new Promise(function(resolve,reject){ setTimeout(function(){ resolve('display'); //reject(some http err, maybe) },3000); }); return promise; } var resp = abc(); //first func handles resolve, second handles reject resp.then(function(data){ console.log("data,"+data); }, function(err){ console.log(err); })
- promise
var fn = function(){ setTimeout(function(){ return 'called'; },3000); }; var resp = fn(); document.write(resp); //output: undefined
var fn = function(){ var promise = new Promise(function(resolve,reject){ setTimeout(function(){ //resolve('called'); reject('err'); },3000); }); return promise; }; var resp = fn(); document.write(resp); resp.then(function(data){ document.write(data); }, function(err){ document.write(err); });
13. closure: inner function can access outer function variable.
//before:
var fn = function(){
var cntr = 0;
var inc = function(){
cntr++;
return cntr;
};
return inc();
};
var resp = fn();
document.write(resp+'<br/ >');
document.write(resp+'<br/ >');
document.write(resp+'<br/ >');
//output:1,1,1
//after
var fn = function(){
var cntr = 0;
var inc = function(){
cntr++;
return cntr;
};
return inc;
};
var resp = fn();
document.write(resp()+'<br/ >');
document.write(resp()+'<br/ >');
document.write(resp()+'<br/ >');
//output: 1,2,3
//return more than one func
var fn = function(){
var cntr = 0;
var inc = function(){
cntr++;
return cntr;
};
var reset = function(){
return cntr=0;
};
return {
'inc':inc,
'reset':reset
};
};
var resp = fn();
document.write(resp.inc()+'<br/ >');
document.write(resp.inc()+'<br/ >');
document.write(resp.inc()+'<br/ >');
//a funny example
function abc(a){
return function(b){
console.log("a+b",a+b);
return function(c){
console.log("all:",a,b,c);
return a+b+c;
}
}
}
console.log("final:",abc(2)(3)(4));
14. js operate html
- dom props
//js manipulate dom, js should load after html, at the buttom of html //or use this onload function in the top of js file to make sure the js code is executed window.onload = function(){ var elem = document.getElementById('div'); elem.innerHTML = 'div3'; var elems = document.getElementsByTagName('div'); elems[0].innerHTML = 'div1'; //retrieve custom attribute using query selector var elem4 = document.querySelector('div[username="4"]'); elem4.innerHTML = '4~'; }
-
js event handling
window.onload = function(){ document.getElementById('btn').onclick = function(){ alert('hi'); }; }
//change div content using input text window.onload = function(){ document.getElementById('btn').onclick = function(){ alert('hi'); var content = document.getElementById("txtbx").value; document.getElementById('div').innerHTML = content; }; };
- insertAdjacentHTML:
- ‘beforebegin’: Before the element itself.
- ‘afterbegin’: Just inside the element, before its first child.
- ‘beforeend’: Just inside the element, after its last child.
- ‘afterend’: After the element itself.
window.onload = function(){ document.getElementById('btn').onclick = function(){ var newContent = '<h2>hi</h2>'; //beforebegin //afterbegin //beforeend end of the element content //afterend document.getElementById('div').insertAdjacentHTML('beforeend',newContent); }; };
-
event listener
//two kinds: element listener, event listener window.onload = function(){ document.getElementById('btn').addEventListener('click',function(){ alert('hi'); }); };
window.onload = function(){ function eventFn(){ alert('hi'); } document.getElementById('btn').addEventListener('click',eventFn); document.getElementById('btn2').addEventListener('click',function(){ document.getElementById('btn').removeEventListener('click',eventFn); }); }; //click: alert, remove->click: no alert
A practice - shift input to output box and keep the order
-
script.js
window.onload = function(){ var interval_var ; function shift(direction,time){ var leftElem = document.getElementById("input"); var rightElem = document.getElementById("output"); window.clearInterval(interval_var); interval_var = setInterval(function(){ var leftStr = leftElem.value; var rightStr = rightElem.value; console.log(leftStr); if(direction == "toRight") { rightElem.value = leftStr.substring(leftStr.length-1,leftStr.length)+rightStr; leftElem.value = leftStr.substring(0,leftStr.length-1); console.log("right",rightElem.value); if(leftElem.value.length===0){ clearInterval(interval_var); } } if(direction == "toLeft") { rightElem.value = rightStr.substring(1,rightStr.length); leftElem.value = leftStr+rightStr.substring(0,1) ; console.log("left",leftElem.value); if(rightElem.value.length===0){ clearInterval(interval_var); } } },time); } document.getElementById("btn1").addEventListener('click',function(){ shift("toRight",1000); }); document.getElementById("btn3").addEventListener('click',function(){ shift("toLeft",1000); }); document.getElementById("btn2").addEventListener('click',function(){ clearInterval(interval_var); }); };
- html:
<body> <h1>Hello Plunker!</h1> <div id = "div"> shift </div> <br/> <input type="text" id = "input" value = "default"/> <input type="text" id = "output"/><br/> <input type="button" id="btn1" value=">>" /> <input type="button" id="btn2" value="||" /> <input type="button" id="btn3" value="<<" /> </body>
- html:
Comments