主頁 >  其他 > ?? 前端如何與后端對接?當年差點和后端同學打起來了!

?? 前端如何與后端對接?當年差點和后端同學打起來了!

2021-10-13 07:41:23 其他

閱讀須知

本文不談及老技術(畢竟沒有經歷那個年代,emmm),只談一些個人體會,如果會有部分內容與你想法不同,以你為準,

大學期間對于前端的學習

對于我雙非本科小菜雞來說,最開始入門的語言是 C 語言,之后大二大三就以 Java 語言為主,后面了解了一下其它學校同學學習的課程,好像大部分也是以 Java 為主,不過有的學校會教學一些 Web 前端的課程,這個是挺好的,

我是僅僅大二學了一本 《Web基礎入門指南》書籍(可能書名也不叫這個名字),內容也是比較基礎,學習一些 html 標簽,css 語法也學的很少,

課程快要結束的時候,老師給我們提及了 ajax 以及異步請求相關的概念,逐漸的有了前后端的概念,最后的作業就是完成一個課程設計,也是比較經典的管理系統,要有資料庫連接等等,我們當時做的就是比較經典的「圖書管理系統」了,

大學期間做的專案

大二學習前端的知識不是很多,后面來到了大三,學習了 JavaEE 以及軟體工程的課程,當時這兩門學科老師進行了聯合,要求我們分組完成一個大的課程設計,這個也是作為期末考試的重點比例分數,可以說如果這個專案分數不高的話,兩門都得掛了,

不過平常與大佬接觸蠻多,所以就和大佬們組了隊,其中就有一位小學就學習過編程的同學,對于大學才剛接觸編程的我來說經驗還是有許多差距,

當時軟體工程老師給我們提及了,前端框架可以考慮使用 Vue 或者 React 框架,那時候我最開始接觸這兩個詞,然后組內大佬就開始研究這個框架了,讓我佩服學習能力真的好強,一周內就開始撰寫頁面了,

而后端當時提及的就是 SSM,如果不太熟悉的小組也可以使用 SSH,我們當時就采用了 SSM 框架,并且采用前后端分離的模式開發,

后端也是一位大佬,當時就引入了 Swagger UI

在這里參考官方的介紹:

Swagger UI allows anyone — be it your development team or your end consumers — to visualize and interact with the API’s resources without having any of the implementation logic in place. It’s automatically generated from your OpenAPI (formerly known as Swagger) Specification, with the visual documentation making it easy for back end implementation and client side consumption.

來自谷歌翻譯: Swagger UI 允許任何人——無論是你的開發團隊還是你的最終消費者——在沒有任何實作邏輯的情況下可視化 API 資源并與之互動, 它是根據您的 OpenAPI(以前稱為 Swagger)規范自動生成的,帶有可視化檔案,便于后端實作和客戶端使用,

當時做的效果就是如官方圖片一樣,提供了一種可視化的效果,這樣前端同學就不用這么花費很多溝通上的成本,直接看圖一目了然,

這個當時也是對我的認知有了一些變化,就覺得大佬們真強,對于這個技術廣度感到了不足,給大佬們點贊!

最后我們組確確實實拿到了班級第一名,但是程序中前后端的兩位大佬也出現過溝通問題,也吵過,就差打起來了…

之后,有這段做專案的經歷加上自己也系統學習了前端相關的知識,春招找到了一份實習,接下來就來說說實習作業的真物體驗如何,

一次實習作業的真物體驗

學校時期與大佬們接觸,自己對于技術方面也更加熱愛了,同時接觸的領域也更廣了,比如開始自己去學習 Vue 和 React 框架,

但是帶著學校的思維第一次進入了一家公司實習,當時想的是應該前后端也會按照學校那會的方式來做,而實際情況缺差別有點大,

實習那會,有一批的實習生,我應該算是前端的一個主力了,當時討論的時候就說后端寫好介面檔案,可以考慮使用 Swagger UI(因為上文提及過,我大學期間就有使用過,這個還挺好用的)

不過當我提及 Swagger UI 時,貌似就一位后端同學知道,其它同學好像沒怎么了解,

因為了解的不夠充足,這個 Swagger UI 就放棄考慮了,最開始是沒有一個規范的介面檔案的,告訴我的介面也是比較「簡單」,至于這個介面能不能用我還要自己去請求一下,然后測驗一下?

