Vue.JS 聯系人單頁應用(五) - 從前端到后端

前言

在前面四篇文章中,我們搭建了一個純粹的客戶端應用,數據保存在客戶端內存中。同時,對于表格和表單的自動化,進行了一些嘗試。
正常的生產環境中,數據通常存放在數據服務器上,前端需要完成的工作還包括,訪問后端API接口,實現真正的CRUD。而實現此功能的一大利器則是AJAX。
這篇文章是從前端到后端的一個分界線,因此我們將盡量減少復雜度,希望讓前端和后端都能看懂,你的同伴需要什么。

Axios 介紹

Axios 開源代碼在 Github

Promise based HTTP client for the browser and node.js
運行在瀏覽器及node.js上,基于Promise的HTTP 客戶端工具

項目改造

前端改造
  1. HTML
    受益于Vue的組件化編程,我們無需對HTML文件進行任何修改,當然如果你還沒有加入Axios的引用,那么此時需要在HTML中添加Axios引用。
<script type="text/javascript" src="https://unpkg.com/axios/dist/axios.min.js"></script>
  1. Javascript
data: {
    title: '聯系人',
    columns: [{
      name: 'id',
      iskey: true
    }, {
      name: 'name',
      caption: '姓名',
    }, {
      name: 'birthday',
      caption: "出生日期",
      type: 'date'
    }, {
      name: 'phone',
      caption: '電話'
    }],
    row: {
      id: 0,
      name: '',
      birthday: '',
      phone: ''
    },
    list: [{
      id: 1,
      name: '深圳有事Q我',
      birthday: '2000-09-10',
      phone: '2345678'
    }, {
      id: 2,
      name: '上海沒事別煩我',
      birthday: '1980-01-22',
      phone: '1293587023'
    }, {
      id: 3,
      name: '北京藍色醫生',
      birthday: '1990-02-01',
      phone: '1332345876'
    }]
  },
-------------------------------- 我是修改隔離線 ---------------------------------
data: {
    title: '聯系人',
    columns: [],
    ......
    list: []
  },
mounted: function(){
    let vm=this
    //ID=0時,返回TableSchema
    axios.get('/api/contacts/0')
         .then(function (response) {
           vm.columns.push.apply(vm.columns,response.data)
          })
         .catch(function (error) {
            console.log(error);
         })
    //取出所有聯系人
    axios.get('/api/contacts')
         .then(function(response) {
           vm.list.push.apply(vm.list, response.data)
         })
         .catch(function(error) {
           console.log(error)
         })
  },

2.1 控制表格和表單的所有數據,都存放在columns和list這兩個數組中。
2.2 mounted是Vue組件事件,詳細說明看 官網
2.3 Axios 官網使用說明

后端實現

打開Visual Studio 2013,創建一個基本的WebAPI項目,具體過程可以參考 十分鐘快速實現WebAPI

  1. 業務實體 - ViewModel
Public Class ContactViewModel
    Public Sub New(ByVal id As Integer,
                   ByVal name As String,
                   ByVal birthday As Nullable(Of DateTime),
                   ByVal phone As String)
        Me.id = id
        Me.name = name
        Me.birthday = birthday
        Me.phone = phone
    End Sub
    Public Property id As Integer
    Public Property name As String
    Public Property birthday As Nullable(Of DateTime)
    Public Property phone As String
End Class
'---------------------------'
Public Class TableSchema
    Public Property name As String
    Public Property caption As String
    Public Property type As String
    Public Property iskey As Boolean
End Class

定義兩個類,TableSchema用于保存數據結構,ContactViewModel用于保存聯系人信息。

  1. 新建聯系人API控制器ContactsController
