vue.js,ajax渲染页面的实例


Posted in Javascript onFebruary 11, 2018

关于上次说的用vue.js,zepto,node.js,webpack等技术重构CNode。这是一个比较入门的项目,一般你学完vue就可以上手了,CNode网站有公开的API所以你可以获取这个网站的所有数据接口,然后渲染到页面上,用CSS等加工一下就可以了。起初,我一直感觉好难好难好难,虽然说不出难在哪里,就感觉好难好难好难。让我细说,不就是用ajax获取数据,然后传到组件上渲染吗,再模仿着写样式不就好了吗。是不难啊,可是为什么我心里天然觉得很难呢?

CNode是给了我们数据接口,ajax也就那么几个方法。后来我仔细想想,发现了内心恐惧的地方是ajax。是啊,给了我数据接口,我能获取到数据,但是你给了我什么啊?在没用之前,对于ajax获取到的数据我是未知的。人总对自己未知的东西感到恐惧!就像同学说的,ajax我之前以为很难的啊,后来我用起来感觉也没什么啊。我想,大部分初学者对于ajax的困惑往往就在于对他获取到的数据的未知性的恐惧。

既然恐惧它的未知性,那么我们不妨好好看看这个“数据”!这里我用的是zepto的Ajax方法(现学现用嘛)。

let data = { 
 page: 1, 
 limit: 20,//获取20个 
 tab: 'all', 
 mdrender: true 
}; 
let topics = []; 
$.get("https://cnodejs.org/api/v1/topics", data, function (res) { 
   if (res && res.data) { // 如果查到数据 
   topics = res.data; 
   } 
  })

然后在Console输入topics

ajax获取到的是Json格式,如上图所示,我们可以看到获取到了20个Json类型的“对象”,每个对象有那么多个属性。比如我要获取第一个对象的title

现在你应该看穿了ajax获取到的那个数据了吧,感觉这一小步迈出去后,整个人都轻松了。

趁热打铁,简单的用vue渲染一个页面。

HTML:

<!DOCTYPE html> 
<html lang="en"> 
<head> 
 <meta charset="UTF-8"> 
 <title>Document</title> 
 <script src="http://zeptojs.com/zepto.js"></script> 
 <script src="vue.js"></script> 
</head> 
<body> 
<div id="app"> 
 <ul> 
  <li v-for="(item,i) in items" :key="item.id">  
   <span class="index" :title="i + 1">{{(i + 1) > 9999 ? "..." : (i + 1)}}</span> 
   <span class="face"> 
     <img :src="item.author.avatar_url" alt="" :title="item.author.loginname" width="80" height="80" /> 
   </span> 
   <span class="name" :title="item.title">{{item.title}}</span></li> 
 
 </ul> 
</div> 
<script src="Ajax-demo1.js"></script> 
</body> 
</html>

JS:

new Vue({ 
 el: '#app', 
 data:{ 
  items:[], 
  scroller:null, 
  tip:{ 
    page: 1, 
    limit: 20, 
    tab: 'all', 
    mdrender: true 
  } 
 }, 
 methods:{ 
  getData(){ 
   let self = this; 
   $.get("https://cnodejs.org/api/v1/topics", this.tip, function (res) { 
    if (res && res.data) { // 如果查到数据 
    self.items = res.data; 
   } 
  }) 
  } 
 }, 
 created:function() { 
  this.getData(); 
  console.log("success"); 
 }, 
 mounted:function() { 
 
 } 
})

emmmmm,有个小问题得说下,AJAX是异步函数(关于异步可以去看我上一篇博客),它的回调函数执行环境是全局作用域,所以在getData中AJAX的this指向的是window。这有两个解决方法,一个是像我这样的用self把this存起来,还有一种就是用箭头函数this绑定。

很多时候,我们往往对未知的事物感到恐惧,而这个恐惧往往阻碍我们迈出战胜未知的那一步,这时候咬咬牙,迈出去就好了,困难永远都只存在于脑子里。

