zoukankan      html  css  js  c++  java
  • Vue-resoure 实现get post jsonp请求

    1.之前学习中,如何发起数据请求?

    2.常见的数据请求类型?get post jsonp

    3.常见的URL请求资源地址

      get请求地址:  http://vue.studyit.io/api/getlunbo

      post请求地址:http://Vuestudyit.io/api/post

      jsonp请求地址:http://Vuestudyit.io/api/jsonp

    4.JSONP的实现原理

      由于浏览器的安全性限制,不允许AJAX访问  协议不同,域名不同,端口不同 数据接口不同,浏览器认为这种访问不安全

      可以通过动态创建script标签的形式,把script标签的src属性指向数据接口的地址,因为script标签不存在跨域限制,这个数据获取方式,称作为JSONP  (

      注意:根据JSONP的实现原理,知晓JSONP只支持GET请求)

      具体的实现过程:

    •     先在客户端定义一个回调方法,预定义对数据的操作
    •     再把这个回调方法的名称,通过URL传参的形式 提交到服务器的数据接口
    •     服务器数据接口组织好要发送给客户端的数据,在拿着客户端传递过来的回调函数方法名称,拼接出一个调用这个函数的字符串,发送给客户端去解析执行
    •     客户端拿到服务器返回字符串之后,当作script脚本去解析执行,这样就能够拿到JSONP的数据了。

     除了使用v-resouce之外,还可以使用axios的第三方包实现数据的请求 主流现在是axios 

      

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <meta name="viewport" content="width=device-width, initial-scale=1.0">
        <meta http-equiv="X-UA-Compatible" content="ie=edge">
        <title>Document</title>
        <script src="./lib/vue-2.4.0.js"></script>
        <!-- 引入第三方的axios cdn包 -->
        <script src="https://unpkg.com/axios/dist/axios.min.js"></script>   
    
    </head>
    <body>
        <div class="app">
            <input id="aa" type="button" value="点击我" @click="getinfo">
            <input type="button" value="VueGET" @click="getinfo">
        </div>
        
    
    <script>
    
    // 使用js GET请求
    window.onload=function(){
                //1.获取a节点,并为其添加onclick点击函数
                document.getElementById("aa").onclick=function(){
                    //创建一个XMLHttpRequest对象
                    var request=new XMLHttpRequest();
                    //5.调用XMLHttpRequest对象的open方法 建立与服务器之间的联系
                    request.open("GET",'http://www.phonegap100.com/appapi.php?a=getportalList&catid=20&page=1');
                    //6.调用XMLHttpRequest对象的send方法
                    request.send(null);
                    //7.为XMLHttpRequest 对象添加onreadystatechange响应函数
                    request.onreadystatechange=function(){
                        //8.判断响应是否完成:XMLHttpRequest 对象的readystate属性为4的时候
                        if(request.readyState==4){
                            //9.在判断响应是否可用,XMLHttpRequest 对象status属性值为200
                            if(request.status==200||request.status==304){
                                //10.输出结果  responseText
                                console.log(request);
                            }
                        }
                    }
                    //2.取消点击事件的默认行为
                    return false;
                }
    }
    
            // 使用Vue axios get请求
        var vm=new Vue({
    
            el:'.app',
            data:{},
            methods: {
                getinfo(){   //发起get请求
                var api='http://www.phonegap100.com/appapi.php?a=getportalList&catid=20&page=1';
                   axios.get(api).then(function(result){
                        console.log(result);          //请求成功
                   });
                }
            },
        });
    
    </script>
    </body>
    </html>
  • 相关阅读:
    C#-WebApi-EF-CodeFirst-构建迁移命令说明
    webform-rdlc报表报错:未能加载文件或程序集Microsoft.SqlServer.Types版本错误的处理方案
    Observable与Subject
    使用ionic生成apk时遇到的错误:[ERROR] An error occurred while running subprocess cordova
    Socket通讯
    Transactions-事务
    Visual studio2017前端项目包管理从Borwer升级到libman
    NetCore-EFCore-DBfirst-同步数据库生成Model
    学习计划
    关于Vue2.5 less 版本过高
  • 原文地址:https://www.cnblogs.com/xiaowie/p/11611595.html
Copyright © 2011-2022 走看看