Ajax知识点

  1. Ajax与JSON

	//XMLHttpRequest对象,是一个异步调用对象,是Ajax的核心
	//创建的步骤
	//1.创建XMLHttpRequest对象
	//2.创建一个新的HTTP请求,并指定HTTP请求的方法,URL,
	//3.设置响应HTTP请求状态变化的函数

	//注意:如果是HTTP表单请求post数据的,需要添加HTTP头,使用setRequestHeader()
	//使用:xhr.setRequestHeader("Content-type","application/x-www-from-urlecoder");
	<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Ajax案例</title>
    <link rel="stylesheet" href="css/ajaxstyle.css">
</head>
<body>
    <div class="banner" id="banner"></div>
    <script>
        //封装一个XHR函数,兼容各个版本
        function createXHR(){
            var xhr;
            //兼容 IE7+,Firefox,Chrome,Opera,Safari
            if(window.XMLHttpRequest){
                xhr = new XMLHttpRequest();
            }else{
            //兼容 IE6,IE5
                xhr = new ActiveXObject("Microsoft.XMLHTTP");
            }
            return xhr;
        }
        //调用
        var xhr = createXHR();
        var data = null;  //用于接收服务端返回数据

        //相应XMLHttpRequest对象状态变化的函数
        xhr.onreadystatechange = function(){
            if(xhr.readyState === 4 ){
                if((xhr.status>=200&&xhr.status<300)||xhr.status===304){
                    data = JSON.parse(xhr.responseText);
                    // console.log(data);
                    renderDataToDom();
                }else{
                    console.log("unsuccess");
                }
            }
        }
        //创建HTTP请求
        xhr.open('get','./ajax/server/slider.json',true);
      	
        //发送HTTP请求
        xhr.send(null);

        //渲染数据
        function renderDataToDom(){
            var img = data.slider,
                i,len=img.length,
                str="",
                banner = document.getElementById("banner");
                for(i=0;i<len;i++){
                    str+= '<a href="'+img[i].linkUrl+'"><img src="'+img[i].picUrl+'"></a>';
                }
                //渲染图片信息
                banner.innerHTML = str;
        }
        
    </script>
</body>
</html>
  1. jQuery的ajax

	jQuery的Ajax方法
	$.ajax();
	$.get();
	$.post();
	$.getJson();
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Ajax_jQuery</title>
    <link rel="stylesheet" href="css/ajaxstyle.css">
</head>
<body>
    <div class="banner" id="banner"></div>
    <script src="https://cdn.bootcdn.net/ajax/libs/jquery/3.5.1/jquery.js"></script>
    <script>
        $.ajax({
            url:"./ajax/server/slider.json", 	//请求地址
            type:"post",	//请求方法
            dataType:"json",	//数据返回格式
            async:true,			//异步/同步
            success:function(datas){//成功响应的回调函数
                renderDatasToDom(datas.slider);
            }
        });
        //jquery渲染数据
        function renderDatasToDom(data){
            var str="";
            $.each(data,function(index,obj){
                str+='<a href="'+obj.linkUrl+'"><img src="'+obj.picUrl+'"></a>';
            })
            $("#banner").html(str);
        }
    </script>
</body>
</html>
  1. ##关于Ajax中的跨域请求
	<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>ajax_demo2</title>
</head>
<body>
    <script>
        //跨域 封装一个JSONP函数
        function getJSONP(url,callback){
            if(!url){
                return;
            }
            var arr = ["a","b","c","d","e","f","g","h","i","j"];
            var r1 = Math.floor(Math.random()*10);
            var r2 = Math.floor(Math.random()*10);
            var r3 = Math.floor(Math.random()*10);
            var name = "getJSONP"+arr[r1]+arr[r2]+arr[r3];
            var cbname = "getJSONP."+name;
            // console.log(name);
            if(url.indexOf('?')===-1){
                url += "?jsonp="+cbname;
            }else{
                url += "&jsonp="+cbname;
            }
            // console.log(url);
            var script = document.createElement('script');
            //定义被脚本执行的回调函数
            getJSONP[name] = function(e){
                try{
                    callback && callback(e);
                }catch(e){

                }finally{
                    delete getJSONP[name];
                    script.parentNode.removeChild(script);
                }
            }
            script.src = url;
            document.getElementsByTagName("head")[0].appendChild(script);
        }
        getJSONP('http://class.imooc.com/api/jsonp',function(res){
            console.log(res);
        });
    </script>
</body>
</html>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值