網頁就是HTML?這么理解大概沒錯。因為網頁中不但包含文字,還有圖片、視頻、Flash小游戲,有復雜的排版、動畫效果,所以,HTML定義了一套語法規則,來告訴瀏覽器如何把一個豐富多彩的頁面顯示出來。
HTML長什么樣?上次我們看了新浪首頁的HTML源碼,如果仔細數數,竟然有6000多行!
所以,學HTML,就不要指望從新浪入手了。我們來看看最簡單的HTML長什么樣:
~~~
<html>
<head>
<title>Hello</title>
</head>
<body>
<h1>Hello, world!</h1>
</body>
</html>
~~~
可以用文本編輯器編寫HTML,然后保存為`hello.html`,雙擊或者把文件拖到瀏覽器中,就可以看到效果:

HTML文檔就是一系列的Tag組成,最外層的Tag是``。規范的HTML也包含`...`和`...`(注意不要和HTTP的Header、Body搞混了),由于HTML是富文檔模型,所以,還有一系列的Tag用來表示鏈接、圖片、表格、表單等等。
### CSS簡介
CSS是Cascading Style Sheets(層疊樣式表)的簡稱,CSS用來控制HTML里的所有元素如何展現,比如,給標題元素``加一個樣式,變成48號字體,灰色,帶陰影:
~~~
<html>
<head>
<title>Hello</title>
<style>
h1 {
color: #333333;
font-size: 48px;
text-shadow: 3px 3px 3px #666666;
}
</style>
</head>
<body>
<h1>Hello, world!</h1>
</body>
</html>
~~~
效果如下:

### JavaScript簡介
JavaScript雖然名稱有個Java,但它和Java真的一點關系沒有。JavaScript是為了讓HTML具有交互性而作為腳本語言添加的,JavaScript既可以內嵌到HTML中,也可以從外部鏈接到HTML中。如果我們希望當用戶點擊標題時把標題變成紅色,就必須通過JavaScript來實現:
~~~
<html>
<head>
<title>Hello</title>
<style>
h1 {
color: #333333;
font-size: 48px;
text-shadow: 3px 3px 3px #666666;
}
</style>
<script>
function change() {
document.getElementsByTagName('h1')[0].style.color = '#ff0000';
}
</script>
</head>
<body>
<h1 onclick="change()">Hello, world!</h1>
</body>
</html>
~~~
點擊標題后效果如下:

### 小結
如果要學習Web開發,首先要對HTML、CSS和JavaScript作一定的了解。HTML定義了頁面的內容,CSS來控制頁面元素的樣式,而JavaScript負責頁面的交互邏輯。
講解HTML、CSS和JavaScript就可以寫3本書,對于優秀的Web開發人員來說,精通HTML、CSS和JavaScript是必須的,這里推薦一個在線學習網站w3schools:
[http://www.w3schools.com/](http://www.w3schools.com/)
以及一個對應的中文版本:
[http://www.w3school.com.cn/](http://www.w3school.com.cn/)
當我們用Python或者其他語言開發Web應用時,我們就是要在服務器端動態創建出HTML,這樣,瀏覽器就會向不同的用戶顯示出不同的Web頁面。
- 關于
- Python簡介
- 安裝Python
- Python解釋器
- 第一個Python程序
- 使用文本編輯器
- Python代碼運行助手
- 輸入和輸出
- Python基礎
- 數據類型和變量
- 字符串和編碼
- 使用list和tuple
- 條件判斷
- 循環
- 使用dict和set
- 函數
- 調用函數
- 定義函數
- 函數的參數
- 遞歸函數
- 高級特性
- 切片
- 迭代
- 列表生成式
- 生成器
- 迭代器
- 函數式編程
- 高階函數
- 返回函數
- 匿名函數
- 裝飾器
- 偏函數
- 模塊
- 使用模塊
- 安裝第三方模塊
- 面向對象編程
- 類和實例
- 訪問限制
- 繼承和多態
- 獲取對象信息
- 實例屬性和類屬性
- 面向對象高級編程
- 使用slots
- 使用@property
- 多重繼承
- 定制類
- 使用枚舉類
- 使用元類
- 錯誤、調試和測試
- 錯誤處理
- 調試
- 單元測試
- 文檔測試
- IO編程
- 文件讀寫
- StringIO和BytesIO
- 操作文件和目錄
- 序列化
- 進程和線程
- 多進程
- 多線程
- ThreadLocal
- 進程 vs. 線程
- 分布式進程
- 正則表達式
- 常用內建模塊
- datetime
- collections
- base64
- struct
- hashlib
- itertools
- XML
- HTMLParser
- urllib
- 常用第三方模塊
- PIL
- virtualenv
- 圖形界面
- 網絡編程
- TCP/IP簡介
- TCP編程
- UDP編程
- 電子郵件
- SMTP發送郵件
- POP3收取郵件
- 訪問數據庫
- 使用SQLite
- 使用MySQL
- 使用SQLAlchemy
- Web開發
- HTTP協議簡介
- HTML簡介
- WSGI接口
- 使用Web框架
- 使用模板
- 異步IO
- 協程
- asyncio
- aiohttp
- 實戰
- Day 1 - 搭建開發環境
- Day 2 - 編寫Web App骨架
- Day 3 - 編寫ORM
- Day 4 - 編寫Model
- Day 5 - 編寫Web框架
- Day 6 - 編寫配置文件
- Day 7 - 編寫MVC
- Day 8 - 構建前端
- Day 9 - 編寫API
- Day 10 - 用戶注冊和登錄
- Day 11 - 編寫日志創建頁
- Day 12 - 編寫日志列表頁
- Day 13 - 提升開發效率
- Day 14 - 完成Web App
- Day 15 - 部署Web App
- Day 16 - 編寫移動App
- FAQ
- 期末總結