網站開發前端和后端用什么語言,用golang做后端?
前端后端精一即可。不要通,要精。 前端 html+css+js 后端 主流 jsp php asp.net asp (也是精一即可)
什么是后端編程?
舉一個開發H5的例子:
一般來說,我們只需要將應用程序簡單地分成前端和后端兩個開發任務。這種情況也有其交流習慣的原因(就像我們生活中的許多稱呼,語言,文字在熟悉中,都會用簡化的方式來代替完整的稱呼)。相應地,我們也會按照大家熟悉的方式將可歸納的能力范圍整合到某個名詞下,所以后端開發工程師也會負責數據庫的開發。
用過軟件或應用的人都知道,我們將簡單地將用戶分為看得見和看不見兩類。我們習慣把用戶看到的稱為前端,而把用戶看不到的部分稱為后端。一般用戶看到的東西分為視覺、功能、交互方式、內容等等,對于開發來說,主要是功能和交互體驗,這些可以簡單劃分為前端部分,前端使用的開發語言有: html、 css、 js等,但是不代表前端的技術難度就很簡單,一款軟件的體驗好與壞往往是無法區分的。
舉例來說,我在標題新聞中寫了一個小程序,相應的用戶看到的功能是前端,然后用戶使用我開發的小程序,獲取我的功能并反饋,最常見的是數據反饋,比如用戶注冊我的小程序,行為數據通常由后端工程師處理,其實這很簡單,后端開發是基于服務器環境的開發,因此我們也稱它為服務器語言,另外,不同的平臺有自己不同的開發文檔作為提交產品的規范,這也和后端開發有關。
通過下面一張圖來表達下前端和后端開發的關系:以上,謝謝。
什么語言開發的web最快?
JavaScript開發的web最快。
但是這個問題又分為幾個方面:
1、下載數據量方面:
網頁種只有三個大分支:HTML、CSS、JavaScript。
其中 HTML 是必要的,不可或缺的。剩下兩個實際上完全刪除都是 OK 的。(很多交互邏輯是不需要 JavaScript 的)
但是不能一味追求速度,網站還是要基本好看的,所以 CSS 要加進來。雖說 HTML + CSS 能實現大多數的交互邏輯,但是 JavaScript 有時能簡化這些邏輯,使得代碼量減少,或者有些復雜交互邏輯只能使用 JavaScript 來實現,所以按需使用 JavaScript 也是有必要的。
要使網頁的訪問速度提高,一個首要條件是下載的數據量降低。一個總大小 1MB 的網頁和一個總大小 1KB 的網頁誰的加載速度快,這很容易理解。
所以盡可能精簡 HTML 文件體積,盡可能精簡 CSS,盡可能精簡 JavaScript,可以非常有效、肉眼可見地提升網頁的加載速度。
精簡 HTML、CSS、JavaScript 可以在很多方面入手,最輕松的方式是盡可能的使用新特性,比如 HTML5、CSS3 和 JavaScript ES6。在不考慮古代瀏覽器兼容性(以 3~5 年內主流瀏覽器兼容為標準最佳)的情況下,建議盡可能【不要】使用 babel 之類的工具進行轉碼,可以不降低代碼的執行效率,并且不增大文件體積。
還有就是盡量不使用第三方類庫,原生 JavaScript 現在已經非常好用了,在沒有必要的情況下,盡可能全部交互邏輯使用原生實現。或是使用一些可拆分的精簡類庫(對于特別復雜的情況)。或者對于開源類庫,在遵守開源協議的前提下截取關鍵代碼來使用。
然后使用各種壓縮工具將 HTML、CSS、JavaScript 文件中不需要的空格、標記符全部刪除,最后使用 Brotli 或是 GZip 對文件進行壓縮。
數據量少了,訪問速度就上來了。
2、資源方面:
對于網頁種用到的第三方資源,比如圖片之類,盡可能壓縮(在不損失質量的情況下),并嘗試使用 WebP 等新格式。視頻也是類似。對于 CSS、JavaScript 等資源盡可能內聯到文件中,避免單獨下載,最好是啟用 HTTP/2,對資源使用 Server Push。
3、服務端方面
對于靜態類型頁面(純靜態,或是使用 API 加載頁面數據類型的網站),可以開啟 HTTP/2,可以預先將文件使用 Brotli 和 Gzip 分別壓縮好存儲起來。
對于動態類型頁面(模板頁面,內容通過服務端代碼運算后填充),建議不要等所有數據全部計算完再向前端返回數據,可以考慮邊算邊輸出(減少 TTFB 時間)。如果服務端計算很慢的話,可以先返回 HTML 的 <head> 部分,讓瀏覽器先去下載外部資源(CSS、JavaScript 之類),還可以做一些 Prefetch 之類,讓瀏覽器不要閑著等數據。對于需要用到 DOM 元素的 JavaScript,可以靈活使用 defer 屬性以減少代碼量、下載數據量。
要使網頁的訪問速度最快,用什么語言開發最好?
前端:原生 JavaScript ES6,這是唯一選擇。盡量不要使用大型的前端框架(動不動給你打包一個 1M 的 bundle 是很嚇人的。而且頁面變化不復雜的話,這些框架的虛擬 DOM 帶來的性能提升還彌補不了大量代碼帶來的性能損失,得不償失。所以請在絕對必要的情況下再去使用這些東西。)
后端:看你具體的業務場景了,各種語言應對各種不同的場景,沒有一家獨大一說(不然讓其他語言怎么活)。Java、Go、Python、C#.Net、Node.JS、Ruby、PHP……或者使用 C/C++ 來寫后端也是完全可以的,靈活實現不同場景[手動滑稽]。(你要愿意,直接寫匯編都可以)
總的來說,常規優化做好了,根據實際業務場景來選擇語言技術棧,才是提升訪問速度的關鍵辦法。
(或者能給廣大用戶提一下物理網絡速度也好)