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阅读 196,165评论 5 462
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 82,503评论 2 373
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 143,295评论 0 325
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 52,589评论 1 267
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 61,439评论 5 358
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 46,342评论 1 273
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 36,749评论 3 387
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,397评论 0 255
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 39,700评论 1 295
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 34,740评论 2 313
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 36,523评论 1 326
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,364评论 3 314
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 37,755评论 3 300
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,024评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,297评论 1 251
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 41,721评论 2 342
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 40,918评论 2 336

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,517评论 18 139
  • 1. Java基础部分 基础部分的顺序:基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法,线程的语...
    子非鱼_t_阅读 31,514评论 18 399
  • 第一次背诵长恨歌的时候,是高二,当时正从所谓的实验班发配到普通班。第一次记得的长恨歌里面的是这句“上穷碧落下黄泉”...
    道帅阅读 1,251评论 0 3
  • L先生是我们的大客户,中午安排在一起吃饭。 刚刚坐定,他就开始在众人面前表扬我们同事W,夸W工作能力强且周到细致,...
    清溪有画阅读 261评论 5 4
  • 偏远的古城,喧嚣的鼓点,城墙下新鲜的血液被浓烈的烟雾熏的发黑,城头上一个男子身着宽松的法师白袍,无限温柔的抱着一个...
    考拉凶猛阅读 177评论 0 0