前端接口設計

前面的話

  先後端開發要分離。可是,具體哪些地方須要約定呢?如何制定約定規則呢?制定後如何應用呢?本文將詳細介紹這些問題相關的工程實踐方法——接口設計html

 

概述

  在協做流程的博文中,咱們瞭解了一個Web系統的體系架構,以及前端與後端交互的整個流程,接下來簡單回顧,並進行相應的規則約定前端

  當客戶端向服務器端發送一個請求時,服務器端的Web系統收到該請求,經過分析來進行一系列的操做,包括蒐集全部的數據模型,一般這個過程會伴隨有數據庫操做;數據蒐集完成後,Web系統根據請求信息,選擇合適的模板來響應Web客戶端數據庫

  這時,問題來了,用戶請求的地址須要經過什麼樣的約定規則映射到視圖模板上呢?後端

  Web系統選擇了合適的模板以後,將蒐集的數據模型按照必定的約定規則,交給模板引擎進行頁面結構的組裝服務器

  這時,問題又來了,不一樣的模板須要經過什麼樣的約定規則與數據模型進行匹配呢?前端工程師

  有了視圖模板和數據模型後,Web系統就能夠組裝出客戶端所須要的頁面結構,而後再將這個頁面結構返回給客戶端。客戶端拿到返回的數據模型後,根據必定的規則繪製頁面,同時展現給用戶架構

  實際上,頁面只包含了一部分數據,還有一部分數據須要經過另外的接口來載入。接下來,客戶端根據一系列的約定規則發起數據請求異步

  問題來了,一個頁面須要包含哪些數據載入的請求呢?換句話說,一個頁面中,哪些數據須要經過異步請求載入進來的呢?工具

  Web系統收到數據請求以後,根據一系列的數據操做,篩選出約定的數據模型學習

  最後的問題,一個數據請求須要什麼樣的約定規則來與數據模型進行匹配呢?

  Web系統蒐集到數據以後,按照約定規則組裝出數據模型,返回給客戶端。客戶端將數據模型按照必定的結構展現給用戶

  在以上的交互流程中,咱們能夠提取出4個關鍵的元素:URL、TEMPLATE、API、MODEL

  URL:頁面訪問地址或者稱爲頁面標識

  Template:一個頁面對應的分離了數據模型以後的頁面結構,後續能夠根據不一樣的數據模型展示不一樣的信息

  API:頁面用於載入數據的異步請求的接口

  Model:數據模型(包含組裝頁面模板的模型和異步請求返回的數據模型)

  若是要對先後端進行分離,須要進行如下一些規則約定

  一、URL與模板的約定,約定了頁面須要映射到哪些視圖模板上去

  二、URL與異步接口的約定,約定了頁面有哪些數據是經過異步接口載入進來的

  三、模板和數據模型的約定,約定了視圖模板與什麼樣的數據模型相對應,以及數據模型的格式和類型等信息

  四、異步接口和數據模型的約定,約定了異步接口的輸入輸出信息

  頁面入口規範用來處理URL與模板,及URL與接口之間的約定

  同步數據規範用來處理模板和數據模型的約定

  異步接口規範用來處理異步接口和數據模型的約定

 

接口規範

  經過前面的內容,咱們大體地瞭解了頁面入口規範、同步數據規範和異步接口規範這三個基礎規範,其中每一個規範也會定義出若干規則約定來指導先後端工程師的具體實施

  接下來,詳細介紹每一個規範包含哪些約定規則,以及這些約定規則是如何制定的,以網易雲音樂的下面這個頁面爲例進行說明

【頁面入口規範】

  頁面入口規範首先要對頁面進行說明,包含一些用來描述頁面基本信息、URL攜帶參數說明、頁面可能會用到的視圖模板的對應關係、頁面可能會發出的異步請求的異步載入數據的接口的詳細信息。簡而言之,能夠總結爲如下四點

1、基本信息
2、輸入參數
3、模板列表
4、接口列表

  下圖是頁面入口規範中,某個頁面所定義的規則約定的範例

  首先,前、後端工程師須要根據交互原型對系統進行頁面拆分。頁面拆分的原則主要根據先後端功能實現的方式(好比單頁或多頁)來權衡

  基本信息包括訪問地址和頁面描述,訪問地址能夠不攜帶參數,頁面描述說明了頁面的用途或功能

  輸入參數主要用來講明訪問地址在請求時能夠攜帶的參數,包括參數名稱、參數類型和參數描述

  異常跳轉用於系統全局異常處理,該部分並非必須的

  模板列表須要列舉出當前頁面涉及到的相關視圖模板,其中必須包含一個默認的視圖模板。若是正常顯示和異常顯示的頁面差別較大值時,還須要包含異常模板,或其餘模板

  接口列表須要定義出頁面用到的全部異步接口列表,要根據交互原型及後端數據的操做開銷來進行權衡。通常來講,對於SEO的要求較低,或頁面的相關性不高,或者已經存在數據載入接口,或者數據收集時須要長時間的開銷,能夠考慮用異步的方式來載入數據。圖片的接口列表包括歌曲列表、相關節目、收藏節目和評論列表

