Dom与Jquery的ajax

Dom与Jquery的ajaxDom与Jquery的ajax

大家好,又见面了,我是你们的朋友全栈君。

Dom与jquery互相转换

DOM是文档对象模型(Document Object Model,简称DOM)
jQuery是一个JavaScript 库,极大地简化了JavaScript编程。

  • dom与jq互转,jq对象只能用jq方法,dom对象只能用内置的dom方法,不能互窜
    $(“#test”) //jq对象
    $(“#test”)[0] //dom对象
    $(“#test”).get(0) //dom对象
    var dom = document.getElementById(“test”); //dom对象
    $(dom) //jq对象
    在这里插入图片描述案例:
//这是一个JavaScript对象
  var variable =                     
  //这就是个jQuery对象
  var $variable = $()            
  //这是一个DOM对象,方法包括getElementById( ),getElementByTagName( )...
  var variable = document.get...     
//dom与jquery互相转换
   //取得<input>标签中的value属性的内容[dom对象->jquery对象]
    var inputElement = document.getElementById("inputID");//DOM对象
    var $input = $(inputElement);//jQuery对象
    var value = $input.val();
    alert(value);
    //取得 <div>标签中的文本内容[jquery对象->dom对象,方法一]
    var $div = $("#divID");//jQuery对象
    var divElement = $div[0];//DOM对象
    var html = divElement.innerHTML;
    alert(html);
    //取得<div>标签中的文本内容[jquery对象->dom对象,方法二]
    var $div = $("#divID");//jQuery对象
    var divElement = $div.get(0);//DOM对象
    var html = divElement.html();
    alert(html);

Dom原生Ajax请求

function getHTTPObject(){
    if(typeof XMLHttpRequest == "undefined"){
        XMLHttpRequest = new ActiveXObject("MSXML2.XMLHTTP");  //兼容IE
    }
    return new XMLHttpRequest();
} 
//获取服务端数据
function getContent(){
    var request = getHTTPObject();
    if(request){
        //第一个参数是访问请求类型GET POST SEND, 
        //第二个参数是数据来源地址,一般指服务器接口
        //第三个参数代表是否异步方式发送和处理
        request.open("GET", "data.json", true);  
        request.onreadystatechange = function(){
            //readyState有5种值,0是未初始化 1是正在加载 2是加载完毕 3是正在交互 4是完成
            if(request.readyState == 4){
                console.log(request.responseText);
            }
        };
        request.send(null);
    }else{
        alert("Sorry, Error");
    }
}

jquery的Ajax请求

function findAllDepts() {
    $.ajax({
        async : false,    //表示请求是否异步处理
        type : "post",    //请求类型
        url : "/getDepts",//请求的 URL地址
        dataType : "json",//返回的数据类型
        success: function (data) {
          console.log(data);  //在控制台打印服务器端返回的数据
          for(var i=0;i<data.length;i++){
              console.log(data[i].deptId+" "+data[i].deptName);
          }
            $("select[name='depertmentId']").empty();
            $("select[name='depertmentId']").append('<option value="">——请选择——</option>');
            for(var i=0;i<data.length;i++){
                var html ='<option value="'+data[i].deptId+'">';
                html +=data[i].deptName + '</option>';
                $("select[name='departmentId']").append(html);  //将数据显示在html页面
            }
        },
        error:function (data) {
            alert(data.result);
        }
    });
};
 
$(document).ready(function () {
   findAllDepts();  //页面加载完成就执行该方法
});

服务端原生代码:

//Java代码:后台获取单个数控定位器的历史表格的数据
//请求路径看get(),post()里面的逻辑分配
    public void getHistorySingleData() throws IOException{ 
   
        HttpServletRequest request = ServletActionContext.getRequest();
        HttpServletResponse response = ServletActionContext.getResponse();
        response.setHeader("Content-type", "text/html;charset=UTF-8");
        response.setContentType("text/html;charset=utf-8");
        String deviceName = request.getParameter("deviceName");
        String startDate= request.getParameter("startDate");
        String endDate = request.getParameter("endDate");
        SingleHistoryData[] singleHistoryData = chartService.getHistorySingleData(deviceName,startDate, endDate);
        System.out.println(singleHistoryData.length);
        System.out.println(JSONArray.fromObject(singleHistoryData).toString());
        //打印:[{"time":"2016-11-11 10:00:00","state":"运行","ball":"锁紧",....},{"time":"2016-11-11 10:00:05","state":"运行","ball":"锁紧",....},{},{}....]查到几条singleHistoryData对象就打印几个对象的信息{"time":"2016-11-11 10:00:05","state":"运行","ball":"锁紧",....}
        //将json数据回传给回调函数
        response.getWriter().print(JSONArray.fromObject(singleHistoryData).toString());
    }

SSM代码:

msg类:

package com.xiaoyu.shop.bean;

import java.util.HashMap;
import java.util.Map;

/** * 通知返回类 * @author Administrator * */
public class Msg { 
   
	//状态码 100-成功 200-失败
	private int code;
	//提示信息
	private String msg;
	
	//用户要返回给浏览器的数据
	private Map<String, Object> extend = new HashMap<String, Object>();

	public static Msg success(){ 
   
		Msg result = new Msg();
		result.setCode(100);
		result.setMsg("处理成功!");
		return result;
	}
	
	public static Msg fail(){ 
   
		Msg result = new Msg();
		result.setCode(200);
		result.setMsg("处理失败!");
		return result;
	}
	
	public Msg add(String key,Object value){ 
   
		this.getExtend().put(key, value);
		return this;
	}
	
	public int getCode() { 
   
		return code;
	}

	public void setCode(int code) { 
   
		this.code = code;
	}

	public String getMsg() { 
   
		return msg;
	}

	public void setMsg(String msg) { 
   
		this.msg = msg;
	}

	public Map<String, Object> getExtend() { 
   
		return extend;
	}

	public void setExtend(Map<String, Object> extend) { 
   
		this.extend = extend;
	}
	
	
}

将json数据回传给回调函数的方法:


package com.xiaoyu.shop.controller;

import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.ResponseBody;

import com.xiaoyu.shop.bean.Msg;

@Controller
public class AdminController { 
   
    /** * 管理员登录 * /adminlogin : 请求路径 */
    @RequestMapping("/adminlogin")
    @ResponseBody
    public Msg userLogin(@RequestParam(value = "adminName") String adminName,
            @RequestParam(value = "adminPassword") String adminPassword) { 
   
        System.out.println(adminName + "+" + adminPassword);
        if (adminName.equals("admin") && adminPassword.equals("admin")) { 
   
            return Msg.success().add("msg", "管理员登录成功");
        } else { 
   
            return Msg.fail().add("msg", "管理员登录失败");
        }
    }

}

SpringBoot代码:

msg类参考ssm的msg类。
将json数据回传给回调函数的方法:

//管理员模糊分页查询用户
    @RequestMapping("/admin_LikeUserList")
    @ResponseBody
    public Msg admin_LikeUserList(@RequestParam(value = "pn", defaultValue = "") Integer pn,
                                  @RequestParam(value = "userName", defaultValue = "") String userName){ 
   
        System.out.println(pn + ";" + userName);
        PageHelper.startPage(pn, 5);
        List<User> UserList = userService.LikeUserList(userName);
        for(User s:UserList){ 
   
            System.out.println(s.toString());
        }
        PageInfo page = new PageInfo(UserList, 5);
        return Msg.success().add("pageInfo", page);
    }

java后台接收数据

前台请求

var params = { 
   “xxx”:“xx”}
$.ajax({ 
   
    type:”post”,
    ansyv:true,
    data:params,
    datatype:”json”,
    url:””,
    success:function(data){ 
   
    },
    error:function(){ 
   
    }
})

java后台接收数据

方法一:

public String getData(HttpServlettRequest request){ 
   
    String ss= request.getParameter(“xxx”); //ss=>xx
}

方法二:

public String getData(){ 
   
HttpServletRequest request=  ServletActionContext.getRequest();  
    String ss =  request.getParameter("xxx");  //ss=>xx
}

方法三:
需要Spring mvc
后端通过 @RequestParam(value=”xxx”) String xxx 分别获取对应的键值对

@RequestMapping(value="/example1", method=RequestMethod.GET)
public @ResponseBody String emrSubmit(
      @RequestParam(value="id") String id,
      @RequestParam(value="name") String name
){ 
   
  //...
}

方法四:
需要Spring mvc
后端通过 @RequestParam Map <String,Object> param 一次性获取全部的键值对

@RequestMapping(value="/example1", method=RequestMethod.GET)
public @ResponseBody String emrSubmit(
      @RequestParam Map<String,Object> param
){ 
   
  //提取前端传来的具体参数
  String id = (String)params.get("id");
  String name = (String)params.get("name ");
  //...
}

jQuery:html(),text(),val()方法的区别

1.HTML
html():取得第一个匹配元素的html内容。这个函数不能用于XML文档。但可以用于XHTML文档
html(val):设置每一个匹配元素的html内容。这个函数不能用于XML文档。但可以用于XHTML文档。
2.TEXT
text():取得所有匹配元素的内容。
结果是由所有匹配元素包含的文本内容组合起来的文本。这个方法对HTML和XML文档都有效。
text(val):设置所有匹配元素的文本内容
与 html() 类似, 但将编码 HTML (将 “<” 和 “>” 替换成相应的HTML实体).
3.VAL
val():获得第一个匹配元素的当前值。
val(val):设置每一个匹配元素的值。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/106652.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • DSP C6000代码优化

    DSP C6000代码优化忙完项目的事情,对DSP的学习又近了一步。在此介绍一下C6000代码优化的问题:1.手动汇编优化软件流水1.1.更短的执行时间1.2.更小的代码空间两部分需要权衡线性汇编比汇编更加简单编译器把高级语言编译成汇编,汇编器是吧汇编编译成.obj的二进制代码,连接器把所有文件连接到一起生成可执行文件1.31.先指令后-O(n)选项,还不行就线性汇编,很少到手动汇编2.项目经验首先得评估代码运行时间,这个在DSPDEBUG-TOOL-clock,利用该工具可以很好的评估到

    2022年6月19日
    24
  • 一文搞懂三极管开关电路,基极电阻如何选择?[通俗易懂]

    一文搞懂三极管开关电路,基极电阻如何选择?[通俗易懂]一文搞懂三极管开关电路,基极电阻如何选择?

    2022年9月2日
    3
  • linux修改用户名的命令_linux退出root用户命令

    linux修改用户名的命令_linux退出root用户命令Linux将用户名修改后,还需要修改组名+家目录+UID这只会更改用户名,而其他的东西,比如用户组,家目录,UID等都保持不变。1、修改用户名$usermod-l新用户旧用户  这只会更改用户名,而其他的东西,比如用户组、家目录、ID等都保持不变。注意: 你需要从要改名的帐号中登出并杀掉该用户的所有进程,要杀掉该用户的所有进程可以执行下面命令$s…

    2022年9月18日
    0
  • python 正则表达式详解

    python 正则表达式详解正则表达式是一个很强大的字符串处理工具,几乎任何关于字符串的操作都可以使用正则表达式来完成,作为一个爬虫工作者,每天和字符串打交道,正则表达式更是不可或缺的技能,正则表达式的在不同的语言中使用方式可能

    2022年7月5日
    15
  • 智能营销增益模型(Uplift Modeling)的原理与实践

    智能营销增益模型(Uplift Modeling)的原理与实践文章目录增益模型因果与推论(CausalInference)增益模型的表示差分响应模型(Two-ModelApproach)模型优缺点差分响应模型升级版(One-ModelApproach)ClassTransformationMethodClassTransformation的两个假设ModelingUpliftDirectly增益模型的评估uplift柱状图Qini曲线(Qi…

    2022年10月22日
    0
  • tomcat修改http长度限制_解决浏览器与服务器请求url长度限制[通俗易懂]

    tomcat修改http长度限制_解决浏览器与服务器请求url长度限制[通俗易懂]一、前言Http中get与post本身是没有受到长度限制的,受到限制是浏览器与服务器对url长度限制。具体说明请阅读我的零一篇文章《关于HTTPGET/POST请求参数长度最大值的一个理解误区》。二、概述1、服务器限制我目前使用的服务器一般是tomcat+nginx,它们都是通过控制http请求头的长度来进行限制的,nginx的配置参数为large_client_header_buffer…

    2022年8月24日
    4

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号