使用Vue调取接口,并渲染数据的示例代码


Posted in Javascript onOctober 28, 2019

刚接触vue.js框架的时候,很伤脑筋。今天整理一下post/get两种方式,简单的调取数据库数据,并进行渲染,希望帮助大家!

首先,在HTML页面引入:

//引入vue.js文件
<script src="https://cdn.staticfile.org/vue/2.4.2/vue.min.js"></script>
引入vue-resource.min.js文件,就可以引入接口方法了
<script src="https://cdn.staticfile.org/vue-resource/1.5.1/vue-resource.min.js"></script>

然后,在body中书写div:

//id在下面js中进行引用
<div id="box">
 
 <table border="1" cellpadding="0" cellspacing="0">
 <tr>
 <td>序号</td>
 <td>姓名</td>
 <td>头像</td>
 </tr>
  //v-for 循环数据表中的数据
 <tr v-for="v in msg">
 <td>{{v.id}}</td>
 <td>{{v.username}}</td> 
 <td>{{v.photo}}</td>
 </tr>
 </table>
</div>

第三,js代码:

<script type = "text/javascript">
window.onload = function(){
//实例化vue类
var vm = new Vue({
 //绑定box
 el:'#box',
 data:{
   //设置msg内容为空,在请求数据前为空的状态
   msg:'',
   },
 mounted:function () {
   //调取本地的get(就在下面)
   this.get();
   },
 methods:{
 get:function(){
   //发送get请求
   this.$http.post('http://你的IP/api/方法',{key:"密钥"},{emulateJSON:true}).then(function(res){
    //msg等于回调函数返回的res(值)
    this.msg=res.body.data;
    //在打印台测试打印,无误后一定要删除
    console.log(res);  
   },function(){
    console.log('请求失败处理');
   });
  }
 }
});
}
</script>

控制器:

public function index()
 {
  //  //引入秘钥
  $pwd=new ApisModel();
  $passwd=$pwd->passwd();
  // print_r($passwd);die;
  //空的数组,等待输入秘钥与存储在model层的秘钥对比
  $date=request()->get();
   // print_r($date);die;
  // 对比秘钥是否一致
  if($date['key']==$passwd){
    $model=new ApisModel();
    $data=$model->role_show();
   
    return json(array('data'=>$data,'code'=>1,'message'=>'操作完成'));
   }else{
    $data = ['name'=>'status','message'=>'操作失败'];
    
    return json(['data'=>$data,'code'=>2,'message'=>'秘钥不正确']);
   }
 
 }

model:

public function passwd(){
 $key='存放在本地的密钥';
  return $key;
 }
 //简单的测试接口
 public function role_show(){
  return Db::name('role_power')->select();
 
 }

OK,post方式搞定了,下面是vue使用get方法进行接口调用,渲染数据

简单粗暴,大致一样,就不一一详解了,上代码:

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>Vue 测试实例 - 菜鸟教程(runoob.com)</title>
<script src="https://cdn.staticfile.org/vue/2.4.2/vue.min.js"></script>
<script src="https://cdn.staticfile.org/vue-resource/1.5.1/vue-resource.min.js"></script>
</head>
<body>
 
<div id="box">
 
 <table border="1" cellpadding="0" cellspacing="0">
 <tr>
 <td style="width:130px;height:30px;">ROLE_ID</td>
 <td style="width:130px;height:30px;">POWER_ID</td>
 <td style="width:130px;height:30px;">创建时间</td>
 </tr>
 <tr v-for="v in msg">
 <td style="width:130px;height:30px;">{{v.role_id}}</td>
 <td style="width:130px;height:30px;">{{v.power_id}}</td> 
 <td style="width:130px;height:30px;">{{v.create_time}}</td>
 </tr>
 </table>
</div>
<script type = "text/javascript">
window.onload = function(){
var vm = new Vue({
 el:'#box',
 data:{
   msg:'',
   },
 mounted:function () {
   this.get();
   },
 methods:{
   get:function(){
    //发送get请求
    this.$http.get("http://ip?key=密钥",{emulateJSON:true}).then(function(res){
     console.log(res.body); 
     this.msg=res.body.data; 
    },function(){
     console.log('请求失败处理');
    });
   }
  }
});
}
</script>
</body>
</html>

ok,都测试好了,可以使用,千万别搞错id哦。