【同步數據規範】

  同步數據規範包含用於對模板的詳細說明的基本信息、對數據模型的說明(名稱、類型等信息),若是視圖模板須要後端注入接口,也須要包含注入接口的信息。簡而言之,能夠總結爲如下三點

1、基本信息
2、預填數據
3、注入接口

  下圖是同步數據規範中,某個模板所定義的規則約定的範例

  首先,是模板基本信息部分,描述了模板文件的物理位置,及模板文件的功能等

  預填數據的信息就是注入到模板中的數據模型,包括模板所用到的全部數據的詳細信息,不只包含全局數據,也包含當前頁面的數據模型。其中,對數據的說明要包含數據名稱、數據類型和數據描述等信息。對於複雜的數據類型,還需展開介紹其內部的數據模型的結構

  注入接口主要定義接口的輸入輸出信息,但注入接口並非每一個模板都必須的,大部分模板不須要注入接口

【異步接口規範】

  異步接口規範包含如下三點

1、基本信息
2、輸入數據
3、輸出結果

  下圖是異步接口規範中,某個接口所定義的規則約定的範例

  首先,異步接口基本信息部分,包括接口的請求方式、接口地址、接口描述等,圖中的接口地址不須要攜帶查詢參數

  輸入數據(REST和查詢參數)須要包含數據名稱、數據類型和數據描述等信息

  輸出結果(通用部分和結果集)主要定義的是返回給客戶端的數據模型的結構,須要說明每一個字段的名稱、類型和描述等信息。對於複雜的數據類型,還需展開介紹其內部的數據模型的結構

 

規範應用

  在系統設計階段,定製了三個規則約定規範。在進入開發階段,前、後端工程師如何應用這些規範來完成系統中的設計、開發、測試等工做呢?

  一、根據頁面入口規範來構建項目結構

  頁面入口規範定義了每一個頁面對應的模板文件,能夠導出配置信息,而後構建項目的目錄結構(包含前端的目錄結構和後端的模板結構)

  根據配置文件生成目錄的過程可使用自動化工具來完成

  二、根據同步數據規範模擬同步數據

  同步數據規範定義了每一個模板定義的同步數據信息,能夠導出模擬數據的配置文件,而後生成同步的模擬數據的文件

  根據配置文件生成模擬數據的過程可使用自動化工具來完成

  三、根據異步接口規範模擬異步數據

  異步接口規範定義了每一個接口的輸入輸出,能夠導出接口與返回結果的模擬數據的匹配的配置信息,而後生成接口對應的模擬數據的文件

  根據配置文件生成模擬數據的過程可使用自動化工具來完成

  在本地開發時,經過模擬數據的形式將前端相關的內容與後端獨立出來,接下來前端工程師就能夠獨立開發

 

本地開發

  進入開發階段,通常要怎樣來搭建前端開發環境呢?前端開發環境主要包含兩部分:一部分是本地模擬服務器、另外一部分是本地代理

  客戶端發出的請求首先會被本地模擬服務器攔截,本地模擬服務器根據必定的配置規則,直接將請求返回給Web客戶端。若是頁面存在某些數據須要異步載入,這個請求會被本地代理攔截,本地代理根據模擬數據的映射規則,直接將生成的模擬數據返回給Web客戶端

  前端本地開發環境搭建完成以後,全部的客戶端與服務器端的交互都會被本地模擬服務器或本地代理攔截,這樣就將先後端開發作了完全的分離

【本地模擬服務器】

  本地環境中的本地模擬服務器在接收到Web客戶端發來的請求時,首先會根據處理規則進行匹配,若是匹配,則請求被攔截

  根據規範導出的配置信息一樣會被本地模擬服務器所使用。經過配置信息,本地模擬服務器能夠識別出這些請求所對應的模板文件和模擬數據所在的位置,從而整合模板文件和模擬數據,生成一個HTML頁面結構代碼,返回給Web客戶端

【本地代理】

  本地環境中的本地代理在接收到Web客戶端發來的異步請求時,會攔截該請求。根據規範導出的配置信息一樣會被本地代理所使用,經過配置信息,本地代理找出請求對應的模擬數據,把數據轉換成JSON數據格式或其餘定義好的數據格式,返回給Web客戶端

  若是請求未匹配,則該異步請求可能會訪問遠程服務器

【聯調】

  經過本地環境的搭建獨立了先後端開發的過程。先後端開發工做完成以後,須要進行聯調

  先後端聯調須要去除本地環境,這時Web客戶端發出的請求就能夠順利到達服務器端

  在實際開發中只須要對配置文件進行調整既可,以控制哪些請求須要被本地服務器或代理攔截,哪些須要使用遠程服務器

 

最後

  本文是蔡劍飛、鄭海波老師的《產品前端架構》課程中《接口設計》章節的學習記錄

相關文章
相關標籤/搜索