以上这篇vue.js,ajax渲染页面的实例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
js创建数据共享接口——简化框架之间相互传值
Oct 23 Javascript
js综合应用实例简单的表格统计
Sep 03 Javascript
javascript动态的改变IFrame的高度实现自动伸展
Oct 12 Javascript
AngularJS基础 ng-include 指令简单示例
Aug 01 Javascript
JS实现一次性弹窗的方法【刷新后不弹出】
Dec 26 Javascript
利用Vue构造器创建Form组件的通用解决方法
Dec 03 Javascript
示例vue 的keep-alive缓存功能的实现
Dec 13 Javascript
JavaScript实现的级联算法示例【省市二级联动功能】
Dec 25 Javascript
javascript History对象原理解析
Feb 17 Javascript
JavaScript 双向链表操作实例分析【创建、增加、查找、删除等】
Apr 28 Javascript
js 函数性能比较方法
Aug 24 Javascript
详解TypeScript的基础类型
Feb 18 Javascript
Node.js使用MySQL连接池的方法实例
Feb 11 #Javascript
vue中引用阿里字体图标的方法
Feb 10 #Javascript
Express进阶之log4js实用入门指南
Feb 10 #Javascript
Vue完整项目构建(进阶篇)
Feb 10 #Javascript
JS简单获得节点元素的方法示例
Feb 10 #Javascript
JS简单添加元素新节点的方法示例
Feb 10 #Javascript
vue.js系列中的vue-fontawesome使用
Feb 10 #Javascript
You might like
PHP的FTP学习(二)
2006/10/09 PHP
PHP通过iconv将字符串从GBK转换为UTF8字符集
2011/07/18 PHP
PHP微信开发用Cache 解决数据缓存
2016/07/11 PHP
PHP获取当前执行php文件名的代码
2017/03/02 PHP
PHP中的函数声明与使用详解
2017/05/27 PHP
PHP 计算至少是其他数字两倍的最大数的实现代码
2020/05/26 PHP
一个html5播放视频的video控件只支持android的默认格式mp4和3gp
2014/05/08 Javascript
angularjs中的单元测试实例
2014/12/06 Javascript
javascript文本框内输入文字倒计数的方法
2015/02/24 Javascript
JS实现图片局部放大或缩小的方法
2016/08/20 Javascript
Node.js实现兼容IE789的文件上传进度条
2016/09/02 Javascript
JS实现随机颜色的3种方法与颜色格式的转化
2017/01/05 Javascript
node.js连接MongoDB数据库的2种方法教程
2017/05/17 Javascript
使用Vue.js和Element-UI做一个简单登录页面的实例
2018/02/23 Javascript
Node.js readline 逐行读取、写入文件内容的示例
2018/03/01 Javascript
layer弹出层 iframe层去掉滚动条的实例代码
2018/08/17 Javascript
JavaScript常用数组操作方法,包含ES6方法
2020/05/10 Javascript
Vue.js的动态组件模板的实现
2018/11/26 Javascript
微信小程序基于高德地图查找位置并显示文字
2019/10/30 Javascript
python基于pyDes库实现des加密的方法
2017/04/29 Python
解决Python网页爬虫之中文乱码问题
2018/05/11 Python
python清除字符串中间空格的实例讲解
2018/05/11 Python
python3第三方爬虫库BeautifulSoup4安装教程
2018/06/19 Python
Python3爬虫学习入门教程
2018/12/11 Python
基于MATLAB和Python实现MFCC特征参数提取
2019/08/13 Python
使用python写的opencv实时监测和解析二维码和条形码
2019/08/14 Python
python 常见的反爬虫策略
2020/09/27 Python
Python如何telnet到网络设备
2021/02/18 Python
Bibloo荷兰:女士、男士和儿童的服装、鞋子和配饰
2019/02/25 全球购物
应届生求职信
2014/05/31 职场文书
致百米运动员广播稿5篇
2014/10/13 职场文书
餐饮食品安全责任书
2015/01/29 职场文书
秦始皇兵马俑导游词
2015/02/02 职场文书
民事撤诉申请书范本
2015/05/18 职场文书
大学生军训感言
2015/08/01 职场文书
美国运营商 T-Mobile 以 117.83Mb/s 的速度排第一位
2022/04/21 数码科技