當時花費了很多的溝通成本,后來由帶我們的組長給后端同學開了一次會議,開始整改規范上的問題,要求寫好一份完整的介面檔案,之后我就輕松許多了,不需要我做的時候還得和介面負責人溝通許久,

不過,后來又出現了問題,雖然檔案的內容是比較詳細了,但是因為介面會比較多,所以每個人可能就會分配一下,負責某個模塊的幾個介面,就在這里出了點小問題,

比如前端取值的話,有些介面是通過 res.data.xxx 就可以獲取 xxx 屬性的值了,原本我以為大家都會用這種規范上來做,但是之后寫其它頁面的時候我發現 res.data 取不到值了,充滿疑惑的我又開始了除錯,在控制臺列印了一下,原來我得需要 res.data.data.xxx 才能獲取那個值,看完之后我哭了呀,

于是乎,我又得找后端同學商量一下了…

作為一起加入的實習同學,出現問題也是很正常,遇到問題去解決問題就好了,

要是脾氣暴躁的前端 er,估計會和后端開懟了,甚至打起來了(開個玩笑哈,一般不會有這種情況的哈,打贏了坐牢,打輸了住院…)

前端與后端的對接

之前有一位小伙伴問我前端與后端對接需要掌握哪些技術堆疊,該怎么對接等等,

首先,是技術堆疊方面,其實對于前端來說,了解一下「RESTful API」就好了,一般后端同學回傳的介面型別和這個設計差不多,可能公司要求會有點差別,

https://www.ruanyifeng.com/blog/2018/10/restful-api-best-practices.html

在現在主流前后端分離開發模式下,前端同學就負責撰寫界面實作,后端同學提供 API 介面,這樣減少一些溝通成本,

在過去前后端打架的時代,我覺得你寫的介面不行,而你又覺得我寫的頁面太簡單了,覺得我技術一般,然后就打起來了…

咳咳,題外話題外話,至少我是沒有經歷過那個時代,真打沒打起來我還沒實際見過,但是網上見過,見過真實的產品和開發人員對噴的情況,

而至于怎么對接的話,作為前端來說的話,如果后端同學按照公司規范提供介面檔案或者一些可視化的介面,這樣是非常好的,自己也會輕松很多,省去一些溝通的成本,

但實際情況往往與理想狀態還是有點差距,有時候后端同學回傳的介面可能會有一些問題,這也很正常,誰還不經歷個 bug 呢,作為前端的我們來說,不要抱怨,和平交流,

因為這個功能是這位后端同學給你提供介面,說不定之后的一些功能你們還需要合作,因此建立良好的合作關系還是很重要的,

結尾

本篇文章就到此結束啦,的文章可不僅僅只有知識類分享哈,喜歡我的文章可以點點關注,下次我們還能遇見,許久沒有求點贊了,這次能要一個「點贊」嗎,各位大佬們,球球了~

我是「一百個Chocolate」,一位獅子座的程式員,帶著熱情面對生活,好好生活,好好學習,

2021 年還有一個季度,我們一起加油!

轉載請註明出處,本文鏈接:https://www.uj5u.com/qita/310515.html

標籤:其他

上一篇:技術水平低,就這還敢寫自動化專案實戰經驗豐富?

下一篇:程式猿之國慶有空嗎?

