大米就这样长成的

大米就这样长成的

分享一下我老师大神的人工智能教程!零基础,通俗易懂!http://blog.csdn.net/jiangjunshow

也欢迎大家转载本篇文章。分享知识,造福人民,实现我们中华民族伟大复兴!

                     

Vue2+VueRouter2+webpack 构建项目实战(四)接通api,先渲染个列表

2017年8月补充

2016年,我写了一系列的 VUE 入门教程,当时写这一系列博文的时候,我也只是一个菜鸟,甚至在写的过程中关闭了代码审查,否则通不过校验。

本来写这一系列的博文只是为了给自己看的,但没想到的是,这系列博文的点击量超过了2万以上,搜索引擎的排名也是非常理想,这让我诚惶诚恐,生怕我写的博文有所纰漏,误人子弟。

再者,这一年的发展,VUE 项目快速迭代,看着我一年前写的博文,很可能各种提示已经发生改变,对照着过时的资料,非常可能导致新手在学习的过程中产生不必要的困扰。

因此,本人决定,重写这个系列的博文,力求以简明、清晰、准确的图文以及代码描述,配合 github 的项目开源代码,给各位 VUE 新手提供一个高质量的入门文案。

以下为我写的博文:

  1. Vue2+VueRouter2+Webpack+Axios 构建项目实战2017重制版(一)基础知识概述
  2. Vue2+VueRouter2+Webpack+Axios 构建项目实战2017重制版(二)安装 nodejs 环境以及 vue-cli 构建初始项目
  3. Vue2+VueRouter2+Webpack+Axios 构建项目实战2017重制版(三)认识项目所有文件
  4. Vue2+VueRouter2+Webpack+Axios 构建项目实战2017重制版(四)调整 App.vue 和 router 路由
  5. Vue2+VueRouter2+Webpack+Axios 构建项目实战2017重制版(五)配置 Axios api 接口调用文件
  6. Vue2+VueRouter2+Webpack+Axios 构建项目实战2017重制版(六)将接口用 webpack 代理到本地
  7. Vue2+VueRouter2+Webpack+Axios 构建项目实战2017重制版(七)初识 *.vue 文件
  8. Vue2+VueRouter2+Webpack+Axios 构建项目实战2017重制版(八)渲染一个列表出来先
  9. Vue2+VueRouter2+Webpack+Axios 构建项目实战2017重制版(九)再把内容页面渲染出来
  10. Vue2+VueRouter2+Webpack+Axios 构建项目实战2017重制版(十)打包项目并发布到子目录
  11. Vue2+VueRouter2+Webpack+Axios 构建项目实战2017重制版(十一)阶段性小结

以下为原文

目录索引

《Vue2+VueRouter2+webpack 构建项目实战(一)准备工作》

《Vue2+VueRouter2+webpack 构建项目实战(二)目录以及文件结构》

《Vue2+VueRouter2+webpack 构建项目实战(三)配置路由,整俩页面先》

《Vue2+VueRouter2+webpack 构建项目实战(四)接通api,先渲染个列表》

《Vue2+VueRouter2+webpack 构建项目实战(五)配置子路由》

通过前面几篇教程,我们已经顺利搭建起来了,并且已经组建好路由了。本章节,我们需要做一个列表页面,然后利用获取 http://cnodejs.org/api 的公开API,渲染出来。

制作列表页面

我们打开src/page/index.vue文件,在这里写入下面的代码:

<template>  <div>    <h1 class="logo">cnodejs Api Test</h1>    <ul class="list">      <li v-for="item in lists" v-text="item.title"></li>    </ul>  </div></template><script>export default {  data() {    return {      lists:[{        id:1,        title:"test title 1"      },{        id:2,        title:"test title 2"      }]    }  }}</script>
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23

如上,我们通过自己写的两组数据,很轻松的将页面渲染成功了。通过浏览器,我们可以看到效果

Vue2+VueRouter2+webpack 构建项目实战(四)接通api,先渲染个列表-LMLPHP

配合点css

这里,我着重强调的不是css如何去写,而是我的组织项目的结构,我感觉我组织得还是很不错的。

新建文件, src/style/scss/_index.scss

输入下面的内容

