封装自己的ajax类库

首先封装自己的 jQuery库

  1. 启发:css的元素选择器思想

  2. 简单的代码实现

    function jQuery(selector){
    
        if(typeof selector == "string"){
    if(selector.charAt(0) == "#"){
    //原先的dom对象还要留着,因为最终的实现还要用这些对象的方法去实现,我们无法完成
    //domObj为全局变量
    domObj = document.getElementById(selector.substring(1))
    //但是由于封装了新方法,所以原先的dom对象就暂时不能用了(调用不了我们自定义的方法),要返回自定义的jQuery对象
    return new jQuery()
    //如果要真正起到修改作用,必须用domObj,如果要调用我们自己扩展的方法必须用 jQuery对象
    //所以可行的方法是:在我们自定义的方法里操作原生的domObj对象
    }
    } if(typeof selector == "function"){
    window.onload = selector
    } this.html = function(innerData){
    domObj.innerHTML = innerData
    } this.click = function(fun){
    domObj.onclick = fun
    } //既可以取值,又可以改值
    this.val = function(v){
    if(v == undefined){
    return domObj.value
    }else{
    domObj.value = v
    }
    } this.change = function(fun){
    domObj.onchange = fun
    } $ = jQuery

封装自己的ajax请求

  1. 简单代码实现

    function jQuery(selector){
    
        if(typeof selector == "string"){
    if(selector.charAt(0) == "#"){
    //原先的dom对象还要留着,因为最终的实现还要用这些对象的方法去实现,我们无法完成
    domObj = document.getElementById(selector.substring(1))
    //但是由于封装了新方法,所以原先的dom对象就暂时不能用了(调用不了我们自定义的方法),要返回自定义的jQuery对象
    return new jQuery()
    }
    } if(typeof selector == "function"){
    window.onload = selector
    } this.html = function(innerData){
    domObj.innerHTML = innerData
    } this.click = function(fun){
    domObj.onclick = fun
    } this.val = function(v){
    if(v == undefined){
    return domObj.value
    }else{
    domObj.value = v
    }
    } this.change = function(fun){
    domObj.onchange = fun
    } /**
    * 有一些动态的数据不能写死
    * 动态的信息有:
    * 1. 请求的类型
    * 2. 请求的地址
    * 3. 是否异步
    * 4. 提交的数据
    */
    jQuery.ajax = function(jsonArgs) {
    var method = jsonArgs.type.toUpperCase()
    var xhr = new XMLHttpRequest()
    //发送ajax请求,将文本框里的数据提交至后端
    xhr.onreadystatechange = function () {
    if (this.readyState == 4) {
    if (this.status == 200) {
    var jsonObj = JSON.parse(this.responseText)
    jsonArgs.callBack(jsonObj)
    } else {
    alert("异常状态码: " + this.status)
    }
    }
    }
    if (method == "POST") {
    xhr.open(method, jsonArgs.url, jsonArgs.async)
    xhr.setRequestHeader("Content-Type", "application/x-www-form-urlencoded")
    xhr.send(jsonArgs.data)
    }
    if (method == "GET") {
    jsonArgs.data = "?" + jsonArgs.data
    xhr.open(method, jsonArgs.url + jsonArgs.data, jsonArgs.async)
    xhr.send()
    }
    }
    } $ = jQuery new jQuery()
  2. 调用的代码

    <!DOCTYPE html>
    <html lang="en">
    <head>
    <title>全面测试jQuery类库</title>
    <meta charset="UTF-8">
    </head>
    <body>
    <script src="/ajax/js/jQuery-1.0.0.js"></script>
    <script>
    $(function(){
    $("#btn").click(function (){
    $.ajax({
    type : "POST",
    data : "username=" + $("#username").val(),
    async : true,
    url : "/ajax/ajaxRequest10",
    callBack : function(json){
    $("#the-div").html(json.name)
    //自定义回调函数,个性化的处理后端返回的数据
    }
    })
    })
    })
    </script>
    <input type="text" id="username">
    <input type="button" id="btn" value="点击回显数据">
    <div id="the-div"></div>
    </body>
    </html>

ajax02_封装自己的jQuery库和ajax请求的更多相关文章

  1. 关于JQuery中的ajax请求或者post请求的回调方法中的操作执行或者变量修改没反映的问题

    前段时间做一个项目,而项目中所有的请求都要用jquery 中的ajax请求或者post请求,但是开始处理一些简单操作还好,但是自己写了一些验证就出现问题了,比如表单提交的时候,要验证帐号的唯一性,所以 ...

  2. JavaScript原生封装ajax请求和Jquery中的ajax请求

    前言:ajax的神奇之处在于JavaScript 可在不重载页面的情况与 Web 服务器交换数据,即在不需要刷新页面的情况下,就可以产生局部刷新的效果.Ajax 在浏览器与 Web 服务器之间使用异步 ...

  3. jquery中的ajax请求到php(学生笔记)

    首先ajax的基本语法基础.(必须得引入一个jquery文件,下面的例子展示用了网上的jquery文件,要联网.) 2.请求成功(复制代码运行观察效果) <!DOCTYPE html> & ...

  4. jquery版本的ajax请求

    首先引入 <script src="https://code.jquery.com/jquery-3.6.0.js"></script>   $ 和 jqu ...

  5. Jquery progressbar通过Ajax请求获取后台进度演示

    项目源代码下载:http://download.csdn.net/detail/nuptboyzhb/6262253 1.简介 本文主要演示Jquery progressbar的进度条功能.js通过a ...

  6. 论如何把JS踩在脚下 —— JQuery基础及Ajax请求详解

    一.什么是JQuery? JQuery是一种JavaScript框架,是一堆大神搞出来的能够让前端程序猿敲更少代码.实现更多功能的工具(在此,跪谢各位JQuery开发大大们!!!).JQuery的使用 ...

  7. jQuery选择器,Ajax请求

    jQuery选择器: $("#myELement") 选择id值等于myElement的元素,id值不能重复在文档中只能有一个id值是myElement所以得到的是唯一的元素 $( ...

  8. jquery中的ajax请求用法以及参数详情

    url: 要求为String类型的参数,(默认为当前页地址)发送请求的地址. type: 要求为String类型的参数,请求方式(post或get)默认为get.注意其他http请求方法,例如put和 ...

  9. Jquery监听AJAX请求

    .ajaxComplete() 当Ajax请求完成后注册一个回调函数.这是一个 AjaxEvent. .ajaxError() Ajax请求出错时注册一个回调处理函数,这是一个 Ajax Event. ...

随机推荐

  1. Docker系列教程04-Docker构建镜像的三种方式

    简介 创建镜像的方法主要有三种:基于已有镜像的容器创建.基于本地模板导入.基于Dockerfile创建. 今天就逐一讲述为大家讲述,如何构建属于自己的docker镜像. 1.基于容器构建镜像 基于已有 ...

  2. 前端HTML-01

    HTML是什么? 超文本标记语言,是一种用于创建网页的标记语言 文件的扩展名:.html或者.htm HTML不是什么? HTML是一种标记语言,不是变成语言. HTML文档结构 <!DOCTY ...

  3. AQS源码三视-JUC系列

    AQS源码三视-JUC系列 前两篇文章介绍了AQS的核心同步机制,使用CHL同步队列实现线程等待和唤醒,一个int值记录资源量.为上层各式各样的同步器实现画好了模版,像已经介绍到的ReentrantL ...

  4. skywalking 搭建链路监控

    一.skywalking简介 官网:https://github.com/apache/skywalking 引用官网的架构:  二.部署OAP和UI 需使用的镜像 apache/skywalking ...

  5. 6. ZigZag Conversion - LeetCode

    Question 6. ZigZag Conversion Solution 题目大意:将字符串按Z字型排列,然后再一行一行按字符输出 思路:按题目中的第一个例子,画出如下图,通过n的不同值,可以找出 ...

  6. 好客租房28-state和this.setState(this.setState修改状态)

    状态是改变的 语法:this.setstate 千万不要直接改变this.setState setState 修改state 更新ui 数据驱动视图 //导入react     import Reac ...

  7. 目标检测复习之Anchor Free系列

    目标检测之Anchor Free系列 CenterNet(Object as point) 见之前的过的博客 CenterNet笔记 YOLOX 见之前目标检测复习之YOLO系列总结 YOLOX笔记 ...

  8. vscode带命令行参数进行调试

    vscode带命令行参数进行调试 2.输入代码 { // 使用 IntelliSense 了解相关属性. // 悬停以查看现有属性的描述. // 欲了解更多信息,请访问: https://go.mic ...

  9. 解决python 导入selenium 库后自动化运行成功但是报错问题

    本章节开始进入自动化的基础教学了,首先我们要对我们的工具有一定的熟练使用程度,做自动化常用的工具一个是搭建 RobotFramework自动化框架,另外一个便是我们最常用的python 工作原理是比较 ...

  10. VSCode进一步深入了解学习

    紧接上一章节趁热打铁吧,未关注博主的记得关注哦! VSCode设置 (1)关闭预览模式 我们在 VScode 上打开一个新文件的话会覆盖掉以前的文件,这是因为 VSCode 默认开启了预览模式,预览模 ...