欧美三区_成人在线免费观看视频_欧美极品少妇xxxxⅹ免费视频_a级毛片免费播放_鲁一鲁中文字幕久久_亚洲一级特黄

如何開發 Web 應用程序

系統 2185 0

這是一個經常被問到的問題,問的理所當然。作為一個程序員,為什么我就非要被認為知道如何開發Web應用程序呢?這個問題沒有一個簡單的答案,甚至那些教育機構都未必能清楚的知道;我上的那個大學并沒有提供任何關于這個主題的課程。所以,像大多數在這個領域里的web開發人員一樣,我只是通過去做, 去實驗才學會了這些。沒有人告訴我如何去做,我從給自己做點什么東西開始,學會如何開發web應用程序是在這個過程中的一個副產品。這是 學習任何語言 的一個非常有效的方法。

你很幸運,我在這里將會把如何開發一個web應用程序的主要過程都講一下。希望能幫助你入門。

Web應用程序與網站之間的區別

首先,我要說明,開發一個web應用程序跟開發一個網站是不一樣的。雖然在總體上有很大相似之處,但開發它們所需要的時間有巨大的差別。那究竟web應用程序和網站有什么不同呢?通常,維基百科能幫助我們解釋這個問題,讓我們來看看維基百科是如何定義 應用軟件 的:

應用軟件,通常也被稱作應用,指的是專門為幫助用戶去執行一個或多個相關特定任務而設計的計算機軟件。企業軟件,會計軟件,辦公套件,繪圖軟件,媒體播放器等都屬于這種軟件。

跟應用軟件相對照的是系統軟件和中間件,它們管理計算機效能,管理如何跟計算機集成,但通常這些工作并不會直接反映到使用戶受益的任務執行上。舉個 例子,一個不是很恰當的實體類比,應用軟件跟系統軟件之間的關系就好比一個電燈泡和一個發電廠之間的關系,發電廠(系統軟件)只是產生電能,它自己沒有任 何真正的用途,除非利用一個電燈泡這樣的應用工具才能為用戶提供服務。

從里面, 我總結出來自己對web應用程序的定義 :

一個web應用程序是 一個能夠讓用戶完成某些特定任務的網站 。而一個普通的網站的主要目標是給用戶提供信息(博客,新聞,指導,等)。

Web應用程序的開發過程

現在特征已經弄清楚了,我們就可以開始定義開發一個web應用程序的整個過程了。當然,這依賴于工程的大小,過程中的某些步驟可能很小,在你的腦海 里就能完成這種工作,但把事情整個的了解一下總是有好處的。同時還有一點很重要的你要明白,這篇文章并不會對每個步驟進行深層次的描述。

步驟一:分析

開發一個web應用的第一步是 分析 你的需求。你此時應該定義出一個盡量周全的你的應用應該提供的 功能 清單。如果是你為一個客戶做這些工作,你需要明白他們想要什么(要確保你們對方都知道對方在說些什么)。從你們的討論中,你能 總結出需求和軟件規格 。你即使是為自己開發,我也建議你把希望這個web應用能夠做的功能寫下來。

步驟二:設計

一旦你弄清楚了這個web應用需要做哪些事情,你就可以開始設計了。這個步驟通常會反反復復進行很多次,每一次都把設計細化一些。 你第一要做的是畫出頁面流程圖 (畫在紙上,或使用軟件工具,憑各自所好吧。我喜歡用紙,這樣我可以做更快速的改變)。頁面流程圖通常是很抽象的黑白繪畫,畫出你將要實現的web應用的樣子(你可以加一些色彩,但盡量保持簡單)。

Wireframe created using Draft for the iPad

Wireframe created using Draft for the iPad


這個步驟能夠讓你知道你的應用最終會是個什么樣子。跟37signals倡導的相反,我建議使用一些詞語描述,適度細化。當我想到一個很好的想法時,或想 到事情該如何做時,我會把它標注到紙上(例如,當點擊這個按鈕時應該使另外一個元素改變或隱藏,我會把這寫在流程圖上)。

當你對做出的草圖滿意后,你可以 開始制作實體模型了。
實體模型仍然是些圖案,但有色彩和細節。最終的實體模型看起來應該像你將要實現的web應用的一個截屏圖。如果你為一個客戶開發,他會看看這些東西,并給你他的認可。然而,很多人都喜歡跳過這一步(大多數都是非設計人員),他們喜歡直接奔向 網頁原型

原型是用HTML開發出來,使用CSS渲染(有時也是有Javascript)。頁面布局要做出來,鏈接能夠點,顏色,字體,字體大小要設定好(如 果你做了實體模型,這個會很容易)。這一步非常的重要,因為這里所有的東西都能用于你最終的應用中。如果允許的話,在你的原型上 做一些可用性測試 ,從長期的效果來看,這能使你避免大量的失誤。

