ajax实践

题目1:

ajax 是什么?有什么作用?

含义:脚本发起HTTP通信

作用:传输数据到服务器,监听状态码实现服务器返回结果,在整个网页中,数据的发送响应过程中不会影响网页其他位置的操作,这个过程实现了异步操作,节省用户表单验证时间,提高用户体验。
优点:
(1)无刷新更新数据。
AJAX最大优点就是能在不刷新整个页面的前提下与服务器通信维护数据。这使得Web应用程序更为迅捷地响应用户交互,并避免了在网络上发送那些没有改变的信息,减少用户等待时间,带来非常好的用户体验。

(2)异步与服务器通信。
AJAX使用异步方式与服务器通信,不需要打断用户的操作,具有更加迅速的响应能力。优化了Browser和Server之间的沟通,减少不必要的数据传输、时间及降低网络上数据流量。

(3)前端和后端负载平衡。
AJAX可以把以前一些服务器负担的工作转嫁到客户端,利用客户端闲置的能力来处理,减轻服务器和带宽的负担,节约空间和宽带租用成本。并且减轻服务器的负担,AJAX的原则是“按需取数据”,可以最大程度的减少冗余请求和响应对服务器造成的负担,提升站点性能。

(4)基于标准被广泛支持。
AJAX基于标准化的并被广泛支持的技术,不需要下载浏览器插件或者小程序,但需要客户允许JavaScript在浏览器上执行。随着Ajax的成熟,一些简化Ajax使用方法的程序库也相继问世。同样,也出现了另一种辅助程序设计的技术,为那些不支持JavaScript的用户提供替代功能。

(5)界面与应用分离。
Ajax使WEB中的界面与应用分离(也可以说是数据与呈现分离),有利于分工合作、减少非技术人员对页面的修改造成的WEB应用程序错误、提高效率、也更加适用于现在的发布系统。

题目2:

前后端开发联调需要注意哪些事情?

(1),发生方式 :是get还是post,后端用同样的方式接收发送过来的数据
(2),统一接口
(3),前端发送什么数据格式给后端

后端接口完成前如何 mock 数据?

使用server-mock模拟前后端数据传输

//后端router.js文件

app.get(function(req,res){})

统一好接口和发生方式,后端router.js获取前端发生过来的数据保存到req里面

var date1=req.query.xx

查询到变量xx的数据复制给date1,date1就是我们获取到的前端发生过来的xx的数据
获取到前端发送全部数据后,进行某些操作
如:

if(date1===1){
//返回数据到客户端
send(2);
}

前端通过ajax的 var arriDate=XMLHttpResqust.responseText
arriDate就保存着后端返回的数据

题目3:

点击按钮,使用 ajax 获取数据,如何在数据到来之前防止重复点击?

添加一个状态锁,记住当前上次数据是否成功响应,如果没有成功响应,return空

        var dateArrive=true;
        //监听按钮单击状态
        Obtn.addEventListener("click",function(){
            
            if(!dateArrive){
                return;
            }
            //调用ajax函数
            loadDate(function(news){
            render(news);
            pageindex=pageindex+5;
            //还原状态,不锁定
            dateArrive=true;
            });
            //锁定状态
            dateArrive=false;
        })

题目4:

封装一个 ajax 函数,能通过如下方式调用。后端在本地使用server-mock来 mock 数据

index.html文件

    <!DOCTYPE html>
    <html>
        <head>
            <meta charset="utf-8" />
            <title></title>
            <style>
                div{
                    text-align: center;
                }
                #btn{
                    padding: 6px 10px;
                    margin-top: 20px;
                }
                #btn:hover{
                    background: darkcyan;
                }
            </style>
        </head>
        <body>
            <div>
                <button id="btn" href="javascript:void(0);">登录</button>
            </div>
            <script>
                var Obtn=document.querySelector("#btn");
                
                function loadDate(render){
                    var obj={
                        url: '/login',   //接口地址
                        type: 'get',               // 类型, post 或者 get,
                        datas: {
                            username: 'xiaoming',
                            passw: 'abcd1234'
                        },
                        success: render,
                        onerror: function(){
                           console.log('出错了')
                        }
                    }
                    ajax(obj);
                }
                
                function render(ret){
                    console.log(ret,"欢迎您"); 
                }
                //ajax请求响应数据
                function ajax(obj){
                    var xhr=new XMLHttpRequest();
                    var str=obj.url+'?';
                    for (key in obj.datas) {
                        str+=key+'='+obj.datas[key]+'&';
                    }
                    str=str.substr(0,str.length-1);
                    xhr.open(obj.type,str,true);
                    xhr.onreadystatechange=function(){
                        if(xhr.readyState===4){
                            if(xhr.status===200||xhr.status===304){
                            var result=xhr.responseText;
                            obj.success(result);
                        }else{
                           obj.onerror;
                        }
                        }
                      
                    }
                    xhr.send();
                }
                
                //监听按钮单击状态
                Obtn.addEventListener("click",function(){
                    
                    //调用ajax函数
                    loadDate(function(news){
                    render(news);
                    });
                })
            </script>
        </body>
    </html>

router.js文件

    app.get('/login',function(req,res){
        var username=req.query.username;
        var passw=req.query.passw;
        var dates;
        
        if(username==='xiaoming'&&passw==='abcd1234') {
            dates="xiaoming";
        }else{
            dates="用户名或密码不正确...";
        }
        res.send(dates);
    })

数据mock成功

图片.png

题目5:

实现加载更多的功能,效果范例81,后端在本地使用server-mock来模拟数据

操作展示
代码

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 199,902评论 5 468
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 84,037评论 2 377
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 146,978评论 0 332
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 53,867评论 1 272
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 62,763评论 5 360
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,104评论 1 277
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,565评论 3 390
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,236评论 0 254
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,379评论 1 294
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,313评论 2 317
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,363评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,034评论 3 315
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,637评论 3 303
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,719评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,952评论 1 255
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,371评论 2 346
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 41,948评论 2 341

推荐阅读更多精彩内容