Web frontend development
將會介紹...
- Sublime Text 3
- HTML
- Javascript
- CSS
- web crawling
data:image/s3,"s3://crabby-images/64dd8/64dd8424dbcdd5464fe0cea6ca59b32ac917d98b" alt=""
data:image/s3,"s3://crabby-images/daed5/daed586e7573db445cf6686cff6c0d6af9d64103" alt=""
安裝適合的版本
data:image/s3,"s3://crabby-images/3c2b3/3c2b388e46d0a128992d99bd7dd94e044e4388d0" alt=""
data:image/s3,"s3://crabby-images/776c4/776c46c82a5076f5246c53663a47af99b8693d90" alt=""
data:image/s3,"s3://crabby-images/3e80b/3e80b6871dec0c4ed7eed3cbb860338de810cc6c" alt=""
data:image/s3,"s3://crabby-images/7f266/7f266a73aff3927df226063cb86e7b808b4bf8e9" alt=""
優點
- 執行快速
- 搜尋、取代功能(regular expression)
- multiple selection(一次編輯多個地方)
- syntax highlight
- 插件(套件)多,可擴充大量功能
- best editor for developers !!!
data:image/s3,"s3://crabby-images/79a22/79a22a8ab5186c469e3a1051a3c2322d0dc6f5ab" alt=""
縮排控制
上色語言
data:image/s3,"s3://crabby-images/82efb/82efbfa2604dabbc1cea4904a905658e28f7fa8a" alt=""
data:image/s3,"s3://crabby-images/f9dd2/f9dd2fd2002823a99bc869b893427f01dadcc644" alt=""
CTRL+F | 搜尋 |
CTRL+H | 取代 |
CTRL+Shift+P | 開啟指令介面 |
Esc | 離開目前功能 |
CTRL+Click | multiple selection |
data:image/s3,"s3://crabby-images/eaaf4/eaaf4ce4a458939d97ae4bb41c9fe81c1e59adf9" alt=""
插件們
工具們
Tools > Build System > New Build System
data:image/s3,"s3://crabby-images/2c330/2c330c657ba79acc6401f668286fc717738fc67f" alt=""
data:image/s3,"s3://crabby-images/6d38e/6d38ef1ab1fa90f282fa43dc15ab3bea0cad6736" alt=""
snippets
Tools > Developer > New Snippet
data:image/s3,"s3://crabby-images/fc43e/fc43e04c41d2ee12070dd70dada9b1b1e9d899f0" alt=""
material theme
CTRL+Shift+P >
Package Control: Install Package > material theme
terminus
CTRL+Shift+P >
Package Control: Install Package > terminus
data:image/s3,"s3://crabby-images/048e4/048e4bce40ceaf4d0c71d5a24c1293c19bd53ada" alt=""
HTML
HyperText Markup Language
超文字
標記
語言
data:image/s3,"s3://crabby-images/1623f/1623fe063b4a0aaad33b739b1fd52e537358501b" alt=""
what is HTML?
- 標記語言
- 告訴電腦物件的呈現方式
- 不是程式語言!
基本語法
<TAGNAME>EXAMPLE</TAGNAME>
<html>
<body>
<h1>My First Heading</h1>
<p>My first paragraph.</p>
</body>
</html>
基本語法
<TAGNAME>
<img>
<input>
<br>
<link>
<meta>
<source>
基本語法
- 無視換行
- 多個空白會被視為一個
- 檔案以\(\texttt{<!DOCTYPE>}\)開頭
<!DOCTYPE>
Hello World!!!
I am new to HTML
data:image/s3,"s3://crabby-images/691fc/691fce83d0a54b9266711577f122c9a572201790" alt=""
<!DOCTYPE>
Hello World!!!<br>
I am new to HTML
data:image/s3,"s3://crabby-images/5dbad/5dbad514e44146a8cb6a8fe835ffe6b78ba26fef" alt=""
<!DOCTYPE>
<h1>Hello World!!!</h1>
<p>I am new to HTML</p>
data:image/s3,"s3://crabby-images/f3801/f3801b7e8ad66c9815602e6241d896b260be2ba8" alt=""
<!DOCTYPE>
<h1>heading1</h1>
<h2>heading2</h2>
<h3>heading3</h3>
<h4>heading4</h4>
<h5>heading5</h5>
<h6>heading6</h6>
<p>paragraph</p>
data:image/s3,"s3://crabby-images/059fe/059feb1677b1053b6a9fb7fbc352e0a029420f9b" alt=""
<!DOCTYPE>
<h1 style="color: red;">heading1</h1>
<h2 style="color: orange;">heading2</h2>
<h3 style="color: yellow;">heading3</h3>
<h4 style="color: green;">heading4</h4>
<h5 style="color: blue;">heading5</h5>
<h6 style="color: purple;">heading6</h6>
<p style="color: #808080;">paragraph</p>
data:image/s3,"s3://crabby-images/3596f/3596f361932d5e41211eeec7b20676cd989ea50d" alt=""
基本語法
<TAGNAME ATTRIBUTE="VALUE"></TAGNAME>
<!DOCTYPE>
<h1 style="color: red;text-align:center">heading1</h1>
<h2 style="color: orange;text-align:center">heading2</h2>
<h3 style="color: yellow;text-align:center">heading3</h3>
<h4 style="color: green;text-align:center">heading4</h4>
<h5 style="color: blue;text-align:center">heading5</h5>
<h6 style="color: purple;text-align:center">heading6</h6>
<p style="color: #808080;text-align:center">paragraph</p>
data:image/s3,"s3://crabby-images/57104/571046cf10ad60b686166391dd41f7eeb3f495d9" alt=""
<!DOCTYPE>
<h1 style="color: red;text-align: center;border-style: solid;">heading1</h1>
<h2 style="color: orange;text-align: center;border-style: solid;">heading2</h2>
<h3 style="color: yellow;text-align: center;border-style: solid;">heading3</h3>
<h4 style="color: green;text-align: center;border-style: solid;">heading4</h4>
<h5 style="color: blue;text-align: center;border-style: solid;">heading5</h5>
<h6 style="color: purple;text-align: center;border-style: solid;">heading6</h6>
<p style="color: gray;text-align: center;border-style: solid;">paragraph</p>
data:image/s3,"s3://crabby-images/8ccc2/8ccc296beeb9300192da84da2b949d64e6a8d7a3" alt=""
每個都寫一樣的東西
<!DOCTYPE>
<style>
.text{
text-align: center;
border-style: solid;
}
</style>
<h1 class="text" style="color: red;">heading1</h1>
<h2 class="text" style="color: orange;">heading2</h2>
<h3 class="text" style="color: yellow;">heading3</h3>
<h4 class="text" style="color: green;">heading4</h4>
<h5 class="text" style="color: blue;">heading5</h5>
<h6 class="text" style="color: purple;">heading6</h6>
<p class="text" style="color: gray;">paragraph</p>
讓所有 class 是 text 的 element 都加上 "text-align: center;border-style: solid;"
<!DOCTYPE>
<style>
.text{
text-align: center;
border-style: solid;
}
.round{
border-radius: 100px;
}
</style>
<h1 class="text round" style="color: red;">heading1</h1>
<h2 class="text" style="color: orange;">heading2</h2>
<h3 class="text round" style="color: yellow;">heading3</h3>
<h4 class="text" style="color: green;">heading4</h4>
<h5 class="text round" style="color: blue;">heading5</h5>
<h6 class="text" style="color: purple;">heading6</h6>
<p class="text round" style="color: gray;">paragraph</p>
data:image/s3,"s3://crabby-images/dd8dd/dd8dd8e508fc9b2e4c5ea7504fcb237e8db8e0eb" alt=""
<!DOCTYPE>
<style>
.text{
text-align: center;
border-style: solid;
}
.round{
border-radius: 100px;
}
</style>
<h1 class="text round" style="color: red;">heading1</h1>
<h2 class="text" style="color: orange;">heading2</h2>
<h3 class="text round" style="color: yellow;">heading3</h3>
<h4 class="text" style="color: green;">heading4</h4>
<h5 class="text round" style="color: blue;">heading5</h5>
<h6 class="text" style="color: purple;">heading6</h6>
<p class="text round" style="color: gray;">paragraph</p>
CSS code
CSS selector
<!DOCTYPE html>
<ol>
<li>first</li>
<li>second</li>
<li>third</li>
</ol>
ordered list / list item
data:image/s3,"s3://crabby-images/c756b/c756b9a54a44bf0a9463d31dfb22bf7a511718e2" alt=""
<!DOCTYPE html>
<ul>
<li>first</li>
<li>second</li>
<li>third</li>
</ul>
unordered list / list item
data:image/s3,"s3://crabby-images/f7f01/f7f018dea4971d62fbb7cf7a94395dcc59ea08ed" alt=""
<a href="https://slides.com/thomaswang2003/web">learn web</a>
<table style="width:100%">
<tr>
<th>Firstname</th>
<th>Lastname</th>
<th>Age</th>
</tr>
<tr>
<td>Jill</td>
<td>Smith</td>
<td>50</td>
</tr>
<tr>
<td>Eve</td>
<td>Jackson</td>
<td>94</td>
</tr>
</table>
HTML 基本架構
蛤?現在才講?
<!DOCTYPE html>
<html>
<head>
<title>jizz</title>
</head>
<body>
everything to be displayed on page
</body>
</html>
data:image/s3,"s3://crabby-images/92df1/92df1a470eec89a26937d07445e9c4e036f8a84a" alt=""
title
body
metas
<head>
<meta charset="UTF-8">
<meta name="description" content="INFOR Web-frontend jizz">
<meta name="keywords" content="Sublime,HTML,CSS,Javascript,Web-crawling">
<meta name="author" content="Thomas Wang">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
</head>
最熟悉的工具—Google Chrome
data:image/s3,"s3://crabby-images/3e28a/3e28ab819d47ed1ee4779d8e3360a24e16589502" alt=""
F12
data:image/s3,"s3://crabby-images/e4749/e47498b3305402e809cb03541b6e209b964a9b23" alt=""
data:image/s3,"s3://crabby-images/910b8/910b8038a1b42a9ba1abfdb7f56f7de0ed6491ef" alt=""
Cascading Style Sheets
CSS
what is CSS?
- 設定每個元素、類別等的style
- 將style與html分離
- 類似「呈現與內容分離」的理念
selector 語法
/* select by element name */
ELEMENT {...}
/* select by class */
.CLASS {...}
/* select by id */
#id {...}
/* select all */
* {...}
selector 語法
/* select by element name */
h1 {font-weight: 1000;}
/* select by class */
.center {text-align: center;}
/* select by id */
#box {background-color: red;}
/* select all */
* {font-family: 'Noto Sans TC';}
CSS「框架」
其實就是函式庫
Javascript
data:image/s3,"s3://crabby-images/92084/92084a9a8abd4cddb94e003f87a23af70f2b4c6d" alt=""
what is JS?
- 讓元素動起來
- 處理事件(event)
基本語法 跟C++很像
- 宣告變數用 \(\texttt{var}\)
- 弱型別
- \(\texttt{String}\)
- \(\texttt{Number}\)
- \(\texttt{Array}\)
- \(\texttt{Object}\)
data:image/s3,"s3://crabby-images/0f88e/0f88e09b744fcf33aaf175571b0e8e83af6fd9ef" alt=""
function double(x){
x=String(x);
return x+x;
}
console.log(double(7122))
HTML DOM
- 更改HTML網頁的內容
- 處理網頁發生事件
<!DOCTYPE html>
<html>
<head>
<title></title>
</head>
<body>
<script>
var x=7122;
console.log(x);
// js code goes here
</script>
</body>
</html>
document.getElementById
document.getElementsByTag
document.getElementsByClassName
<!DOCTYPE html>
<html>
<body>
<h1 id="test">Testing Page</h1>
<script>
var ele = document.getElementById('test');
ele.innerHTML='Changed';
</script>
</body>
</html>
<!DOCTYPE html>
<html>
<body>
<h1 class="text">heading1</h1>
<h2 class="text">heading2</h2>
<h3 class="text">heading3</h3>
<h4 class="text">heading4</h4>
<h5 class="text">heading5</h5>
<h6 class="text">heading6</h6>
<p class="text">paragraph</p>
<script>
var eles = document.getElementsByClassName('text');
console.log(eles.length);
for(var i=0;i<eles.length;i++)
eles[i].innerHTML='Changed';
</script>
</body>
</html>
<!DOCTYPE html>
<html>
<body>
<h1 class="text">heading1</h1>
<h2 class="text">heading2</h2>
<h3 class="text">heading3</h3>
<h4 class="text">heading4</h4>
<h5 class="text">heading5</h5>
<h6 class="text">heading6</h6>
<p class="text">paragraph</p>
<button onclick="change();">Change</button>
<script>
function change(){
var eles = document.getElementsByClassName('text');
console.log(eles.length);
for(var i=0;i<eles.length;i++)
eles[i].innerHTML='Changed';
}
</script>
</body>
</html>
<!DOCTYPE html>
<html>
<body>
<h1 class="text">heading1</h1>
<h2 class="text">heading2</h2>
<h3 class="text">heading3</h3>
<h4 class="text">heading4</h4>
<h5 class="text">heading5</h5>
<h6 class="text">heading6</h6>
<p class="text">paragraph</p>
<button id="btn">Change</button>
<script>
function change(){
var eles = document.getElementsByClassName('text');
console.log(eles.length);
for(var i=0;i<eles.length;i++)
eles[i].innerHTML='Changed';
}
document.getElementById('btn').addEventListener('click',change);
</script>
</body>
</html>
<!DOCTYPE html>
<html>
<body>
<h1 class="text">heading1</h1>
<h2 class="text">heading2</h2>
<h3 class="text">heading3</h3>
<h4 class="text">heading4</h4>
<h5 class="text">heading5</h5>
<h6 class="text">heading6</h6>
<p class="text">paragraph</p>
<button id="btn">Change</button>
<script>
function double(x){
x=String(x);
return x+x;
}
function change(){
var eles = document.getElementsByClassName('text');
console.log(eles.length);
for(var i=0;i<eles.length;i++)
eles[i].innerHTML=double(eles[i].innerHTML);
}
document.getElementById('btn').addEventListener('click',change);
</script>
</body>
</html>
<!DOCTYPE html>
<html>
<body>
<h1 class="text">heading1</h1>
<h2 class="text">heading2</h2>
<h3 class="text">heading3</h3>
<h4 class="text">heading4</h4>
<h5 class="text">heading5</h5>
<h6 class="text">heading6</h6>
<p class="text">paragraph</p>
<button id="btn1" onclick="change();">Change</button>
<button id="btn2" onclick="hide(this);">Hide</button>
<script>
function double(x){
x=String(x);
return x+x;
}
function change(){
var eles = document.getElementsByClassName('text');
console.log(eles.length);
for(var i=0;i<eles.length;i++)
eles[i].innerHTML=double(eles[i].innerHTML);
}
function hide(x){
if(x.innerHTML=='Hide'){
x.innerHTML='Show';
var eles = document.getElementsByClassName('text');
console.log(eles.length);
for(var i=0;i<eles.length;i++)
eles[i].style.display='none';
}else{
x.innerHTML='Hide';
var eles = document.getElementsByClassName('text');
console.log(eles.length);
for(var i=0;i<eles.length;i++)
eles[i].style.display='block';
}
}
</script>
</body>
</html>
Web Crawler
網頁爬蟲
Web Crawler?
- 從網路上「自動」抓取「大量」資料
如何從網路上取得資料
- Request: 向伺服器請求
- Response: 伺服器回傳的回應(檔案、資料...等)
請求有8種方法(method)
- GET
- POST
- ...不重要
GET: 取得頁面(html css js image ...)
POST: 傳送資料(表單提交)
瀏覽器:向伺服器請求資料,
再呈現在畫面上
爬蟲:自己寫程式向伺服器請求資料
再進行資料處理
Python requests
import requests
response=requests.get('https://tioj.ck.tp.edu.tw')
print(response)
print(response.text)
data:image/s3,"s3://crabby-images/ae5d8/ae5d849b9f7d05a7b36d47e7fa9294891a746d65" alt=""
缺了css
但我們不在乎
怎麼處理html code?
python bs4
from bs4 import BeautifulSoup as bs
code='<div><p>bs4</p></div>'
html=bs(code,'html.parser')
print(html.prettify())
print(html.select('div > p'))
print(html.select('div > p')[0].text)
利用selector找到你要的元素
然後擷取資料
data:image/s3,"s3://crabby-images/38a1e/38a1e3413192b3d8c01e6d461f92b9fecd5e5c5f" alt=""
website
By thomaswang2003
website
- 663