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
  • 示例項目結構 在 Visual Studio 中創建一個 WinForms 應用程式後,項目結構如下所示: MyWinFormsApp/ │ ├───Properties/ │ └───Settings.settings │ ├───bin/ │ ├───Debug/ │ └───Release/ ...
  • [STAThread] 特性用於需要與 COM 組件交互的應用程式,尤其是依賴單線程模型(如 Windows Forms 應用程式)的組件。在 STA 模式下,線程擁有自己的消息迴圈,這對於處理用戶界面和某些 COM 組件是必要的。 [STAThread] static void Main(stri ...
  • 在WinForm中使用全局異常捕獲處理 在WinForm應用程式中,全局異常捕獲是確保程式穩定性的關鍵。通過在Program類的Main方法中設置全局異常處理,可以有效地捕獲並處理未預見的異常,從而避免程式崩潰。 註冊全局異常事件 [STAThread] static void Main() { / ...
  • 前言 給大家推薦一款開源的 Winform 控制項庫,可以幫助我們開發更加美觀、漂亮的 WinForm 界面。 項目介紹 SunnyUI.NET 是一個基於 .NET Framework 4.0+、.NET 6、.NET 7 和 .NET 8 的 WinForm 開源控制項庫,同時也提供了工具類庫、擴展 ...
  • 說明 該文章是屬於OverallAuth2.0系列文章,每周更新一篇該系列文章(從0到1完成系統開發)。 該系統文章,我會儘量說的非常詳細,做到不管新手、老手都能看懂。 說明:OverallAuth2.0 是一個簡單、易懂、功能強大的許可權+可視化流程管理系統。 有興趣的朋友,請關註我吧(*^▽^*) ...
  • 一、下載安裝 1.下載git 必須先下載並安裝git,再TortoiseGit下載安裝 git安裝參考教程:https://blog.csdn.net/mukes/article/details/115693833 2.TortoiseGit下載與安裝 TortoiseGit,Git客戶端,32/6 ...
  • 前言 在項目開發過程中,理解數據結構和演算法如同掌握蓋房子的秘訣。演算法不僅能幫助我們編寫高效、優質的代碼,還能解決項目中遇到的各種難題。 給大家推薦一個支持C#的開源免費、新手友好的數據結構與演算法入門教程:Hello演算法。 項目介紹 《Hello Algo》是一本開源免費、新手友好的數據結構與演算法入門 ...
  • 1.生成單個Proto.bat內容 @rem Copyright 2016, Google Inc. @rem All rights reserved. @rem @rem Redistribution and use in source and binary forms, with or with ...
  • 一:背景 1. 講故事 前段時間有位朋友找到我,說他的窗體程式在客戶這邊出現了卡死,讓我幫忙看下怎麼回事?dump也生成了,既然有dump了那就上 windbg 分析吧。 二:WinDbg 分析 1. 為什麼會卡死 窗體程式的卡死,入口門檻很低,後續往下分析就不一定了,不管怎麼說先用 !clrsta ...
  • 前言 人工智慧時代,人臉識別技術已成為安全驗證、身份識別和用戶交互的關鍵工具。 給大家推薦一款.NET 開源提供了強大的人臉識別 API,工具不僅易於集成,還具備高效處理能力。 本文將介紹一款如何利用這些API,為我們的項目添加智能識別的亮點。 項目介紹 GitHub 上擁有 1.2k 星標的 C# ...