今天,本文向初學者介紹一些 Web 開發(fā)中的基本概念和用到的技術,從A到Z總共26項,每項對應一個概念或者技術。
A — AJAX
AJAX 全稱為“ Asynchronous JavaScript and XML ”(異步 JavaScript 和 XML ),是一種創(chuàng)建交互式網頁應用的 網頁開發(fā) 技術。根據(jù)Ajax提出者Jesse James Garrett建議,AJAX:
使用 XHTML + CSS 來表示信息;
使用 JavaScript 操作 DOM (Document Object Model)進行動態(tài)顯示及交互;
使用 XML 和 XSLT 進行數(shù)據(jù)交換及相關操作;
使用 XMLHttpRequest 對象與 Web服務器 進行異步數(shù)據(jù)交換;
使用 JavaScript 將所有的東西綁定在一起。
類似于 DHTML 或 LAMP ,AJAX不是指一種單一的技術,而是有機地利用了一系列相關的技術。事實上,一些基于AJAX的“派生/合成”式(derivative/composite)的技術正在出現(xiàn),如 AFLAX 。
B — Browser
網頁瀏覽器 是個顯示 網頁服務器 或文件系統(tǒng)內的文件,并讓用戶與此些文件交互的一種 軟件 。它用來顯示在 萬維網 或 局域網 等內的文字、圖像及其他信息。這些文字或圖像,可以是連接其他網址的超連結,用戶可迅速及輕易地瀏覽各種信息。大部分網頁為 HTML 格式,有些網頁需特定瀏覽器才能正確顯示。 個人電腦 上常見的網頁瀏覽器按照2010年1月的市場占有率依次是 微軟 的 Internet Explorer 、 Mozilla 的 Firefox 、 Google 的 Google Chrome 、 蘋果公司 的 Safari 和 Opera軟件公司 的 Opera 。瀏覽器是最經常使用到的 客戶端程序 。Web開發(fā)人員應該確保其程序在各個主流瀏覽器中都能正常工作。
C — CSS
層疊樣式表, 又稱: 串樣式列表 ,英文: Cascading Style Sheets ,簡寫為 CSS ,由 W3C 定義和維護的標準,一種用來為結構化文檔(如 HTML 文檔或 XML 應用)添加樣式(字體、間距和顏色等)的 計算機語言 。目前最新版本是 CSS 2.1,為W3C的候選推薦標準。下一版本CSS 3仍然在開發(fā)過程中。
D — DOM
文檔對象模型 (Document Object Model,簡稱DOM),是 W3C 組織推薦的處理 可擴展置標語言 的標準編程接口。Document Object Model的歷史可以追溯至1990年代后期微軟與 Netscape 的“ 瀏覽器大戰(zhàn) ”(browser wars),雙方為了在 JavaScript 與 JScript 一決生死,于是大規(guī)模的賦予瀏覽器強大的功能。微軟在網頁技術上加入了不少專屬事物,計有VBScript、ActiveX、以及微軟自家的D HTML 格式等,使不少網頁使用非微軟平臺及瀏覽器無法正常顯示。DOM即是當時蘊釀出來的杰作。
E — Events
事件 是可以被控件識別的操作,如按下確定按鈕,選擇某個 單選按鈕 或者 復選框 。每一種控件有自己可以識別的事件,如 窗體 的加載、單擊、雙擊等事件,編輯框(文本框)的文本改變事,等等,現(xiàn)代的Web應用程序很大程度上依靠事件驅動。
事件有系統(tǒng)事件和用戶事件。系統(tǒng)事件由系統(tǒng)激發(fā),如時間每隔24小時,銀行儲戶的存款日期增加一天。用戶事件由用戶激發(fā),如用戶點擊按鈕,在文本框中顯示特定的文本。 事件驅動 控件執(zhí)行某項功能。觸發(fā)事件的對象稱為事件發(fā)送者;接收事件的對象稱為事件接收者。
使用事件機制可以實現(xiàn):當類對象的某個狀態(tài)發(fā)生變化時,系統(tǒng)將會通過某種途徑調用類中的有關處理這個事件的方法或者觸發(fā)控件事件的對象就會調用該控件所有已注冊的事件處理程序等。
F — Firebug
Firebug 是 網頁瀏覽器 Mozilla Firefox 的一個擴展,是一個除錯工具。用戶可以利用它除錯、編輯、甚至刪改任何網站的 CSS 、 HTML 、 DOM 、與 JavaScript 代碼。Firebug 也有提供其他網頁開發(fā)工具,例如 Yahoo! 的網頁速度優(yōu)化建議工具 YSlow 。Firebug是哈維( Joe Hewitt )撰寫的。他是最初Firefox創(chuàng)始者之一。
G — Grid
網格 ,也稱 柵格 ,不過從定義上說,柵格更為準確些。網上找個一個對網頁柵格系統(tǒng)比較恰當?shù)?定義 :以規(guī)則的網格陣列來指導和規(guī)范網頁中的版面布局以及信息分布。網頁柵格系統(tǒng)是從平面柵格系統(tǒng)中發(fā)展而來。對于網頁設計來說,柵格系統(tǒng)的使用,不僅可以讓網頁的信息呈現(xiàn)更加美觀易讀,更具可用性。而且,對于前端開發(fā)來說,網頁將更加的靈活與規(guī)范。如果有很多CSS框架支持柵格功能,可參考文章《 介紹27款經典的CSS框架 》。
H — HTML
超文本置標語言 ( 英文 : HyperText Markup Language , HTML )是為“ 網頁 創(chuàng)建和其它可在 網頁瀏覽器 中看到的信息”設計的一種 置標語言 。HTML被用來結構化信息——例如標題、段落和列表等等,也可用來在一定程度上描述文檔的外觀和 語義 。由 蒂姆·伯納斯-李 給出原始定義,由 IETF 用簡化的 SGML (標準通用置標語言)語法進行進一步發(fā)展的HTML,后來成為國際標準,由 萬維網聯(lián)盟 (W3C)維護。
最新版本是 HTML5 它是HTML下一個的主要修訂版本,現(xiàn)在仍處于發(fā)展階段。目標是取代1999年所定訂的 HTML 4.01和 XHTML 1.0 標準,以期能在互聯(lián)網應用迅速發(fā)展的時候,使網絡標準達到符合當代的網絡需求。廣義論及HTML5時,實際指的是包括HTML、 CSS 和 JavaScript 在內的一套技術組合。
I — IE
Windows Internet Explorer (舊稱 Microsoft Internet Explorer ,簡稱 Internet Explorer ,縮寫 IE ),是 微軟公司 推出的一款 網頁瀏覽器 。截至2010年9月止,統(tǒng)計的數(shù)據(jù)顯示Internet Explorer的 市場占有率 高達59.65%。雖然它依然是使用最廣泛的網頁瀏覽器,但與 2003年 最高峰時相比,市場占有率相差超過30%。
Internet Explorer對一些標準化技術都有一定程度上的支持,但亦有很多運行上的差距和兼容性的故障 ,這導致技術開發(fā)者的批評日益增加。批評增加的情況,在很大程度上是歸因于Internet Explorer的競爭對手相對地已提供完全的技術支持,標準規(guī)格(Standards-compliant)的應用亦越來越廣泛起來。因為Internet Explorer在全球廣為應用,網絡開發(fā)者們在尋求 跨平臺 的代碼時常常會發(fā)現(xiàn)Internet Explorer的漏洞、私有的功能集合和對標準支持的不完善。
2011年3月14日發(fā)布的Internet Explorer 9瀏覽器大幅提高對CSS3和HTML5等W3C規(guī)范的支持程度,這個版本也是Internet Explorer瀏覽器第一個采用GPU加速的版本,正式版于Acid3測試中獲得95/100分,相比以往版本有很大進步。可以認為,從Internet Explorer 9開始,Internet Explorer瀏覽器對W3C規(guī)范的支持將不再是問題。
J — JavaScript
JavaScript 是一種廣泛用于 客戶端 Web開發(fā) 的 腳本語言 ,常用來給HTML網頁添加動態(tài)功能,比如響應用戶的各種操作。它最初由 網景公司 的 Brendan Eich 設計,是一種動態(tài)、弱類型、基于原型的語言,內置支持類。JavaScript是 Sun公司 的注冊商標。 Ecma國際 以JavaScript為基礎制定了 ECMAScript 標準。JavaScript也可以用于其他場合,如服務器端編程。完整的JavaScript實現(xiàn)包含三個部分: ECMAScript , 文檔對象模型 , 字節(jié)順序記號 。
Netscape公司在最初將其腳本語言命名為LiveScript來Netscape在與Sun合作之后將其改名為JavaScript。JavaScript最初受 Java 啟發(fā)而開始設計的,目的之一就是“看上去像Java”,因此語法上有類似之處,一些名稱和命名規(guī)范也借自Java。但JavaScript的主要設計原則源自 Self 和 Scheme .JavaScript與Java名稱上的近似,是當時網景為了營銷考慮與Sun公司達成協(xié)議的結果。為了取得技術優(yōu)勢, 微軟 推出了 JScript 來迎戰(zhàn)JavaScript的 腳本語言 。為了互用性, Ecma國際 (前身為 歐洲計算機制造商協(xié)會 )創(chuàng)建了ECMA-262標準(ECMAScript)。現(xiàn)在兩者都屬于 ECMAScript 的實現(xiàn)。盡管JavaScript作為給非程序人員的 腳本語言 ,而非作為給程序人員的 編程語言 來推廣和宣傳,但是JavaScript具有非常豐富的特性。
K — Keyword Optimization
關鍵詞優(yōu)化 ,也叫 搜索引擎優(yōu)化 ( Search Engine Optimization ,簡稱 SEO )是一種利用 搜索引擎 的搜索規(guī)則來提高目的 網站 在有關搜索引擎內的排名的方式。由于不少研究發(fā)現(xiàn),搜索引擎的用戶往往只會留意搜索結果最前面的幾個條目,所以不少 網站 都希望通過各種形式來影響搜索引擎的排序。當中尤以各種依靠廣告維生的網站為甚。
所謂“針對搜索引擎作優(yōu)化的處理”,是指為了要讓網站更容易被搜索引擎接受。搜索引擎會將網站彼此間的內容做一些相關性的數(shù)據(jù)比對,然后再由 瀏覽器 將這些內容以最快速且接近最完整的方式,體現(xiàn)給搜索者。
搜索引擎優(yōu)化對于任何一家網站來說,要想在網站推廣中取得成功,搜索引擎優(yōu)化都是至為關鍵的一項任務。同時,隨著搜索引擎不斷變換它們的排名算法規(guī)則,每次算法上的改變都會讓一些排名很好的網站在一夜之間名落孫山,而失去排名的直接后果就是失去了網站固有的可觀訪問量。所以每次搜索引擎算法的改變都會在網站之中引起不小的騷動和焦慮。可以說,搜索引擎優(yōu)化是一個愈來愈復雜的任務。
L — Less
Less 最早是一個ruby的gem,讓CSS具有動態(tài)語言的特性,這些特性包括變量,操作符,嵌套規(guī)則。其實Less真正的作用是將使用高級特性的CSS轉換成標準的CSS。這些都是在Web客戶端發(fā)起請求時通過Http Handler來完成的。也可以是編輯時就完成的。此外,Less可以配置成自動最小化所生成的CSS文件,不僅節(jié)省了帶寬,并且使最終用戶體驗更上一層。另外有.Net版本的 Less 。
M — MVC
MVC模式 (Model-View-Controller)是 軟件工程 中的一種 軟件架構 模式,把軟件系統(tǒng)分為三個基本部分:模型(Model)、視圖(View)和控制器(Controller)。MVC模式最早由 Trygve Reenskaug 在1974年提出,是 施樂帕羅奧多研究中心 (Xerox PARC)在20世紀80年代為程序語言 Smalltalk 發(fā)明的一種軟件設計模式。 MVC模式 的目的是實現(xiàn)一種動態(tài)的程序設計,使后續(xù)對程序的修改和擴展簡化,并且使程序某一部分的重復利用成為可能。除此之外,此模式通過對復雜度的簡化,使程序結構更加直觀。軟件系統(tǒng)通過對自身基本部份分離的同時也賦予了各個基本部分應有的功能。
N — Node.JS
Node 是一個Javascript運行環(huán)境(runtime) , 實際上它是對Google V8 引擎(應用于Google Chrome瀏覽器)進行了封裝。 V8 引 擎執(zhí)行Javascript的速度非???,性能非常好。Node對一些特殊用例進行了優(yōu)化,提供了替代的API,使得V8在非瀏覽器環(huán)境下運行得更好。例 如,在服務器環(huán)境中,處理二進制數(shù)據(jù)通常是必不可少的,但Javascript對此支持不足,因此,V8.Node增加了Buffer類,方便并且高效地 處理二進制數(shù)據(jù)。因此,Node不僅僅簡單的使用了V8,還對其進行了優(yōu)化,使其在各環(huán)境下更加給力。 Node.js 包羅萬象,但最主要的一點是,它提供了一種在Web瀏覽器之外運行Javascript的途徑。Javascript廣泛應用于網站的前端開發(fā)。Node使得這種流行的編程語言能夠在更多環(huán)境下運行,甚至是網站的服務器端。
O — Object
對象 (object),是 面向對象 (Object Oriented) 中的術語,既表示客觀世界 問題空間 (Namespace)中的某個具體的事物,又表示軟件系統(tǒng) 解空間 中的基本元素。在軟件系統(tǒng)中,對象具有唯一的 標識符 ,對象包括 屬性 (Properties)和 方法 (Methods),屬性就是需要記憶的信息,方法就是對象能夠提供的服務。在面向對象(Object Oriented) 的軟件中,對象(Object)是某一個 類 (Class)的 實例 (Instance)。
P — PHP
PHP ( H ypertext P reprocessor )是一種在電腦上運行的 腳本語言 ,主要用途是在于處理 動態(tài)網頁 ,也包含了 命令行 運行接口(command line interface),或者產生 圖形用戶界面 (GUI)程序。PHP最早由 Rasmus Lerdorf 在1995年發(fā)明,而現(xiàn)在PHP的標準由PHP Group和開放源代碼社區(qū)維護。PHP以PHP License作為許可協(xié)議,不過因為這個協(xié)議限制了PHP名稱的使用,所以和開放源代碼許可協(xié)議 GPL 不兼容。
PHP的應用范圍相當廣泛,尤其是在網頁程序的開發(fā)上。一般來說PHP大多運行在網頁服務器上,通過運行PHP代碼來產生用戶瀏覽的網頁。PHP可以在多數(shù)的服務器和操作系統(tǒng)上運行,而且使用PHP完全是免費的。根據(jù)2007年4月的統(tǒng)計數(shù)據(jù),PHP已經被安裝在超過2000萬個網站和100萬臺服務器上。
Q — Query
查詢 ,有很多種意思。例如查詢語言用來和存儲數(shù)據(jù)的擴展系統(tǒng)交互,一個很好的例子就是SQL用來操作關系數(shù)據(jù)庫。另一種意思是,一個查詢字符串,作為URL的一部分用于Web應用程序中傳遞數(shù)據(jù),查詢字符串的格式一般是鍵值對形式。
R — Regular Expressions
正則表達式 ( 英語 :Regular Expression、regex或regexp,縮寫為RE),也譯為 正規(guī)表示法 、 常規(guī)表示法 ,在 計算機科學 中,是指一個用來描述或者匹配一系列符合某個 句法 規(guī)則的 字符串 的單個字符串。在很多 文本編輯器 或其他工具里,正則表達式通常被用來檢索和/或替換那些符合某個模式的文本內容。許多 程序設計語言 都支持利用正則表達式進行字符串操作。例如,在 Perl 中就內建了一個功能強大的正則表達式引擎。正則表達式這個概念最初是由 Unix 中的工具軟件(例如 sed 和 grep )普及開的。
S — Source Control
源代碼管理 ,也稱 版本控制 ,是一種 軟件工程 技巧,借此能在軟件開發(fā)的過程中,確保由不同人所編輯的同一程式檔案都得到同步。 軟件設計師 常會利用版本控制來追蹤、維護 源碼 、 文件 以及 設定檔 等等的更動,并且提供控制這些更動控制權的 程序 。在最簡單的情況下, 軟件設計師 可以自己保留一個程式的許多不同版本,并且為它們做適當?shù)木幪?。這種簡單的方法已被用在很多大型的軟件專案中。這是一個可以達到目的的方法,但不夠有效率。除了得同時維護很多幾乎一樣的 程式碼 備份外;而且極度依賴 軟件設計師 的自我修養(yǎng)與開發(fā)紀律,但這卻常是導致錯誤發(fā)生的原因。
有時候,一個程式同時存有兩個以上的版本也有其必要性,例如:在一個為了部署的版本中 程式錯誤 已經被修正、但沒有加入新功能;在另一個開發(fā)版本則有新的功能正在開發(fā)、也有新的錯誤待解決,這使得同時間需要不同的版本并修改。此外,為了找出只存在于某一特定版本中的 程式錯誤 、或找出 程式錯誤 出現(xiàn)的版本,軟件除錯者也必須借由比對不同版本的程式碼以找出問題的位置。
T — TDD
測試驅動開發(fā) (Test-driven development)是現(xiàn)代計算機 軟件開發(fā) 方法的一種。利用 測試 來驅動 軟件 程序的設計和實現(xiàn)。測試驅動開始流行于20世紀90年代。測試驅動開發(fā)是 極限編程 中倡導的程序開發(fā)方法,方法主要是先寫測試程序,然后再編碼使其通過測試。測試驅動開發(fā)的目的是取得快速反饋并使用“illustrate the main line”方法來構建程序。
測試驅動開發(fā)的比喻。開發(fā)可以從兩個方面去看待:實現(xiàn)的功能和質量。測試驅動開發(fā)更像兩頂帽子思考法的開發(fā)方式,先戴上實現(xiàn)功能的帽子,在測試的輔助下,快速實現(xiàn)正確的功能;再戴上 重構 的帽子,在測試的保護下,通過去除冗余和重復的代碼,提高代碼重用性,實現(xiàn)對質量的改進??梢姕y試在測試驅動開發(fā)中確實屬于核心地位,貫穿了開發(fā)的始終。
U — Unit Testing
單元測試 (又稱為 模塊測試 )是針對 程序模塊 ( 軟件設計 的最小單位)來進行正確性檢驗的測試工作。程序單元是應用的最小可測試部件。在 過程化編程 中,一個單元就是單個程序、函數(shù)、過程等;對于面向對象編程,最小單元就是方法,包括基類(超類)、抽象類、或者派生類(子類)中的方法。
通常來說,程序員每修改一次程序就會進行最少一次單元測試,在編寫程序的過程中前后很可能要進行多次單元測試,以證實程序達到 軟件規(guī)格書 ( en:Specification )要求的工作目標,沒有 臭蟲 ;雖然單元測試不是什么必須的,但也不壞,這牽涉到 項目管理 的政策決定。
V — VIM
Vim 是從 vi 發(fā)展出來的一個 文本編輯器 。代碼補完、編譯及錯誤跳轉等方便編程的功能特別豐富,在程序員中被廣泛使用。和 Emacs 并列成為 類Unix系統(tǒng) 用戶最喜歡的編輯器。Vim的第一個版本由 Bram Moolenaar 在1991年發(fā)布。最初的簡稱是 V i IM itation,隨著功能的不斷增加,正式名稱改成了 V i IM proved?,F(xiàn)在是在 開放源代碼 方式下發(fā)行的 自由軟件 。
W — WordPress
WordPress 是一種使用 PHP 語言開發(fā)的 博客 平臺,用戶可以在支持 PHP 和 MySQL 數(shù)據(jù)庫 的服務器上架設自己的網志。也可以把 WordPress 當作一個 內容管理系統(tǒng) (CMS)來使用。WordPress 是一個免費的 開源 項目,在 GNU通用公共許可證 下授權發(fā)布。目前最新版本為2011年2月24日發(fā)布的3.0.5官方簡體中文版,另外還有包括英文在內的多種語言可選。
X — XSS
跨網站指令碼 ( Cross-site scripting ,通常簡稱為 XSS )是一種網站應用程式的安全漏洞攻擊,允許惡意使用者將程式碼注入到網頁上,其他使用者在觀看網頁時就會受到影響。這類攻擊通常包含了 HTML 以及使用者端 腳本語言 。
Y — YUI
Yahoo! UI Library ( YUI ) 是一個開放源代碼的 JavaScript 函數(shù)庫,為了能建立一個高互動的網頁,它采用了 AJAX , DHTML 和 DOM 等程式碼技術。它也包含了許多 CSS 資源。
Z — Z index
Z-Index
是CSS屬性,設置元素的堆疊順序。擁有更高堆疊順序的元素總是會處于堆疊順序較低的元素的前面。該屬性設置一個定位元素沿 z 軸的位置,z 軸定義為垂直延伸到顯示區(qū)的軸。如果為正數(shù),則離用戶更近,為負數(shù)則表示離用戶更遠。