欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Ajax獲取node服務(wù)器數(shù)據(jù)的完整步驟

 更新時(shí)間:2020年09月20日 11:12:18   作者:幸福的code1  
這篇文章主要給大家介紹了關(guān)于Ajax獲取node服務(wù)器數(shù)據(jù)的完整步驟,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧

1.準(zhǔn)備

因?yàn)槭且獙⒎?wù)器獲取的數(shù)據(jù)放在網(wǎng)頁(yè)中 所以說(shuō)對(duì)頁(yè)面的渲染是必要的 這里我準(zhǔn)備的是 art-template模板

2.服務(wù)器的準(zhǔn)備

服務(wù)器要準(zhǔn)備好渲染到頁(yè)面的數(shù)據(jù)

3.頁(yè)面的操作

這里我做的的是一個(gè)搜索框提示功能 講解都在代碼注釋中

服務(wù)器代碼如下

// 輸入框文字提示
app.get("/searchAutoPrompt", (req, res) => {
 // 搜索關(guān)鍵字
 const key = req.query.key;
 // 提示文字列表
 const list = ["百度", "百度官網(wǎng)", "百度游戲", "百度網(wǎng)盤"];
 // 搜索結(jié)果 filter是一個(gè)遍歷的函數(shù) includes(key)是凡是字符串含有key都返回
 let result = list.filter((item) => item.includes(key));
 // 將查詢結(jié)果返回給客戶端
 res.send(result);
});

頁(yè)面代碼:

下面的代碼我用了一個(gè)封裝好的Ajax函數(shù)

代碼如下

function ajax (options) {
 // 默認(rèn)值
 var defaults = {
  type: 'get',
  url: '',
  async: true,
  data: {},
  header: {
   'Content-Type': 'application/x-www-form-urlencoded'
  },
  success: function () {},
  error: function () {}
 }
 // 使用用戶傳遞的參數(shù)替換默認(rèn)值參數(shù)
 Object.assign(defaults, options);
 // 創(chuàng)建ajax對(duì)象
 var xhr = new XMLHttpRequest();
 // 參數(shù)拼接變量
 var params = '';
 // 循環(huán)參數(shù)
 for (var attr in defaults.data) {
  // 參數(shù)拼接
  params += attr + '=' + defaults.data[attr] + '&';
  // 去掉參數(shù)中最后一個(gè)&
  params = params.substr(0, params.length-1)
 }
 // 如果請(qǐng)求方式為get
 if (defaults.type == 'get') {
  // 將參數(shù)拼接在url地址的后面
  defaults.url += '?' + params;
 }

 // 配置ajax請(qǐng)求
 xhr.open(defaults.type, defaults.url, defaults.async);
 // 如果請(qǐng)求方式為post
 if (defaults.type == 'post') {
  // 設(shè)置請(qǐng)求頭
  xhr.setRequestHeader('Content-Type', defaults.header['Content-Type']);
  // 如果想服務(wù)器端傳遞的參數(shù)類型為json
  if (defaults.header['Content-Type'] == 'application/json') {
   // 將json對(duì)象轉(zhuǎn)換為json字符串
   xhr.send(JSON.stringify(defaults.data))
  }else {
   // 發(fā)送請(qǐng)求
   xhr.send(params);
  }
 } else {
  xhr.send();
 }
 // 請(qǐng)求加載完成
 xhr.onload = function () {
  // 獲取服務(wù)器端返回?cái)?shù)據(jù)的類型
  var contentType = xhr.getResponseHeader('content-type');
  // 獲取服務(wù)器端返回的響應(yīng)數(shù)據(jù)
  var responseText = xhr.responseText;
  // 如果服務(wù)器端返回的數(shù)據(jù)是json數(shù)據(jù)類型
  if (contentType.includes('application/json')) {
   // 將json字符串轉(zhuǎn)換為json對(duì)象
   responseText = JSON.parse(responseText);
  }
  // 如果請(qǐng)求成功
  if (xhr.status == 200) {
   // 調(diào)用成功回調(diào)函數(shù), 并且將服務(wù)器端返回的結(jié)果傳遞給成功回調(diào)函數(shù)
   defaults.success(responseText, xhr);
  } else {
   // 調(diào)用失敗回調(diào)函數(shù)并且將xhr對(duì)象傳遞給回調(diào)函數(shù)
   defaults.error(responseText, xhr);
  } 
 }
 // 當(dāng)網(wǎng)絡(luò)中斷時(shí)
 xhr.onerror = function () {
  // 調(diào)用失敗回調(diào)函數(shù)并且將xhr對(duì)象傳遞給回調(diào)函數(shù)
  defaults.error(xhr);
 }
}


<script src="/js/ajax.js"></script>
<script src="/js/template-web.js"></script>
<script type="text/html" id="tpl">
 {{each result}}
  <li class="list-group-item">{{$value}}</li>
 {{/each}}
