实例详解jQuery Mockjax 插件模拟 Ajax 请求
1.原理
jquery-mockjax是用于mock前台ajax向后台请求的返回数据。
原理很简单
在你js代码要发送ajax请求的地方断点一下,然后比较在【引入jquery-mockjax】和【没有引入jquery-mockjax】的情况下$.ajax.toString()的值情况。
很明显,引入jquery-mockjax时,这个mock库会对jquery提供的ajax函数做替换。这样就很容易能mock起来。
在实际的开发过程中,前端后台协商好了统一的接口,就各自开始自己的任务了。这时候我有这么一个Ajax请求需要从后台获取数据:
$.ajax({ url:'/products/' }).done(function(res){ $('#result').html(res); });
但是这个服务可能还没有创建,也许是后台开发那个小伙子(就是那些使用PHP、Ruby、.NET、GoldFusion等等语言的帅哥们)开小差去了,也许是他忙于其它事情。总之,当这个请求发出的时候我不能得到我想要的结果,我只能得到一个404(NotFound)错误。
这实在是很糟糕,催促也没有用,旁边的测试人员吵着闹着要测试呢,而我自己也迫切希望看到立竿见影的效果。这个时候,就只能依靠自己了,其中一个比较好的方法就是模拟Ajax请求,这里我使用jQueryMockjax插件。
地址:jQueryMockjax
这是一个jQuery插件,将其下载下来引用的时候放在jQuery之后:
<!DOCTYPEhtml> <html> <head> <title>Test</title> </head> <body> <divid="result"></div> <scriptsrc="http://code.jquery.com/jquery-1.11.1.min.js"></script> <scriptsrc="vendor/jquery.mockjax.js"></script> </body> </html>
然后在请求代码之前执行模拟请求的代码,使用该插件提供的$.mockjax()方法,暂时先指定2个参数url和responseText:
$.mockjax({ url:'/products/', responseText:'Hereyouare!' });
它会监测具有相同url的Ajax请求并在请求发出时拦截同时模拟响应,responseText的值就是模拟的响应内容,这样我的程序就能愉快地执行了,最开始那个例子的运行结果就是'Hereyouare'这段内容将会显示到div#result中。当我不再需要模拟请求的时候可以使用$.mockjax.clear()方法清除掉:
$.mockjax.clear();
一旦后台服务开发完成,我就可以使用该方法清除掉所有模拟请求体验真实的请求效果了。如果不希望一次性清除掉所有的模拟请求,而是针对某个模拟请求,可以传入该模拟请求的ID,每个模拟请求都会返回一个ID值:
varidOne=$.mockjax({}), idTwo=$.mockjax({}); $.mockjax.clear(idTwo);
这样就把第二个模拟请求清除掉了,保留了第一个。
由于Ajax请求的url地址要和模拟请求的url对应,假设页面上有很多请求,每个请求都去模拟的话就会感觉很痛苦,好在,该插件的url参数提供了一个通配符*方式:
$.mockjax({ url:'/books/*' });
这样除了可以匹配url地址为/books/cook的请求还可以匹配地址为/books/math等等更多请求,甚至还可以使用正则表达式进行更复杂的匹配模式:
$.mockjax({ url:/^\/data\/(cook|math)$/i });
使用插件的data参数可以根据不同的请求数据执行不同的模拟响应:
$.mockjax({ url:'/books/', data:{ type:'cook' }, responseText:'Youwantacookbook!' }); $.mockjax({ url:'/books/', data:{ type:'math' }, responseText:{ "content":"Youwantamathbook!" } });
就算是同一个url地址当请求的数据不同的时候获得的响应内容也不一样。响应内容除了纯文本字符串,也可以使用json
格式的字符串。
该插件还提供了一个默认参数设置对象$.mockjaxSettings,没有指定的参数都将使用这些默认值:
$.mockjaxSettings={ logging:true, status:200, statusText:"OK", responseTime:500, isTimeout:false, throwUnmocked:false, contentType:'text/plain', response:'', responseText:'', responseXML:'', proxy:'', proxyType:'GET', lastModified:null, etag:'', headers:{ etag:'IJF@H#@923uf8023hFO@I#H#', 'content-type':'text/plain' } };
将默认值修改之后,后面的模拟请求都会使用修改后的值:
$.mockjaxSettings.contentType="application/json";
这里只修改了其中的contentType的默认值。
以上所述通过实例详解jQueryMockjax插件模拟Ajax请求的相关知识,希望对大家有所帮助。