.logo {color: red;}.list line-height: 2li {border-bottom: 1px solid #ddd;}}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6

然后在 src/style/style.scss中输入

@import "scss/index";
  • 1

然后,我们就可以在浏览器中,看到带样式的列表了。

我的习惯是,一个文件,一个样式,文件位于src/page/文件夹下面,样式位于src/style/scss下面。文件和样式同名。如果文件位于子目录,如src/page/user/pay.vue,那么,对应的scss文件就是src/style/scss/user/_pay.scss这样。

每一个团队的规范都是不一样的,都是各有所长的,重要的是,条理性。

调用api.js

在第二节中,我们在src/config目录下面建立了一个api.js的空文件。在第三节中没有使用。本节,我们要开始使用了。

首先,我们编辑 src/main.js ,引用 src/config/api.js。如下:

import api from './config/api'Vue.prototype.$api = api
  • 1
  • 2

插入这两行代码,就引用好了api.js,并且,把它绑定到了全局,然后我们就可以在各种地方使用这个文件了。虽然这个文件是空的。

可能部分朋友不知道插入到文件的哪里去。我这里放上main.js的全部代码:

// 引用 vue 没什么要说的import Vue from 'vue'// 引用路由import VueRouter from 'vue-router'// 光引用不成,还得使用Vue.use(VueRouter)// 入口文件为 src/App.vue 文件 所以要引用import App from './App.vue'// 引用路由配置文件import routes from './config/routes'// 引用API文件import api from './config/api'// 将API方法绑定到全局Vue.prototype.$api = api// 使用配置文件规则const router = new VueRouter({  routes})// 跑起来吧new Vue({  router,  el: '#app',  render: (h) => h(App)})
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24

安装superagent组件

要请求接口,就必须有相对应的组件。如果你使用过jquery,应该熟悉其中的AJAX方法。当然,在vue中,我们就不考虑使用jquery了。我们使用superagent这个组件。

安装非常简单,我们首先跳转到项目根目录,然后输入 npm install superagent -D进行安装。

Vue2+VueRouter2+webpack 构建项目实战(四)接通api,先渲染个列表-LMLPHP

编写api.js文件

有了工具了,我们就需要来编写api.js文件,使它可以完成我们想要的工作。

// 配置API接口地址var root = 'https://cnodejs.org/api/v1';// 引用superagentvar request = require('superagent');// 自定义判断元素类型JSfunction toType(obj) {  return ({}).toString.call(obj).match(/\s([a-zA-Z]+)/)[1].toLowerCase()}// 参数过滤函数function filter_null(o) {  for (var key in o) {    if (o[key] == null) {      delete o[key]    }    if (toType(o[key]) == 'string') {      o[key] = o[key].trim()      if (o[key].length == 0) {        delete o[key]      }    }  }  return o}/*  接口处理函数  这个函数每个项目都是不一样的,我现在调整的是适用于  https://cnodejs.org/api/v1 的接口,如果是其他接口  需要根据接口的参数进行调整。参考说明文档地址:  https://cnodejs.org/topic/5378720ed6e2d16149fa16bd*/function _api_base(method, url, params, success, failure) {  var r = request(method, url).type('text/plain'if (params) {    params = filter_null(params);    if (method === 'POST' || method === 'PUT') {      if (toType(params) == 'object') {        params = JSON.stringify(params);      }      r = r.send(params)    } else if (method == 'GET' || method === 'DELETE') {      r = r.query(params)    }  }  r.end(function(err, res) {    if (err) {      alert('api error, HTTP CODE: ' + res.status);      return;    };    if (res.body.success == true) {      if (success) {        success(res.body);      }    } else {      if (failure) {        failure(res.body);      } else {        alert('error: ' + JSON.stringify(res.body));      }    }  });};// 返回在vue模板中的调用接口export default {  get: function(url, params, success, failure) {    return _api_base('GET', root + '/' + url, params, success, failure)  },  post: function(url, params, success, failure) {    return _api_base('POST', root + '/' + url, params, success, failure)  },  put: function(url, params, success, failure) {    return _api_base('PUT', root + '/' + url, params, success, failure)  },  delete: function(url, params, success, failure) {    return _api_base('DELETE', root + '/' + url, params, success, failure)  },}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 36
  • 37
  • 38
  • 39
  • 40
  • 41
  • 42
  • 43
  • 44
  • 45
  • 46
  • 47
  • 48
  • 49
  • 50
  • 51
  • 52
  • 53
  • 54
  • 55
  • 56
  • 57
  • 58
  • 59
  • 60
  • 61
  • 62
  • 63
  • 64
  • 65
  • 66
  • 67
  • 68
  • 69
  • 70
  • 71
  • 72
  • 73
  • 74
  • 75
  • 76

这个文件就有点狂拽酷炫吊炸天了。目前,我们测试cnodejs.org的接口,我调整得可以使用。实际上在其他的接口项目中,这个是需要调整的,要调整到你的项目合适的代码。主要是根据接口返回的内容进行各种判断和处理,其中主要的框架代码是不用动的。

如果你JS基础过硬,一看就懂,如果不行,就慢慢看,慢慢理解吧。反正我基础不成,也看着理解了。

模板中调用api接口试试

编辑src/page/index.vue文件,代码如下:

<template>  <div>    <h1 class="logo">cnodejs Api Test</h1>    <ul class="list">      <li v-for="item in lists" v-text="item.title"></li>    </ul>  </div></template><script>export default {  data() {    return {      lists:[]    }  },  created () {    // 组件创建完后获取数据,这里和1.0不一样,改成了这个样子    this.get_data()  },  methods: {    get_data: function(params) {      var v = this      if (!params) params = {}      // 我们这里用全局绑定的 $api 方法来获取数据,方便吧~      v.$api.get('topics', params, function(r) {        v.lists = r.data      })    },  },}</script>
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31

保存后,我们在浏览器中,就可以看到渲染出来的列表了。如下图所示:

Vue2+VueRouter2+webpack 构建项目实战(四)接通api,先渲染个列表-LMLPHP

小结

好,通过本节的学习,我们已经顺利的从接口获取到数据,并且渲染到我们的页面当中了。这其实已经解决了绝大多数的问题了。

  1. 如何新建一个js文件,并且把这个文件引用,然后绑定到全局
  2. 学习理解superagent插件。
  3. 如何在vue模板中调用绑定的方法。
  4. 组件渲染完成时,执行函数。

本文由FungLeo原创,允许转载,但转载必须附带首发链接。如果你不带链接,我将采取包括但不限于深深的鄙视你等手段!

首发地址:http://blog.csdn.net/fungleo/article/details/53202276

           

给我老师的人工智能教程打call!http://blog.csdn.net/jiangjunshow

Vue2+VueRouter2+webpack 构建项目实战(四)接通api,先渲染个列表-LMLPHP
12-15 10:23