</script>
<script>
 // 獲取搜索框
 var searchInp = document.getElementById('search');
 // 獲取提示文字的存放容器
 var listBox = document.getElementById('list-box');
 //這里用定時(shí)器是為了優(yōu)化 定時(shí)向服務(wù)器發(fā)送請(qǐng)求 優(yōu)化了對(duì)服務(wù)器的壓力
 // 存儲(chǔ)定時(shí)器的變量
 var timer = null;
 // 當(dāng)用戶在文本框中輸入的時(shí)候觸發(fā)
 searchInp.oninput = function () {
  // 清除上一次開啟的定時(shí)器
  clearTimeout(timer);
  // 獲取用戶輸入的內(nèi)容
  var key = this.value;
  // 如果用戶沒有在搜索框中輸入內(nèi)容
  if (key.trim().length == 0) {
   // 將提示下拉框隱藏掉
   listBox.style.display = 'none';
   // 阻止程序向下執(zhí)行
   return;
  }

  // 開啟定時(shí)器 讓請(qǐng)求延遲發(fā)送
  timer = setTimeout(function () {
   // 向服務(wù)器端發(fā)送請(qǐng)求
   // 向服務(wù)器端索取和用戶輸入關(guān)鍵字相關(guān)的內(nèi)容
   ajax({
    type: 'get',
    url: 'http://localhost:3000/searchAutoPrompt',
    data: {
     key: key
    },
    success: function (result) {
     // 使用模板引擎拼接字符串
     var html = template('tpl', {result: result});
     // 將拼接好的字符串顯示在頁(yè)面中
     listBox.innerHTML = html;
     // 顯示ul容器
     listBox.style.display = 'block';
    }
   })
  }, 800)
  
 }
</script>

總結(jié)

到此這篇關(guān)于Ajax獲取node服務(wù)器數(shù)據(jù)的文章就介紹到這了,更多相關(guān)Ajax獲取node服務(wù)器數(shù)據(jù)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • NodeJS實(shí)現(xiàn)圖片上傳代碼(Express)

    NodeJS實(shí)現(xiàn)圖片上傳代碼(Express)

    本篇文章主要介紹了NodeJS實(shí)現(xiàn)圖片上傳代碼(Express) ,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-06-06
  • Node.js中的cluster模塊深入解讀

    Node.js中的cluster模塊深入解讀

    NodeJS引入了Cluster模塊試圖簡(jiǎn)化這些體力勞動(dòng),使用Cluster模塊可以運(yùn)行并管理多個(gè)實(shí)例進(jìn)程,下面這篇文章主要給大家介紹了關(guān)于Node.js中cluster模塊的相關(guān)資料,需要的朋友可以參考借鑒,下面來(lái)一起看看吧
    2018-06-06
  • Node+Express搭建HTTPS服務(wù)的實(shí)現(xiàn)

    Node+Express搭建HTTPS服務(wù)的實(shí)現(xiàn)

    最近開發(fā)需要搭建一個(gè)https的服務(wù),正好最近在用nodejs和express,本文章主要介紹了Node+Express搭建HTTPS服務(wù)的實(shí)現(xiàn),具有一定的參考價(jià)值,感興趣的可以了解一下
    2023-12-12
  • nodejs中request庫(kù)使用HTTPS代理的方法

    nodejs中request庫(kù)使用HTTPS代理的方法

    這篇文章主要介紹了nodejs中request庫(kù)使用HTTPS代理的方法,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2019-04-04
  • koa2 從入門到精通(小結(jié))

    koa2 從入門到精通(小結(jié))

    這篇文章主要介紹了koa2 從入門到精通,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-07-07
  • Node.js安裝教程和NPM包管理器使用詳解

    Node.js安裝教程和NPM包管理器使用詳解

    這篇文章主要介紹了Node.js安裝教程和NPM包管理器使用詳解,安裝部分講解了Windows、和MAC OS下的安裝圖解,并介紹了Linux下的源碼安裝方法,最后對(duì)NPM包管理器做了詳細(xì)介紹,需要的朋友可以參考下
    2014-08-08
  • WebSocket實(shí)現(xiàn)簡(jiǎn)單客服聊天系統(tǒng)

    WebSocket實(shí)現(xiàn)簡(jiǎn)單客服聊天系統(tǒng)

    這篇文章主要為大家詳細(xì)介紹了WebSocket實(shí)現(xiàn)簡(jiǎn)單客服聊天系統(tǒng),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-05-05
  • 詳解NODEJS的http實(shí)現(xiàn)

    詳解NODEJS的http實(shí)現(xiàn)

    這篇文章主要介紹了詳解NODEJS的http實(shí)現(xiàn)的技術(shù)過(guò)程以及詳細(xì)分析,需要的朋友學(xué)習(xí)參考下吧。
    2018-01-01
  • 通過(guò)Nodejs搭建網(wǎng)站簡(jiǎn)單實(shí)現(xiàn)注冊(cè)登錄流程

    通過(guò)Nodejs搭建網(wǎng)站簡(jiǎn)單實(shí)現(xiàn)注冊(cè)登錄流程

    這篇文章主要介紹了通過(guò)Nodejs搭建網(wǎng)站簡(jiǎn)單實(shí)現(xiàn)注冊(cè)登錄流程,Node.js 是一個(gè)基于 Chrome V8 引擎的 JavaScript 運(yùn)行環(huán)境。 Node.js 使用了一個(gè)事件驅(qū)動(dòng)、非阻塞式 I/O 的模型,使其輕量又高效。,需要的朋友可以參考下
    2019-06-06
  • 使用Node.js實(shí)現(xiàn)Clean?Architecture方法示例詳解

    使用Node.js實(shí)現(xiàn)Clean?Architecture方法示例詳解

    這篇文章主要為大家介紹了使用Node.js實(shí)現(xiàn)Clean?Architecture方法示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-02-02

最新評(píng)論