Vue.JS 聯(lián)系人單頁應(yīng)用(五) - 從前端到后端

前言

在前面四篇文章中丹喻,我們搭建了一個(gè)純粹的客戶端應(yīng)用,數(shù)據(jù)保存在客戶端內(nèi)存中翁都。同時(shí)碍论,對(duì)于表格和表單的自動(dòng)化,進(jìn)行了一些嘗試柄慰。
正常的生產(chǎn)環(huán)境中鳍悠,數(shù)據(jù)通常存放在數(shù)據(jù)服務(wù)器上,前端需要完成的工作還包括坐搔,訪問后端API接口藏研,實(shí)現(xiàn)真正的CRUD。而實(shí)現(xiàn)此功能的一大利器則是AJAX概行。
這篇文章是從前端到后端的一個(gè)分界線遥倦,因此我們將盡量減少復(fù)雜度,希望讓前端和后端都能看懂占锯,你的同伴需要什么。

Axios 介紹

Axios 開源代碼在 Github缩筛。

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

項(xiàng)目改造

前端改造
  1. HTML
    受益于Vue的組件化編程,我們無需對(duì)HTML文件進(jìn)行任何修改瞎抛,當(dāng)然如果你還沒有加入Axios的引用艺演,那么此時(shí)需要在HTML中添加Axios引用。
<script type="text/javascript" src="https://unpkg.com/axios/dist/axios.min.js"></script>
  1. Javascript
data: {
    title: '聯(lián)系人',
    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: '北京藍(lán)色醫(yī)生',
      birthday: '1990-02-01',
      phone: '1332345876'
    }]
  },
-------------------------------- 我是修改隔離線 ---------------------------------
data: {
    title: '聯(lián)系人',
    columns: [],
    ......
    list: []
  },
mounted: function(){
    let vm=this
    //ID=0時(shí),返回TableSchema
    axios.get('/api/contacts/0')
         .then(function (response) {
           vm.columns.push.apply(vm.columns,response.data)
          })
         .catch(function (error) {
            console.log(error);
         })
    //取出所有聯(lián)系人
    axios.get('/api/contacts')
         .then(function(response) {
           vm.list.push.apply(vm.list, response.data)
         })
         .catch(function(error) {
           console.log(error)
         })
  },

2.1 控制表格和表單的所有數(shù)據(jù)胎撤,都存放在columns和list這兩個(gè)數(shù)組中晓殊。
2.2 mounted是Vue組件事件,詳細(xì)說明看 官網(wǎng) 伤提。
2.3 Axios 官網(wǎng)使用說明

后端實(shí)現(xiàn)

打開Visual Studio 2013巫俺,創(chuàng)建一個(gè)基本的WebAPI項(xiàng)目,具體過程可以參考 十分鐘快速實(shí)現(xiàn)WebAPI肿男。

  1. 業(yè)務(wù)實(shí)體 - 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

定義兩個(gè)類介汹,TableSchema用于保存數(shù)據(jù)結(jié)構(gòu),ContactViewModel用于保存聯(lián)系人信息舶沛。

  1. 新建聯(lián)系人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, "北京深藍(lán)醫(yī)生", 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 控制器構(gòu)造器中,初始化一個(gè)聯(lián)系人列表如庭。
2.2 GetValues返回全部聯(lián)系人叹卷。
2.3 GetValue(Byval id as INteger)做了一點(diǎn)小小的處理,當(dāng)id=0時(shí)坪它,返回表結(jié)構(gòu)骤竹,當(dāng)id<>0時(shí),返回單個(gè)聯(lián)系人信息哟楷。
2.4 PostValue瘤载,PutValue, DeleteValue暫時(shí)不做處理。

  1. 加入Index.html和相應(yīng)的javascript卖擅。
    把我們之前完成的html頁面和Javascript代碼復(fù)制到WebAPI項(xiàng)目中鸣奔,html頁面命名為Index.html。

總結(jié)

現(xiàn)在是見證奇跡的時(shí)候了惩阶,按下F5挎狸,可以看到辛苦了幾十分鐘的工作。
在本文中断楷,我們做了幾件小小的事情锨匆。

  • 修改javascript代碼,加入Axios調(diào)用API代碼冬筒。
  • 創(chuàng)建WebAPI項(xiàng)目恐锣,加入ContactsController聯(lián)系人API
  • 在定義聯(lián)系人實(shí)體類時(shí),采用了javascript常用的CamelCase變量命名方式舞痰,以避免Json序列化時(shí)需要處理的復(fù)雜性土榴。
  • 日期顯示還存在BUG,不過這個(gè)應(yīng)該交給后端程序員去處理响牛,包括上面的變量大小寫問題玷禽。

