web開發漫談

来源:http://www.cnblogs.com/submerge/archive/2016/03/07/5251497.html
-Advertisement-
Play Games

本文同步至微信公眾號http://mp.weixin.qq.com/s?__biz=MzAxMzgwNDU3Mg==&mid=401950045&idx=1&sn=cec056802bb52f909554691d0427f4f0#rd 對後續文章感興趣的可以掃碼關註哈 對於一個非技術人員比如說pm,


本文同步至微信公眾號http://mp.weixin.qq.com/s?__biz=MzAxMzgwNDU3Mg==&mid=401950045&idx=1&sn=cec056802bb52f909554691d0427f4f0#rd

對後續文章感興趣的可以掃碼關註哈

對於一個非技術人員比如說pm,網站編輯等通常遇到一些問題,不知道是該找前端解決還是應該找後端。也有一些功能,既可以放到前端來做,也可以放到後端來做。這樣看似一個模糊不清的問題,然而考慮到後續的維護成本,頁面性能時,結論往往是明確的。

    一個web應用在開發模式上通常劃分為前端和後端。本文基於此,淺償輒止的聊聊前後端開發分別都是做什麼的,以為它們之間如何分工當然還有自己的工作觀。希望對非技術人員或初學web開發的同學有所幫助也希望大牛們不要見笑。。

    通俗地說,後端是處理數據的,前端是展示數據的。例如,當我們訪問一個已展示性為主的站點時,首先會在瀏覽器地址欄輸入該站點的網址。這是瀏覽器會通過DNS功能變數名稱解析器獲取到該網址對應的站點的ip地址,然後瀏覽器向對應的web伺服器發送請求(http),web伺服器響應該請求,從DB中獲取數據,並返回給瀏覽器。如下圖所示:紅框圈出來的就是後端做的事情,響應瀏覽器發送的http請求,操作資料庫,處理數據,然後返回。瀏覽器端也就是前端在拿到數據之後,對數據進行展現。這也是通常的以展示性為主的web應用的工作流程。(http為web開發的基石,不清楚的,google之)。

 也就是前端關註的是用戶體驗。真實的還原設計稿,保證web動畫的流暢性,在視覺和交互上給用戶一種清爽、簡潔舒適的感覺。這也是我對於一個好的設計,好的設計稿的理解。用戶界面並不是越炫酷就越好的。要追求極致簡潔,返璞歸真。要做到簡單,有時候,往往更艱難。。而數據操作,併發量,許可權控制等都是後端關註的。

    在對前端,後端有了一個初步的印象之後,接下來,實際開發中前後端是怎麼協作的呢?一種方式是前後端開發之前預先定義好數據格式及變數的命名等,然後前端根據設計稿和預先的約定編寫頁面模板,將模板開發好之後,發給後端程式員。後端在拿到模板之後,操作資料庫,用獲取到的數據渲染模板生成html頁面返回給瀏覽器。另一種方式是,前後端預先定義好數據格式,然後把數據以json或jsonp形式的介面暴露給前端,然後前端獲取到數據之後,在前端進行模板的渲染。具體該使用哪一種方式,或是兩種方式都使用,就需要根據具體的業務場景具體分析了。

    按照目前的開發模式,目前還無法完全的做到前後端分離。好的應用也都是在前端後端及設計師通力配合的結果。一方面為了降低工作中的溝通成本另一方面從提升工程師自身的開發素質從整體的全局的角度上認識web開發而不是前端開發或者後端開發而言,我們都不應該只局限於前端或後端。前端工程師也應該去瞭解些後端的知識,後端也應該去學一些前端的知識。在保證知識廣度的前提下去拓展知識的深度。

    最後,正如文章開頭說言,有一些功能,既可以放到前端來做,也可以放到後端來做。不同的實現方式,它的後期的維護成本以及性能往往不盡相同,有時候差別還很大。有的時候,我建議有些功能放到後端完成,並不是想減輕自己的工作量,而是考慮到這些因素之後得出的一個結論。開發當中,不可避免的會碰到一些問題、困難。我們不能因為難做而繞道採用兩一種次一些的實現方案。正是因為有一些問題有困難,才有我們存在的價值。當然,一切的一切都是建立在我們每個程式員自身的基礎素質之上的。。


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 在設計的過程中第一步就是先排版構建框架,後利用CSS對各個塊進行定位。不過各個樣式的id和class博客園本身已經定義好了,我們可以在設置面板中勾選禁用模板預設CSS”覆選框。然後刷新博客首頁查看源碼,將代碼copy到dw上修改樣式。最後將自己修改滿意好的css樣式貼到“管理”-“博客設置”中“通過
  • 1.Ajax 1.1.Ajax簡介 Ajax簡介這一部分我們主要是談一下ajax的起源,ajax是什麼?因為這些是跟技術無關的。所以,大多細節都是一筆帶過。 Ajax的起源? Ajax一詞源於2005年 Jesse James Garrett發表的一篇題為"Ajax:A new Approach t
  • 閉包的概念: 在電腦科學中,閉包(也稱詞法閉包或函數閉包)是指一個函數或函數的引用,與一個引用環境綁定在一起。這個引用環境是一個存儲該函數每一個非局部變數(也叫自由變數的表)。已暈^^ 閉包,不同於一般的函數,它允許一個函數在立即詞法作用域外調用時,仍然訪問非本地變數 ——from維基百科 閉包其
  • 背景:在前端開發中,有時會為頁面綁定resize事件,或為一個頁面元素拖拽事件(其核心就是綁定mousemove)在一個正常操作中也有可能在一個短時間內觸發非常多次事件綁定程式,而DOM操作是很消耗性能的,如果為這些事件綁定一些操作DOM節點的操作的話就會引發大量的計算,在用戶看來頁面可能就一時間沒
  • 講述了javascript主要由ECMAScript、DOM、BOM組成
  • 問題1: 使用連續賦值後面的變數會成為全局對象的一個屬性,並且這個屬性可以通過delete刪除。 原因:賦值語句是從右往左執行的,我們將10賦值給了c,但是c此時還聲明,接著把c的返回值賦值給了b,但是b也還沒有聲明,最後賦值給了a此時a有聲明,所以a就是局部變數。 var a = b = c =
  • (第一篇博文) 今天在一個交流群里見他們無聊,然後找到之前收藏的一些c語言題目放出去想讓他們做,結果反倒是自己不會做,於是花了很多時間去想。 原題:張三說李四在說謊,李四說王五在說謊,王五說張三和李四都在說謊。現在問:這三人中到底誰說的是真話,誰說的是假話? 其實問題本身並不難,只是一開始想多了,陷
  • 瞭解RegExp類型: ECMAScript通過RegExp類型來支持正則表達式。 var expression=/pattern/flags; 正則表達式的模式(pattern)部分: 可以是任何簡單或複雜的正則表達式,可以包含字元類,限定符,分組,向前查找,反向引用。 關於正則表達式中各種特殊字
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...