ajax實踐

1宗挥、ajax 是什么索昂?有什么作用餐茵?

  • ajax炬转,即Asynchronous JavaScript and XML(異步的 JavaScript 和 XML)辆苔。是一種不需要刷新頁面就能向后臺提交或獲取數據的技術算灸,也是一種瀏覽器支持的JS內置對象扼劈。
  • 它最大的作用在于提升用戶瀏覽網頁的過程中的體驗。當用戶向服務器發(fā)送ajax請求時菲驴,網頁不會重置和刷新荐吵,因此用戶等待返回數據的過程中可以進行其它操作。

2赊瞬、前后端開發(fā)聯(lián)調需要注意哪些事情先煎?后端接口完成前如何 mock 數據?

  • 前后端聯(lián)調需要注意以下事項:
    1.確認接口類型(get/post)及接口名稱巧涧;
    2.確認前端發(fā)送的參數類型及格式薯蝎;
    3.確認后端響應所返回的數據類型及格式。
  • 在后端接口完成前谤绳,我們可以使用server-mock占锯,模擬后端服務器袒哥,接收和處理前端的請求。

3消略、點擊按鈕堡称,使用 ajax 獲取數據,如何在數據到來之前防止重復點擊艺演?

我們可以為代碼添加“狀態(tài)鎖”却紧,保證數據返回之前,用戶的重復點擊無效胎撤。例如:

<script>
    var btn = document.querySelector('#load-more')
    var ct = document.querySelector('#ct')
    var pageIndex = 3
    var isDataArrive = true     //1晓殊、默認狀態(tài)下,用戶的點擊是有效的伤提。
    btn.addEventListener('click',function(){
        if(isDataArrive){     //2挺物、當isDataArrive = true時,才執(zhí)行后續(xù)的語句飘弧。
            var xhr = new XMLHttpRequest()
            xhr.onreadystatechange = function(){
                if(xhr.readyState ===4){
                    if(xhr.status === 200 || xhr.status === 304){
                        var results = JSON.parse(xhr.responseText)
                        var fragment = document.createDocumentFragment()
                        for(var i = 0; i < results.length; i++){
                            var node = document.createElement('li')
                            node.innerText = results[i]
                            fragment.appendChild(node)
                        }
                        ct.appendChild(fragment)
                        pageIndex = pageIndex + 6
                    }else{
                    console.log('出錯了')
                    }
                    isDataArrive = true     //4识藤、當瀏覽器接收到后端返回的數據后,在頁面進行了展示次伶,同時將isDataArrive值更改為true痴昧,此時用戶就可以再次點擊了。
                }
            }
            xhr.open('get','/loadMore?index=' + pageIndex + '&length=6',true)
            xhr.send()
            isDataArrive = false     //3冠王、當用戶點擊后赶撰,瀏覽器立刻向服務器發(fā)送請求,同時將isDataArrive值更改為false柱彻,即此時用戶點擊是無效的豪娜。
        }
    })
</script>

4、實現加載更多的功能哟楷,后端在本地使用server-mock來模擬數據瘤载。

代碼如下:

//html部分
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>加載更多</title>
    <style>
        ul,li{
            margin: 0;
            padding: 0;
        }
        li{
            list-style: none;
            margin-top: 10px;
            padding: 10px;
            border: 1px solid lightgray;
            cursor: pointer;
        }
        li:hover{
            color: white;
            background: green;
        }
        .btn{
            display: block;
            margin: 10px auto;
            width: 80px;
            height: 40px;
            color: #E27272;
            line-height: 40px;
            text-align: center;
            text-decoration: none;
            border: 1px solid #E27272;
            border-radius: 3px;
            cursor: pointer;
        }
    </style>
</head>
<body>
    <ul id="ct">
        <li>內容1</li>
        <li>內容2</li>
    </ul>
    <a id="load-more" class="btn" href="javascript:void(0)">加載更多</a>
