编写自己的javascript功能库之Ajax(仿jquery方式),ajaxjquery_PHP教程
编写自己的javascript功能库之Ajax(仿jquery方式),ajaxjquery
本人学习的是php,所以就用php跟js来演示代码了,主要是锻炼自己写js的能力,练练手而已。
下面这是我编写的操作ajax的代码功能,勉强让我称之为库吧。。
js代码实例(tool.ajax.js):
<span> 1</span> <span>/** </span><span> 2</span> <span> * JS库 使用ajax </span><span> 3</span> <span> * @author jlb </span><span> 4</span> <span> */ </span><span> 5</span> <span>if(typeof tool == 'undefined') { </span><span> 6</span> <span> var tool = function(){}; </span><span> 7</span> <span>} </span><span> 8</span> <span>tool.ajax = function(){}; </span><span> 9</span> <span>10</span> <span>11</span> <span>/** </span><span>12</span> <span> * 获取ajax对象 </span><span>13</span> <span> * @return 成功返回ajax对象 </span><span>14</span> <span> */ </span><span>15</span> <span>tool.ajax.getAjaxObject = function () { </span><span>16</span> <span> try{return new XMLHttpRequest()}catch(e){} </span><span>17</span> <span> try{return new ActiveXOject('Microsoft.XMLHTTP')}catch(e){} </span><span>18</span> <span> alert('您的浏览器版本过低!请升级您的浏览器'); </span><span>19</span> <span>} </span><span>20</span> <span>21</span> <span>22</span> <span>/** </span><span>23</span> <span> * ajax提交数据 </span><span>24</span> <span> * @param 参数列表 </span><span>25</span> <span> * @return void </span><span>26</span> <span> */ </span><span>27</span> <span>tool.ajax.formSubmit = function (options) { </span><span>28</span> <span> var allow_param, //允许的参数列表 </span><span>29</span> <span> HTTP, //ajax对象 </span><span>30</span> <span> url, //请求的地址 </span><span>31</span> <span> data; //携带的数据 </span><span>32</span> <span>33</span> <span> allow_param = ['method', 'url', 'data', 'success', 'type']; </span><span>34</span> <span> //设置默认值 </span><span>35</span> <span> if(!options['type']) { </span><span>36</span> <span> options['type'] == 'text'; </span><span>37</span> <span> } </span><span>38</span> <span>39</span> <span> //处理url与数据, 将数据与URL合并 </span><span>40</span> <span> var disposeParam = function (list) { </span><span>41</span> <span> var data = {url:list['url'],data:''}; </span><span>42</span> <span> if(list['method'] == 'get') { </span><span>43</span> <span> data['data'] += '?'; </span><span>44</span> <span> for (var i in list['data']) { </span><span>45</span> <span> data['data'] += i + '=' + list['data'][i] + '&'; </span><span>46</span> <span> } </span><span>47</span> <span> } </span><span>48</span> <span> if(list['method'] == 'post') { </span><span>49</span> <span> for (var i in list['data']) { </span><span>50</span> <span> data['data'] += i + '=' + list['data'][i] + '&'; </span><span>51</span> <span> } </span><span>52</span> <span> } </span><span>53</span> <span> return data </span><span>54</span> <span> } </span><span>55</span> <span> data = disposeParam(options); </span><span>56</span> <span> HTTP = tool.ajax.getAjaxObject(); </span><span>57</span> <span> //ajax回调函数 </span><span>58</span> <span> HTTP.onreadystatechange = function () { </span><span>59</span> <span> if(HTTP.readyState == 4 && HTTP.status == 200) { </span><span>60</span> <span> if(options['type'] == 'text') { </span><span>61</span> <span> options['success'](HTTP.responseText); </span><span>62</span> <span> } </span><span>63</span> <span> else if(options['type'] == 'json') { </span><span>64</span> <span> options['success'](eval('(' + HTTP.responseText + ')')); </span><span>65</span> <span> } </span><span>66</span> <span> } </span><span>67</span> <span> } </span><span>68</span> <span>69</span> <span> if(options['method'] == 'get') { </span><span>70</span> <span> url = data['url'] + data['data']; </span><span>71</span> <span> HTTP.open(options['method'],url); </span><span>72</span> <span> //设置请求头解决get提交有缓存问题,通过修改文件最后修改时间解决 </span><span>73</span> <span> HTTP.setRequestHeader('If-Modified-Since', 0); </span><span>74</span> <span> HTTP.send(null); </span><span>75</span> <span> return; </span><span>76</span> <span> } </span><span>77</span> <span>78</span> <span> if(options['method'] == 'post') { </span><span>79</span> <span> HTTP.open(options['method'], data['url']); </span><span>80</span> <span> //设置请求头 </span><span>81</span> <span> HTTP.setRequestHeader('Content-type', 'application/x-www-form-urlencoded'); </span><span>82</span> <span> HTTP.send(data['data'].replace(/(&*$)/g,'')); </span><span>83</span> <span> return; </span><span>84</span> <span> } </span><span>85</span> }
使用实例(ajax_test.html):
<span> 1</span> <span><!</span><span>DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"</span><span>></span> <span> 2</span> <span><</span><span>html </span><span>lang</span><span>="en"</span><span>></span> <span> 3</span> <span><</span><span>head</span><span>></span> <span> 4</span> <span><</span><span>meta </span><span>http-equiv</span><span>="Content-Type"</span><span> content</span><span>="text/html;charset=UTF-8"</span><span>></span> <span> 5</span> <span><</span><span>title</span><span>></span>简单ajax功能库用法示例<span></</span><span>title</span><span>></span> <span> 6</span> <span></</span><span>head</span><span>></span> <span> 7</span> <span><</span><span>body</span><span>></span> <span> 8</span> <span><!--</span><span>引入编写好的tool.ajax.js文件</span><span>--></span> <span> 9</span> <span><</span><span>script </span><span>src</span><span>="tool.ajax.js"</span><span>></</span><span>script</span><span>></span> <span>10</span> <span><</span><span>script</span><span>></span> <span>11</span> <span>//</span><span>ajax_test.html</span> <span>12</span> <span>13</span> <span>//</span><span>仿jquery方式ajax请求</span> <span>14</span> <span>var</span><span> options </span><span>=</span><span> { </span><span>15</span> <span> url : </span><span>"</span><span>ajax_test.php</span><span>"</span><span>, </span><span>//</span><span>请求的脚本地址</span> <span>16</span> <span> method : </span><span>"</span><span>get</span><span>"</span><span>, </span><span>//</span><span>是get还是post,注意必须是小写哦..懒得转了...</span> <span>17</span> <span> data : {name:</span><span>"</span><span>莫问出处丶</span><span>"</span><span>,age: </span><span>20</span><span>}, </span><span>//</span><span> 要携带的数据,只支持json格式</span> <span>18</span> <span> success : </span><span>function</span><span> (msg) { </span><span>//</span><span>请求完毕后回调函数..</span> <span>19</span> <span> alert(msg); </span><span>20</span> <span> }, </span><span>21</span> <span> type : </span><span>'</span><span>text</span><span>'</span><span>, </span><span>//</span><span>不写默认就是text,也就是说回调函数携带的数据是字符串.另外就是json</span> <span>22</span> <span> }; </span><span>23</span> <span>24</span> <span> tool.ajax.formSubmit(options); </span><span>25</span> <span></</span><span>script</span><span>></span> <span>26</span> <span></</span><span>body</span><span>></span> <span>27</span> <span></</span><span>html</span><span>></span>
ajax请求的脚本代码(ajax_test.php):
<span>1</span> <?<span>php </span><span>2</span> <span>//</span><span>ajax_test.php</span> <span>3</span> <span>echo</span> "名字:{<span>$_GET</span>['name']} 年龄: {<span>$_GET</span>['age']}";
在浏览器打开ajax_test.html这文件,浏览器显示:
名字:莫问出处丶 年龄: 20
如果返回的数据是json格式将option 中的 type 属性的值改为 json即可
有什么问题就评论留言我吧,第一次写博客,有点小激动.本菜鸟迈出第一步了.

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

热门话题

jQuery引用方法详解:快速上手指南jQuery是一个流行的JavaScript库,被广泛用于网站开发中,它简化了JavaScript编程,并为开发者提供了丰富的功能和特性。本文将详细介绍jQuery的引用方法,并提供具体的代码示例,帮助读者快速上手。引入jQuery首先,我们需要在HTML文件中引入jQuery库。可以通过CDN链接的方式引入,也可以下载

jQuery如何移除元素的height属性?在前端开发中,经常会遇到需要操作元素的高度属性的需求。有时候,我们可能需要动态改变元素的高度,而有时候又需要移除元素的高度属性。本文将介绍如何使用jQuery来移除元素的高度属性,并提供具体的代码示例。在使用jQuery操作高度属性之前,我们首先需要了解CSS中的height属性。height属性用于设置元素的高度

jQuery中如何使用PUT请求方式?在jQuery中,发送PUT请求的方法与发送其他类型的请求类似,但需要注意一些细节和参数设置。PUT请求通常用于更新资源,例如更新数据库中的数据或更新服务器上的文件。以下是在jQuery中使用PUT请求方式的具体代码示例。首先,确保引入了jQuery库文件,然后可以通过以下方式发送PUT请求:$.ajax({u

jQuery是一款广泛应用于前端开发的快速、小巧、功能丰富的JavaScript库。自2006年发布以来,jQuery已经成为众多开发者的首选工具之一,但是在实际应用中,它也不乏一些优势和劣势。本文将深度剖析jQuery的优势与劣势,并结合具体的代码示例进行说明。优势:1.简洁的语法jQuery的语法设计简洁明了,可以大大提高代码的可读性和编写效率。比如,

标题:jQuery小技巧:快速修改页面所有a标签的文本在网页开发中,我们经常需要对页面中的元素进行修改和操作。在使用jQuery时,有时候需要一次性修改页面中所有a标签的文本内容,这样可以节省时间和精力。下面将介绍如何使用jQuery快速修改页面所有a标签的文本,同时给出具体的代码示例。首先,我们需要引入jQuery库文件,确保在页面中引入了以下代码:<

标题:使用jQuery修改所有a标签的文本内容jQuery是一款流行的JavaScript库,被广泛用于处理DOM操作。在网页开发中,经常会遇到需要修改页面上链接标签(a标签)的文本内容的需求。本文将介绍如何使用jQuery来实现这个目标,并提供具体的代码示例。首先,我们需要在页面中引入jQuery库。在HTML文件中添加以下代码:

如何判断jQuery元素是否具有特定属性?在使用jQuery操作DOM元素时,经常会遇到需要判断元素是否具有某个特定属性的情况。这种情况下,我们可以借助jQuery提供的方法来轻松实现这一功能。下面将介绍两种常用的方法来判断一个jQuery元素是否具有特定属性,并附上具体的代码示例。方法一:使用attr()方法和typeof操作符//判断元素是否具有特定属

jQuery是一种流行的JavaScript库,被广泛用于处理网页中的DOM操作和事件处理。在jQuery中,eq()方法是用来选择指定索引位置的元素的方法,具体使用方法和应用场景如下。在jQuery中,eq()方法选择指定索引位置的元素。索引位置从0开始计数,即第一个元素的索引是0,第二个元素的索引是1,依此类推。eq()方法的语法如下:$("s
