目录
axios.get('../data.json').then(response=>(this.info=response.data));
通信交给
axios 来做
get('../data.json') 一个请求
then(response 得到结果
=>(this.info=response.data)); 箭头函数指向它结果要产生的事情
1、什么是Axios
Axios是一个开源的可以用在浏览器端和Node JS的异步通信框架, 她的主要作用就是实现AJAX异步通信,其功能特点如下:
从浏览器中创建XMLHttpRequests
从node.js创建http请求
支持Promise API[JS中链式编程]
拦截请求和响应
转换请求数据和响应数据
取消请求
自动转换JSON数据
客户端支持防御XSRF(跨站请求伪造)
GitHub:http://GitHub - axios/axios: Promise based HTTP client for the browser and node.js
中文文档:http://axios中文网|axios API 中文文档 | axios
2、为什么要使用Axios
由于Vue.js是一个视图层框架并且作者(尤雨溪) 严格准守SOC(关注度分离原则)所以Vue.js并不包含AJAX的通信功能, 为了解决通信问题, 作者单独开发了一个名为vue-resource的插件, 不过在进入2.0版本以后停止了对该插件的维护并推荐了Axios框架。少用jQuery, 因为它操作Dom太频繁!
3、第一个Axios应用程序
问题: Vue 先加载模板,后渲染数据
解决闪烁问题
<!--v-cloak 解决闪烁问题-->
<style>
[v-cloak]{
display: none;
}
</style>
1.data.json
{
"name": "gh_xiaohe个人博客",
"url": "https://blog.csdn.net/gh_xiaohe",
"page": 1,
"isNonProfit": false,
"address": {
"street": "含光门",
"city": "陕西西安",
"country": "中国"
},
"links": [
{
"name": "bilibili",
"url": "https://www.bilibili.com/"
},
{
"name": "个人博客",
"url": "https://blog.csdn.net/gh_xiaohe"
},
{
"name": "百度",
"url": "https://www.baidu.com/"
}
]
}
2.测试代码(1)
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<body>
<div id="vue">
</div>
<!--引入js文件-->
<script src="https://cdn.jsdelivr.net/npm/vue@2.5.21/dist/vue.min.js"></script>
<script src="https://unpkg.com/axios/dist/axios.min.js"></script>
<script type="text/javascript">
var vm = new Vue({
el:"#vue",
/*
* mounted(){ 钩子函数,链式编程 ES6新特性
*
* 编译好的HTML挂载到页面完成后执行的时间钩子此钩子函数中
* 一般会做一些ajax请求获取数据进行数据初始化
* 注意:mounted在整个实例中只执行一次
* */
mounted(){//钩子函数,链式编程 ES6新特性
axios.get('../data.json').then(response => console.log(response.data)); / //执行完响应后 输出一句话 response相应的数据
}
});
</script>
</body>
</html>
2.测试代码(2)
<!DOCTYPE html>
<html lang="en" xmlns:v-binf="http://www.w3.org/1999/xhtml" xmlns:v-bind="http://www.w3.org/1999/xhtml">
<head>
<meta charset="UTF-8">
<title>Title</title>
<!--v-cloak 解决闪烁问题-->
<style>
[v-cloak] {
display: none;
}
</style>
</head>
<body>
<div id="app" v-cloak>
<div>属性名:{{info.name}}</div>
<div>链接:<a v-bind:href="info.url">{{info.url}}</a></div>
<div>页数:{{info.page}}</div>
<div>是否有利润isNonProfit:{{info.isNonProfit}}</div>
<div>地址:{{info.address.street}}--{{info.address.city}}--{{info.address.country}}</div>
<div>数组:{{info.links}}</div>
</div>
<!--引入js文件-->
<script src="https://cdn.jsdelivr.net/npm/vue@2.5.21/dist/vue.min.js"></script>
<script src="https://unpkg.com/axios/dist/axios.min.js"></script>
<script>
var mv = new Vue({
el: "#app",
//此时data() 是方法 , 不是data 属性 二者不一样
data() {
return {
//请求的返回参数合适,必须和json字符串一样 可以省略不写
info: {
name: null,
url: null,
address:{
street:null,
city:null,
country:null
},
links:[]
}
}
},
/*
* mounted(){ 钩子函数,链式编程 ES6新特性
*
* 编译好的HTML挂载到页面完成后执行的时间钩子此钩子函数中
* 一般会做一些ajax请求获取数据进行数据初始化
* 注意:mounted在整个实例中只执行一次
* */
mounted() { //钩子函数,链式编程 ES6新特性
axios.get('../data.json').then(response => this.info=response.data); //执行完响应后 输出一句话 response相应的数据
}
});
</script>
</body>
</html>
Vue的生命周期
Vue实例有一个完整的生命周期,也就是从开始创建初始化数据、编译模板、挂载DOM、渲染一更新一渲染、卸载等一系列过程,我们称这是Vue的生命周期。通俗说就是Vue实例从创建到销毁的过程,就是生命周期。