0
点赞
收藏
分享

微信扫一扫

04Vue-Axios异步通信

书写经典 2022-01-31 阅读 40

目录

1、什么是Axios

2、为什么要使用Axios

3、第一个Axios应用程序

        1.data.json

        2.测试代码(1)

         2.测试代码(2)

Vue的生命周期


 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实例从创建到销毁的过程,就是生命周期。

举报

相关推荐

0 条评论