以上这篇使用Vue调取接口,并渲染数据的示例代码就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
TFDN图片播放器 不错自动播放
Oct 03 Javascript
一段利用WSH修改和查看IP配置的代码
May 11 Javascript
js 与或运算符 || &amp;&amp; 妙用
Dec 09 Javascript
9行javascript代码获取QQ群成员具体实现
Oct 16 Javascript
jquery UI Datepicker时间控件的使用方法(终结版)
Nov 07 Javascript
SpringMVC返回json数据的三种方式
Dec 10 Javascript
jQuery获取当前点击的对象元素(实现代码)
May 19 Javascript
AngularJS 在同一个界面启动多个ng-app应用模块详解
Dec 20 Javascript
xmlplus组件设计系列之按钮(2)
Apr 26 Javascript
原生js实现简单的链式操作
Jul 04 Javascript
浅谈实现vue2.0响应式的基本思路
Feb 13 Javascript
详解vue beforeRouteEnter 异步获取数据给实例问题
Aug 09 Javascript
JavaScript 反射和属性赋值实例解析
Oct 28 #Javascript
vue 解决数组赋值无法渲染在页面的问题
Oct 28 #Javascript
在vue中把含有html标签转为html渲染页面的实例
Oct 28 #Javascript
详解关闭令人抓狂的ESlint 语法检测配置方法
Oct 28 #Javascript
Vue实现将数据库中带html标签的内容输出(原始HTML(Raw HTML))
Oct 28 #Javascript
js实现图片无缝循环轮播
Oct 28 #Javascript
Vue 实现html中根据类型显示内容
Oct 28 #Javascript
You might like
水质对咖图啡风味的影响具体有哪些
2021/03/03 冲泡冲煮
一个更简单的无限级分类菜单代码
2007/01/16 PHP
php递归删除目录与文件的方法
2015/01/30 PHP
使用jscript实现二进制读写脚本代码
2008/06/09 Javascript
一个原生的用户等级的进度条
2010/07/03 Javascript
浅谈javascript的数据类型检测
2010/07/10 Javascript
jQuery实现统计复选框选中数量
2014/11/24 Javascript
分享我的jquery实现下拉菜单心的
2015/11/29 Javascript
仅9张思维导图帮你轻松学习Javascript 就这么简单
2016/06/01 Javascript
js实现楼层效果的简单实例
2016/07/15 Javascript
浅谈Vue.js应用的四种AJAX请求数据模式
2017/08/30 Javascript
使用Node.js实现ORM的一种思路详解(图文)
2017/10/24 Javascript
JS随机数产生代码分享
2018/02/24 Javascript
Javascript实现异步编程的过程
2018/06/18 Javascript
Jquery的Ajax技术使用方法
2019/01/21 jQuery
JavaScript如何判断input数据类型
2020/02/06 Javascript
详解JavaScript原型与原型链
2020/11/16 Javascript
JavaScript实现点击切换验证码及校验
2021/01/10 Javascript
vue实现验证用户名是否可用
2021/01/20 Vue.js
python Django连接MySQL数据库做增删改查
2013/11/07 Python
Python 爬虫爬取指定博客的所有文章
2016/02/17 Python
Python设计模式之命令模式原理与用法实例分析
2019/01/11 Python
Python中pyecharts安装及安装失败的解决方法
2020/02/18 Python
python+gdal+遥感图像拼接(mosaic)的实例
2020/03/10 Python
Python爬取数据并实现可视化代码解析
2020/08/12 Python
英国剑桥包官网:The Cambridge Satchel Company
2016/08/01 全球购物
世界第一冲浪品牌:O’Neill
2016/08/30 全球购物
瑞典快乐袜子:Happy Socks
2018/02/16 全球购物
联想台湾官网:Lenovo TW
2018/05/09 全球购物
日语专业毕业生自荐信
2013/11/11 职场文书
制药工程专业个人求职自荐信
2014/01/25 职场文书
学历公证委托书
2014/04/09 职场文书
2015年行政部工作总结
2015/04/28 职场文书
导游词之云南-元阳梯田
2019/10/08 职场文书
Python面向对象之内置函数相关知识总结
2021/06/24 Python
一小时迅速入门Mybatis之bind与多数据源支持 Java API
2021/09/15 Javascript