Derek
共用平台課 前端工程師
F2E TW 掃地工
大C專案前端架構規劃
&
共用模組開發
Worldwide Browser Usage
所以接下來的課程會跳過IE情境
產品如果有用到
還是要乖乖去GOOGLE
CAN I USE 神站不解釋
一張圖秒懂
你會知道哪些事情可以做
Browser, Headless Browser, or Runtime | JavaScript Engine |
---|---|
Mozilla | Spidermonkey |
Chrome | V8 |
Safari | JavaScriptCore |
IE and Edge | Chakra |
PhantomJS | JavaScriptCore |
HTMLUnit | Rhino |
TrifleJS | V8 |
Node.js | V8 |
Io.js* | V8 |
跟車子相關的請找Rex 大大
決定你如何最佳化你的 Javascript
markup
HTML element
with attr
<!DOCTYPE html>
<html lang="zh-TW">
<head>
<meta charset="utf-8">
<title>My test page</title>
</head>
<body>
<p>This is my page</p>
</body>
</html>
不夠?來看Real World吧
靈活運用html tags 可以事半功倍
<div>, <h1...h6>, <span>...
<header>, <article>, <content>...
<media>, <audio>, <img>...
Document Object Model
其實就真的把它想成是一個個Object
Text
擁有『繼承』的屬性
以及HTML上自定義的屬性
<!DOCTYPE html>
<html>
<head>
<title>Web page parsing</title>
</head>
<body>
<div>
<h1>Web page parsing</h1>
<p>This is an example Web page.</p>
</div>
</body>
</html>
每個節點就是一個DOM element
Document Fragment 是不同的東西
學React 必需得懂的概念
EventTarget.addEventListener()
於 EventTarget 物件上註冊指定事件的監聽器。
EventTarget.removeEventListener()
移除 EventTarget 物件上的指定事件監聽器。
對此 EventTarget 物件派送(dispatch)一個事件物件,也就是於此 EventTarget 物件上觸發一個指定的事件物件實體。
至少先去把繼承鍊練習個30遍
DOM + CSS
CSS + DOM
一個查找匹配的過程
請看另外一張投影片
var eventUtils={
// 添加句柄
addHandler:function(element,type,handler){
if(element.addEventListener){
element.addEventListener(type,handler,false);
}else if(element.attachEvent){
element.attachEvent('on'+type,handler);
}else{
element['on'+type]=handler;
}
},
// 删除句柄
removeHandler:function(element,type,handler){
if(element.removeEventListener){
element.removeEventListener(type,handler,false);
}else if(element.detachEvent){
element.detachEvent('on'+type,handler);
}else{
element['on'+type]=null;
}
},
//获取事件对象
//IE模型中event是一个全局唯一的对象绑定在window对象上
getEvent:function(event){
return event?event:window.event;
},
//获取类型
getType:function(event){
return event.type;
},
getElement:function(event){
return event.target || event.srcElement;
},
//阻止默认事件
preventDefault:function(event){
if(event.preventDefault){
event.preventDefault();
}else{
event.returnValue=false;
}
},
//阻止冒泡
stopPropagation:function(event){
if(event.stopPropagation){
event.stopPropagation();
}else{
event.cancelBubble=true;
}
}
}