Node.js伺服器環境下使用Mock.js攔截AJAX請求的教程_node.js

來源:互聯網
上載者:User

0、Node環境下安裝和使用Mock

# 安裝npm install mockjs
// 使用 Mockvar Mock = require('mockjs')var data = Mock.mock({  // 屬性 list 的值是一個數組,其中含有 1 到 10 個元素  'list|1-10': [{    // 屬性 id 是一個自增數,起始值為 1,每次增 1    'id|+1': 1  }]})// 輸出結果console.log(JSON.stringify(data, null, 4))

1、攔截 ajax 請求調用
方法如下

Mock.mock( rurl?, rtype?, template|function( options ) )

方法說明:
(1)rurl: 選擇性參數。

表示需要攔截的 URL,可以是 URL 字串或 URL 正則。例如 /\/domain\/list\.json/、'/domian/list.json'。
(2)rtype:選擇性參數。

 表示需要攔截的 Ajax 請求類型。例如 GET、POST、PUT、DELETE 等。
(3)template|function:必選參數,只取其中一項。

(4)template 表示資料範本,可以是對象或字串。例如 { 'data|1-10':[{}] }、'@EMAIL'。
(5)function 指向本次請求的 Ajax 選項集,含有 url、type 和 body 三個屬性,參見 XMLHttpRequest 規範。
提示

從 1.0 開始,Mock.js 通過覆蓋和類比原生 XMLHttpRequest 的行為來攔截 Ajax 請求,不再依賴於第三方 Ajax 工具庫(例如 jQuery、Zepto 等)。

2. 攔截 Ajax 請求逾時
配置攔截 Ajax 請求時的行為。支援的配置項有:timeout。

(1)Mock.setup( settings )
(2)settings
必選。
配置項集合。
(3)timeout
可選。
指定被攔截的 Ajax 請求的回應時間,單位是毫秒。值可以是正整數,例如 400,表示 400 毫秒 後才會返迴響應內容;也可以是橫杠 '-' 風格的字串,例如 '200-600',表示回應時間介於 200 和 600 毫秒之間。預設值是'10-100'。

3. 本人理解的攔截
使用同一個方法名,去欄截指定方法。通過 call 修改 this 指向,到達 攔截。

// 實現原理// 定義父類var mock_ajax = function(str){ this.showName=function(){ console.log(str); } return this;};// 定義子類var jquery_ajax = function(str){ this.showName = function(){ console.log('ajax'); } return this;};jquery_ajax('').showName();// -> ajax// 改變 this 指向mock_ajax.call(jquery_ajax,'111');// 調用jquery_ajax.showName();

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.