在這個步驟的最后,你基本上就知道了你的web應用是如何組織到一起的了。登錄頁面有些什么,用戶如何從主頁轉向到各個頁面。

我建議你去聽一下 Ryan Singer在“Web應用的未來”研討會上做的他是如何設計37signals的演講

步驟三:實現

選擇一個框架

現在我們已經知道了要去開發什么東西,那就要把它做出來。這一部分的工作很多,你大部分的時間都要花在這個上面。你第一個要做的決定是如何著手,采用什么樣的技術,什么框架。你有很多選擇的余地,你需要選出一個適合你的。下面是一個最常用的框架的列表:

沒有一個明確的標準說哪個框架最好。它們都各有不同,每個都有自己的長處。最重要的是你要知道 它們任何一個都能讓你開發出好用的web應用。

開發

一旦你知道了如何去開發,那就要甩開臂膀開干了。這個開發工作可以看作有很多塊,但說到底,這都是標準的編程活動了。在后臺,你要創建類,對象,服 務,過程,以及持久層來把這些對象保存到數據庫中。后臺是整個應用的核心,對任何應用來說,它跟普通的編程沒有什么區別。接著是前臺的開發,你現在編寫的 代碼才是真正給用戶使用的操作界面。你把后臺的程序和原型界面集成到一起,把系統各部分集成到一起。你還可以把你在開發過程中想到的一些很炫的小功能用 JavaScript實現。

再說一次,有很多種途徑可以實現后臺程序。建議你去讀一讀跟你選擇的框架相關的資料,弄清楚如何實現這一部分的工作。通常,這些知識會跟 面向對象編程 有關,但有些框架正在慢慢的向 領域驅動設計 發展。

步驟四:打磨拋光

現在應用程序已經開發出來,各個獨立的模塊也集成到了一起。你需要通過 測試 來確保你在步驟一中定義的需求和軟件規格是否被實現(這個問題在你開發的整個過程中都要記在腦中)。你要 確保 那些愚蠢的用戶不能通過試圖做一些你還沒有實現的操作而把你的應用弄壞(參考 白盒 黑盒測試 )。你同時還要確保你的程序能夠在各種瀏覽器里(希望不是IE6)都能 正確的運行

現在也是你做一些小的調整, 改進你的應用程序給人的感覺的時候 ,讓它趨于完美。

步驟五:發布和后續工作

這最后一步(但不是就此完結)是發布你的應用,讓用戶能夠真正使用它(如果這個應用是個公眾開發的應用,別忘了做新聞宣傳)。如果你愿意,先發布一 個Beta版,這樣只有一小部分用戶能夠發現你的應用里的大問題(因為你的程序里肯定會有bug),他們會幫助你改進程序的質量。不要忙著增加功能, 要專注于把你目前的程序變的穩固。

當經過了beta階段,你的程序已經變得十分的穩固,聽取用戶反饋的意見,自己試用一下自己的應用,你可以開始思考如何使應用變的更好。 找出不和諧的地方,消除掉 。以后每次的迭代都要經過上面所說的五個步驟,但就像我最初說的,你現在已經有了一個可以運行的應用程序,你很容易直接在心里完成這些步驟,直接奔向在代碼里測試你的功能。

恭喜,你已經自豪的成為一個web應用程序的作者了。

[英文出處]: How to develop web applications

[譯文來源]: 外刊IT評論


本文是使用 B3log Solo 簡約設計の藝術 進行同步發布的

如何開發 Web 應用程序


更多文章、技術交流、商務合作、聯系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!!!

發表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 日韩男人的天堂 | 欧美成人a∨高清免费观看 毛片特级 | 日韩中文一区二区三区 | 日韩手机专区 | 久久影院一区二区三区 | 欧美日韩综合精品 | 精品伊人久久久大香线蕉欧美 | 国产色片在线观看 | 亚洲国产精品一区 | 国产精品极品美女在线观看免费 | 国产高清在线观看 | 久在线播放 | 久久国产精品一区二区三区 | 日本熟妇无码波多野1223 | 亚洲欧美视频网站 | 在线色网 | 欧洲视频在线观看 | 日韩免费毛片 | 国内精品视频免费观看 | 欧美色呦呦 | 久久不卡一区二区三区 | 国产内谢| 午夜影院网站 | 日日爽 | 自拍亚洲一区 | 国产午夜精品视频免费不卡69堂 | 久色视频在线观看 | 欧美成人26uuu欧美毛片 | 黄色影视大全 | 97中文| 日韩操操操 | 欧美另类性视频 | 99re6热视频精品免费观看 | 欧美日韩在线免费观看 | 日本黄色高清网站 | 国产精品久久久久久久一区探花 | 三A级做爰片免费观看国产电影 | 天天综合网在线观看视频 | 欧美一区视频 | 久久久www成人免费精品 | 欧美一性一看一免费视频 |