Public Class ContactsController
    Inherits ApiController

    Private m_ContactList As New List(Of ContactViewModel)

    Public Sub New()
        With m_ContactList
            .Add(New ContactViewModel(1, "深圳有事Q我", CDate("2000-09-10"), "2345678"))
            .Add(New ContactViewModel(2, "上海沒事別煩我", CDate("1980-01-22"), "1293587023"))
            .Add(New ContactViewModel(3, "北京深藍醫生", CDate("1990-02-01"), "1332345876"))
        End With
    End Sub

    ' GET api/contact
    Public Function GetValues() As IEnumerable(Of ContactViewModel)
        Return m_ContactList
    End Function

    ' GET api/contact/5
    Public Function GetValue(ByVal id As Integer) As Object
        If id = 0 Then
            Return GetSchema()
        Else
            Return m_ContactList.Find(Function(c) c.ID = id)
        End If
    End Function

    Private Function GetSchema() As IEnumerable(Of TableSchema)
        Dim ls = New List(Of TableSchema)

        With ls
            .Add(New TableSchema With {.name = "id", .iskey = True})
            .Add(New TableSchema With {.name = "name", .caption = "姓名"})
            .Add(New TableSchema With {.name = "birthday", .caption = "出生日期", .type = "date"})
            .Add(New TableSchema With {.name = "phone", .caption = "電話"})
        End With

        Return ls
    End Function

    ' POST api/contact
    Public Sub PostValue(<FromBody()> ByVal value As String)

    End Sub

    ' PUT api/contact/5
    Public Sub PutValue(ByVal id As Integer, <FromBody()> ByVal value As String)

    End Sub

    ' DELETE api/contact/5
    Public Sub DeleteValue(ByVal id As Integer)

    End Sub
End Class

在這段代碼中,做了以下幾件事,
2.1 控制器構造器中,初始化一個聯系人列表。
2.2 GetValues返回全部聯系人。
2.3 GetValue(Byval id as INteger)做了一點小小的處理,當id=0時,返回表結構,當id<>0時,返回單個聯系人信息。
2.4 PostValue,PutValue, DeleteValue暫時不做處理。

  1. 加入Index.html和相應的javascript。
    把我們之前完成的html頁面和Javascript代碼復制到WebAPI項目中,html頁面命名為Index.html。

總結

現在是見證奇跡的時候了,按下F5,可以看到辛苦了幾十分鐘的工作。
在本文中,我們做了幾件小小的事情。

  • 修改javascript代碼,加入Axios調用API代碼。
  • 創建WebAPI項目,加入ContactsController聯系人API
  • 在定義聯系人實體類時,采用了javascript常用的CamelCase變量命名方式,以避免Json序列化時需要處理的復雜性。
  • 日期顯示還存在BUG,不過這個應該交給后端程序員去處理,包括上面的變量大小寫問題。

系列文章目錄

  1. 列表顯示
  2. 表單顯示
  3. 表單CRUD
  4. Vue組件化
  5. 從前端到后端
最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 230,501評論 6 544
  • 序言:濱河連續發生了三起死亡事件,死亡現場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發現死者居然都...
    沈念sama閱讀 99,673評論 3 429
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 178,610評論 0 383
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 63,939評論 1 318
  • 正文 為了忘掉前任,我火速辦了婚禮,結果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 72,668評論 6 412
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發上,一...
    開封第一講書人閱讀 56,004評論 1 329
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 44,001評論 3 449
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 43,173評論 0 290
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當地人在樹林里發現了一具尸體,經...
    沈念sama閱讀 49,705評論 1 336
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 41,426評論 3 359
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發現自己被綠了。 大學時的朋友給我發了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 43,656評論 1 374
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 39,139評論 5 364
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質發生泄漏。R本人自食惡果不足惜,卻給世界環境...
    茶點故事閱讀 44,833評論 3 350
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 35,247評論 0 28
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 36,580評論 1 295
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 52,371評論 3 400
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 48,621評論 2 380

推薦閱讀更多精彩內容

  • Spring Cloud為開發人員提供了快速構建分布式系統中一些常見模式的工具(例如配置管理,服務發現,斷路器,智...
    卡卡羅2017閱讀 134,829評論 18 139
  • 1. Java基礎部分 基礎部分的順序:基本語法,類相關的語法,內部類的語法,繼承相關的語法,異常的語法,線程的語...
    子非魚_t_閱讀 31,737評論 18 399
  • 第一次背誦長恨歌的時候,是高二,當時正從所謂的實驗班發配到普通班。第一次記得的長恨歌里面的是這句“上窮碧落下黃泉”...
    道帥閱讀 1,294評論 0 3
  • L先生是我們的大客戶,中午安排在一起吃飯。 剛剛坐定,他就開始在眾人面前表揚我們同事W,夸W工作能力強且周到細致,...
    清溪有畫閱讀 280評論 5 4
  • 偏遠的古城,喧囂的鼓點,城墻下新鮮的血液被濃烈的煙霧熏的發黑,城頭上一個男子身著寬松的法師白袍,無限溫柔的抱著一個...
    考拉兇猛閱讀 208評論 0 0