</body>
<script>
    var btn = document.querySelector('#load-more')
    var ct = document.querySelector('#ct')
    var pageIndex = 3
    var isDataArrive = true
    btn.addEventListener('click',function(){
        if(isDataArrive){
            var xhr = new XMLHttpRequest()
            xhr.onreadystatechange = function(){
                if(xhr.readyState ===4){
                    if(xhr.status === 200 || xhr.status === 304){
                        var results = JSON.parse(xhr.responseText)
                        var fragment = document.createDocumentFragment()
                        for(var i = 0; i < results.length; i++){
                            var node = document.createElement('li')
                            node.innerText = results[i]
                            fragment.appendChild(node)
                        }
                        ct.appendChild(fragment)
                        pageIndex = pageIndex + 6
                    }else{
                    console.log('出錯了')
                    }
                    isDataArrive = true
                }
            }
            xhr.open('get','/loadMore?index=' + pageIndex + '&length=6',true)
            xhr.send()
            isDataArrive = false
        }
    })
</script>
</html>
//router.js部分
app.get('/loadMore',function(req, res){
    var curIdx = req.query.index
    var len = req.query.length
    var data = []
    for(var i = 0; i < len; i++){
        data.push('內容' + (parseInt(curIdx) + i))
    }
    setTimeout(function(){
        res.send(data)
    },3000)
})
最后編輯于
?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市卖擅,隨后出現的幾起案子鸣奔,更是在濱河造成了極大的恐慌,老刑警劉巖惩阶,帶你破解...
    沈念sama閱讀 211,817評論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件挎狸,死亡現場離奇詭異,居然都是意外死亡断楷,警方通過查閱死者的電腦和手機锨匆,發(fā)現死者居然都...
    沈念sama閱讀 90,329評論 3 385
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來冬筒,“玉大人恐锣,你說我怎么就攤上這事紊遵。” “怎么了侥蒙?”我有些...
    開封第一講書人閱讀 157,354評論 0 348
  • 文/不壞的土叔 我叫張陵暗膜,是天一觀的道長。 經常有香客問我鞭衩,道長学搜,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,498評論 1 284
  • 正文 為了忘掉前任论衍,我火速辦了婚禮瑞佩,結果婚禮上,老公的妹妹穿的比我還像新娘坯台。我一直安慰自己炬丸,他們只是感情好,可當我...
    茶點故事閱讀 65,600評論 6 386
  • 文/花漫 我一把揭開白布蜒蕾。 她就那樣靜靜地躺著稠炬,像睡著了一般。 火紅的嫁衣襯著肌膚如雪咪啡。 梳的紋絲不亂的頭發(fā)上首启,一...
    開封第一講書人閱讀 49,829評論 1 290
  • 那天,我揣著相機與錄音撤摸,去河邊找鬼毅桃。 笑死,一個胖子當著我的面吹牛准夷,可吹牛的內容都是我干的钥飞。 我是一名探鬼主播,決...
    沈念sama閱讀 38,979評論 3 408
  • 文/蒼蘭香墨 我猛地睜開眼衫嵌,長吁一口氣:“原來是場噩夢啊……” “哼读宙!你這毒婦竟也來了?” 一聲冷哼從身側響起渐扮,我...
    開封第一講書人閱讀 37,722評論 0 266
  • 序言:老撾萬榮一對情侶失蹤论悴,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后墓律,有當地人在樹林里發(fā)現了一具尸體,經...
    沈念sama閱讀 44,189評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡幔亥,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 36,519評論 2 327
  • 正文 我和宋清朗相戀三年耻讽,在試婚紗的時候發(fā)現自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片帕棉。...
    茶點故事閱讀 38,654評論 1 340
  • 序言:一個原本活蹦亂跳的男人離奇死亡针肥,死狀恐怖饼记,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情慰枕,我是刑警寧澤具则,帶...
    沈念sama閱讀 34,329評論 4 330
  • 正文 年R本政府宣布,位于F島的核電站具帮,受9級特大地震影響博肋,放射性物質發(fā)生泄漏。R本人自食惡果不足惜蜂厅,卻給世界環(huán)境...
    茶點故事閱讀 39,940評論 3 313
  • 文/蒙蒙 一匪凡、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧掘猿,春花似錦病游、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,762評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至改橘,卻和暖如春佣耐,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背唧龄。 一陣腳步聲響...
    開封第一講書人閱讀 31,993評論 1 266
  • 我被黑心中介騙來泰國打工兼砖, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人既棺。 一個月前我還...
    沈念sama閱讀 46,382評論 2 360
  • 正文 我出身青樓讽挟,卻偏偏與公主長得像,于是被迫代替她去往敵國和親丸冕。 傳聞我的和親對象是個殘疾皇子耽梅,可洞房花燭夜當晚...
    茶點故事閱讀 43,543評論 2 349

推薦閱讀更多精彩內容