標籤雲
其他(157675) Python(38076) JavaScript(25376) Java(17977) C(15215) 區塊鏈(8255) C#(7972) AI(7469) 爪哇(7425) MySQL(7132) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5869) 数组(5741) R(5409) Linux(5327) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4554) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2429) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1958) Web開發(1951) python-3.x(1918) HtmlCss(1915) 弹簧靴(1913) C++(1909) xml(1889) PostgreSQL(1872) .NETCore(1853) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • 網閘典型架構簡述

    網閘架構一般分為兩種:三主機的三系統架構網閘和雙主機的2+1架構網閘。 三主機架構分別為內端機、外端機和仲裁機。三機無論從軟體和硬體上均各自獨立。首先從硬體上來看,三機都用各自獨立的主板、記憶體及存盤設備。從軟體上來看,三機有各自獨立的作業系統。這樣能達到完全的三機獨立。對于“2+1”系統,“2”分為 ......

    uj5u.com 2020-09-10 02:00:44 more
  • 如何從xshell上傳檔案到centos linux虛擬機里

    如何從xshell上傳檔案到centos linux虛擬機里及:虛擬機CentOs下執行 yum -y install lrzsz命令,出現錯誤:鏡像無法找到軟體包 前言 一、安裝lrzsz步驟 二、上傳檔案 三、遇到的問題及解決方案 總結 前言 提示:其實很簡單,往虛擬機上安裝一個上傳檔案的工具 ......

    uj5u.com 2020-09-10 02:00:47 more
  • 一、SQLMAP入門

    一、SQLMAP入門 1、判斷是否存在注入 sqlmap.py -u 網址/id=1 id=1不可缺少。當注入點后面的引數大于兩個時。需要加雙引號, sqlmap.py -u "網址/id=1&uid=1" 2、判斷文本中的請求是否存在注入 從文本中加載http請求,SQLMAP可以從一個文本檔案中 ......

    uj5u.com 2020-09-10 02:00:50 more
  • Metasploit 簡單使用教程

    metasploit 簡單使用教程 浩先生, 2020-08-28 16:18:25 分類專欄: kail 網路安全 linux 文章標簽: linux資訊安全 編輯 著作權 metasploit 使用教程 前言 一、Metasploit是什么? 二、準備作業 三、具體步驟 前言 Msfconsole ......

    uj5u.com 2020-09-10 02:00:53 more
  • 游戲逆向之驅動層與用戶層通訊

    驅動層代碼: #pragma once #include <ntifs.h> #define add_code CTL_CODE(FILE_DEVICE_UNKNOWN,0x800,METHOD_BUFFERED,FILE_ANY_ACCESS) /* 更多游戲逆向視頻www.yxfzedu.com ......

    uj5u.com 2020-09-10 02:00:56 more
  • 北斗電力時鐘(北斗授時服務器)讓網路資料更精準

    北斗電力時鐘(北斗授時服務器)讓網路資料更精準 北斗電力時鐘(北斗授時服務器)讓網路資料更精準 京準電子科技官微——ahjzsz 近幾年,資訊技術的得了快速發展,互聯網在逐漸普及,其在人們生活和生產中都得到了廣泛應用,并且取得了不錯的應用效果。計算機網路資訊在電力系統中的應用,一方面使電力系統的運行 ......

    uj5u.com 2020-09-10 02:01:03 more
  • 【CTF】CTFHub 技能樹 彩蛋 writeup

    ?碎碎念 CTFHub:https://www.ctfhub.com/ 筆者入門CTF時時剛開始刷的是bugku的舊平臺,后來才有了CTFHub。 感覺不論是網頁UI設計,還是題目質量,賽事跟蹤,工具軟體都做得很不錯。 而且因為獨到的金幣制度的確讓人有一種想去刷題賺金幣的感覺。 個人還是非常喜歡這個 ......

    uj5u.com 2020-09-10 02:04:05 more
  • 02windows基礎操作

    我學到了一下幾點 Windows系統目錄結構與滲透的作用 常見Windows的服務詳解 Windows埠詳解 常用的Windows注冊表詳解 hacker DOS命令詳解(net user / type /md /rd/ dir /cd /net use copy、批處理 等) 利用dos命令制作 ......

    uj5u.com 2020-09-10 02:04:18 more
  • 03.Linux基礎操作

    我學到了以下幾點 01Linux系統介紹02系統安裝,密碼啊破解03Linux常用命令04LAMP 01LINUX windows: win03 8 12 16 19 配置不繁瑣 Linux:redhat,centos(紅帽社區版),Ubuntu server,suse unix:金融機構,證券,銀 ......

    uj5u.com 2020-09-10 02:04:30 more
  • 05HTML

    01HTML介紹 02頭部標簽講解03基礎標簽講解04表單標簽講解 HTML前段語言 js1.了解代碼2.根據代碼 懂得挖掘漏洞 (POST注入/XSS漏洞上傳)3.黑帽seo 白帽seo 客戶網站被黑帽植入劫持代碼如何處理4.熟悉html表單 <html><head><title>TDK標題,描述 ......

    uj5u.com 2020-09-10 02:04:36 more