系列文章目錄

  1. 列表顯示
  2. 表單顯示
  3. 表單CRUD
  4. Vue組件化
  5. 從前端到后端
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末赫段,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子矢赁,更是在濱河造成了極大的恐慌糯笙,老刑警劉巖,帶你破解...
    沈念sama閱讀 206,839評(píng)論 6 482
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件撩银,死亡現(xiàn)場(chǎng)離奇詭異给涕,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)蜒蕾,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,543評(píng)論 2 382
  • 文/潘曉璐 我一進(jìn)店門稠炬,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人咪啡,你說我怎么就攤上這事首启。” “怎么了撤摸?”我有些...
    開封第一講書人閱讀 153,116評(píng)論 0 344
  • 文/不壞的土叔 我叫張陵毅桃,是天一觀的道長。 經(jīng)常有香客問我准夷,道長钥飞,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 55,371評(píng)論 1 279
  • 正文 為了忘掉前任衫嵌,我火速辦了婚禮读宙,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘楔绞。我一直安慰自己结闸,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,384評(píng)論 5 374
  • 文/花漫 我一把揭開白布酒朵。 她就那樣靜靜地躺著桦锄,像睡著了一般。 火紅的嫁衣襯著肌膚如雪蔫耽。 梳的紋絲不亂的頭發(fā)上结耀,一...
    開封第一講書人閱讀 49,111評(píng)論 1 285
  • 那天,我揣著相機(jī)與錄音匙铡,去河邊找鬼图甜。 笑死,一個(gè)胖子當(dāng)著我的面吹牛鳖眼,可吹牛的內(nèi)容都是我干的黑毅。 我是一名探鬼主播,決...
    沈念sama閱讀 38,416評(píng)論 3 400
  • 文/蒼蘭香墨 我猛地睜開眼具帮,長吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼博肋!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起蜂厅,我...
    開封第一講書人閱讀 37,053評(píng)論 0 259
  • 序言:老撾萬榮一對(duì)情侶失蹤匪凡,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后掘猿,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體病游,經(jīng)...
    沈念sama閱讀 43,558評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,007評(píng)論 2 325
  • 正文 我和宋清朗相戀三年稠通,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了衬衬。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,117評(píng)論 1 334
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡改橘,死狀恐怖滋尉,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情飞主,我是刑警寧澤狮惜,帶...
    沈念sama閱讀 33,756評(píng)論 4 324
  • 正文 年R本政府宣布,位于F島的核電站碌识,受9級(jí)特大地震影響碾篡,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜筏餐,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,324評(píng)論 3 307
  • 文/蒙蒙 一开泽、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧魁瞪,春花似錦穆律、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,315評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至趟畏,卻和暖如春贡歧,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背赋秀。 一陣腳步聲響...
    開封第一講書人閱讀 31,539評(píng)論 1 262
  • 我被黑心中介騙來泰國打工利朵, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人猎莲。 一個(gè)月前我還...
    沈念sama閱讀 45,578評(píng)論 2 355
  • 正文 我出身青樓绍弟,卻偏偏與公主長得像,于是被迫代替她去往敵國和親著洼。 傳聞我的和親對(duì)象是個(gè)殘疾皇子樟遣,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,877評(píng)論 2 345

推薦閱讀更多精彩內(nèi)容

  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理而叼,服務(wù)發(fā)現(xiàn),斷路器豹悬,智...
    卡卡羅2017閱讀 134,600評(píng)論 18 139
  • 1. Java基礎(chǔ)部分 基礎(chǔ)部分的順序:基本語法葵陵,類相關(guān)的語法,內(nèi)部類的語法瞻佛,繼承相關(guān)的語法脱篙,異常的語法,線程的語...
    子非魚_t_閱讀 31,587評(píng)論 18 399
  • 第一次背誦長恨歌的時(shí)候伤柄,是高二绊困,當(dāng)時(shí)正從所謂的實(shí)驗(yàn)班發(fā)配到普通班。第一次記得的長恨歌里面的是這句“上窮碧落下黃泉”...
    道帥閱讀 1,257評(píng)論 0 3
  • L先生是我們的大客戶适刀,中午安排在一起吃飯秤朗。 剛剛坐定,他就開始在眾人面前表揚(yáng)我們同事W蔗彤,夸W工作能力強(qiáng)且周到細(xì)致川梅,...
    清溪有畫閱讀 266評(píng)論 5 4
  • 偏遠(yuǎn)的古城,喧囂的鼓點(diǎn)然遏,城墻下新鮮的血液被濃烈的煙霧熏的發(fā)黑贫途,城頭上一個(gè)男子身著寬松的法師白袍,無限溫柔的抱著一個(gè)...
    考拉兇猛閱讀 182評(píng)論 0 0