最新发布
  • 2023年最新微信小程式抓包教程

    01 開門見山 隔一個月發一篇文章,不過分。 首先回顧一下《微信系結手機號資料庫被脫庫事件》,我也是第一時間得知了這個訊息,然后跟蹤了整件事情的經過。下面是這起事件的相關截圖以及近日流出的一萬條資料樣本: 個人認為這件事也沒什么,還不如關注一下之前45億快遞資料查詢渠道疑似在近日復活的訊息。 訊息是 ......

    uj5u.com 2023-04-20 08:48:24 more
  • web3 產品介紹:metamask 錢包 使用最多的瀏覽器插件錢包

    Metamask錢包是一種基于區塊鏈技術的數字貨幣錢包,它允許用戶在安全、便捷的環境下管理自己的加密資產。Metamask錢包是以太坊生態系統中最流行的錢包之一,它具有易于使用、安全性高和功能強大等優點。 本文將詳細介紹Metamask錢包的功能和使用方法。 一、 Metamask錢包的功能 數字資 ......

    uj5u.com 2023-04-20 08:47:46 more
  • vulnhub_Earth

    前言 靶機地址->>>vulnhub_Earth 攻擊機ip:192.168.20.121 靶機ip:192.168.20.122 參考文章 https://www.cnblogs.com/Jing-X/archive/2022/04/03/16097695.html https://www.cnb ......

    uj5u.com 2023-04-20 07:46:20 more
  • 從4k到42k,軟體測驗工程師的漲薪史,給我看哭了

    清明節一過,盲猜大家已經無心上班,在數著日子準備過五一,但一想到銀行卡里的余額……瞬間心情就不美麗了。最近,2023年高校畢業生就業調查顯示,本科畢業月平均起薪為5825元。調查一出,便有很多同學表示自己又被平均了。看著這一資料,不免讓人想到前不久中國青年報的一項調查:近六成大學生認為畢業10年內會 ......

    uj5u.com 2023-04-20 07:44:00 more
  • 最新版本 Stable Diffusion 開源 AI 繪畫工具之中文自動提詞篇

    🎈 標簽生成器 由于輸入正向提示詞 prompt 和反向提示詞 negative prompt 都是使用英文,所以對學習母語的我們非常不友好 使用網址:https://tinygeeker.github.io/p/ai-prompt-generator 這個網址是為了讓大家在使用 AI 繪畫的時候 ......

    uj5u.com 2023-04-20 07:43:36 more
  • 漫談前端自動化測驗演進之路及測驗工具分析

    隨著前端技術的不斷發展和應用程式的日益復雜,前端自動化測驗也在不斷演進。隨著 Web 應用程式變得越來越復雜,自動化測驗的需求也越來越高。如今,自動化測驗已經成為 Web 應用程式開發程序中不可或缺的一部分,它們可以幫助開發人員更快地發現和修復錯誤,提高應用程式的性能和可靠性。 ......

    uj5u.com 2023-04-20 07:43:16 more
  • CANN開發實踐:4個DVPP記憶體問題的典型案例解讀

    摘要:由于DVPP媒體資料處理功能對存放輸入、輸出資料的記憶體有更高的要求(例如,記憶體首地址128位元組對齊),因此需呼叫專用的記憶體申請介面,那么本期就分享幾個關于DVPP記憶體問題的典型案例,并給出原因分析及解決方法。 本文分享自華為云社區《FAQ_DVPP記憶體問題案例》,作者:昇騰CANN。 DVPP ......

    uj5u.com 2023-04-20 07:43:03 more
  • msf學習

    msf學習 以kali自帶的msf為例 一、msf核心模塊與功能 msf模塊都放在/usr/share/metasploit-framework/modules目錄下 1、auxiliary 輔助模塊,輔助滲透(埠掃描、登錄密碼爆破、漏洞驗證等) 2、encoders 編碼器模塊,主要包含各種編碼 ......

    uj5u.com 2023-04-20 07:42:59 more
  • Halcon軟體安裝與界面簡介

    1. 下載Halcon17版本到到本地 2. 雙擊安裝包后 3. 步驟如下 1.2 Halcon軟體安裝 界面分為四大塊 1. Halcon的五個助手 1) 影像采集助手:與相機連接,設定相機引數,采集影像 2) 標定助手:九點標定或是其它的標定,生成標定檔案及內參外參,可以將像素單位轉換為長度單位 ......

    uj5u.com 2023-04-20 07:42:17 more
  • 在MacOS下使用Unity3D開發游戲

    第一次發博客,先發一下我的游戲開發環境吧。 去年2月份買了一臺MacBookPro2021 M1pro(以下簡稱mbp),這一年來一直在用mbp開發游戲。我大致分享一下我的開發工具以及使用體驗。 1、Unity 官網鏈接: https://unity.cn/releases 我一般使用的Apple ......

    uj5u.com 2023-04-20 07:40:19 more