窗口 - dialog - 与后端交互
与后端交互,一般需要提交表单数据,所以,这次渲染得dialog其实是一个<form>
<form id="loginForm">
<table align="center">
<tr>
<th align="right">用户名</th>
<td>
<input type="text" name="username"/>
</td>
</tr>
<tr>
<th align="right">密码</th>
<td>
<input type="password" name="password"/>
</td>
</tr>
</table>
</form> 使用JS的方式渲染表单为对话框
<script type="text/javascript">
var loginForm;//被循环选择的对象提取出来,这样就用选择器选择一次就够了
$(function () {
loginForm = $("#loginForm").dialog({
title: "登陆",
width: 250,
height: 150,
modal: true,
closable: false,//登录框不允许关闭,所有去掉关闭按钮
buttons: [
{
text: "登陆",
handler: function () {
console.log("登陆");
}
}, {
text: "注册",
handler: function () {
console.log("注册");
}
}
]
});
})
</script> 其实用window组件也能做登录框,但是考虑到如果使用window组件的话,还得自己编写两个(甚至三个)按钮, 所以就使用dialog,直接使用其buttons属性,在底部渲染出两个按钮。以上,用console.log()的方式模拟了等于与注册的操作。
那么如何真实的与后端进行交互呢?
有两种方式
- 第一种:Ajax
var formData = {
username:$("input[name='username']").val(),
password:$("input[name='password']").val(),
};
$.ajax({
type:"POST",
url:"<%=homePage%>/testController/login.ajax?type=json",
dataType:"JSON",//预期服务器返回的数据类型
contentType:"application/json;charset=UTF-8",//发送的数据类型
data:JSON.stringify(formData),//将JSON对象转化成JSON的字符串形式
success:function(data){
if ("0" == data.st){
console.log("登陆成功");
}else{
console.log("登陆失败");
}
}
})
对应的后端
@RequestMapping(value = "/login.ajax",params = "type=json")
@ResponseBody
public Map<String,String> login1(@RequestBody Map<String, String> map){
logger.debug("请求参数:"+map); Map<String,String> map1 = login(map); return map1;
} 说明:前端发送给后端的所有数据,本质上都只可能是字符串,所以,当我在发送Ajax请求的时候,因为指定了 contentType 为 application/json,所以,需要将json对象转换成JSON字符串。而使用Spring MVC作为后端在接收的时候,需要使用@RequestBody注解,该注解将JSON字符串转换成指定的对象,这里转换成了Map 如果不希望通过JSON字符串发送,则可以如下:
handler: function () {
console.log("登陆");
var formData = {
username:$("input[name='username']").val(),
password:$("input[name='password']").val(),
};
$.ajax({
type:"POST",
url:"<%=homePage%>/testController/login.ajax?type=form",
dataType:"JSON",//预期服务器返回的数据类型
data:formData,
success:function(data){
if ("0" == data.st){
console.log("登陆成功");
}else{
console.log("登陆失败");
}
}
})
}
发送的时候不指定发送的类型,默认是 application/x-www-form-urlencoded; 就是k1=v1&k2=v2 的字符串形式
后端也要做相应的改动
@RequestMapping(value = "/login.ajax",params = "type=form")
@ResponseBody
public Map<String,String> login2(@RequestParam Map<String, String> map){
logger.debug("请求参数:"+map); Map<String,String> map1 = login(map);
return map1;
}
ajax方法还有很多其他参数,这里就不展开了,详见文档 上述过程有一个问题,那就是两个表单参数都是自己手动获取的,有没有什么方法,能够获取某个表单中的全部数据呢?答案当然是肯定的
data:$("#loginForm").serialize(),
对表单执行 serialize() 方法后,就能够将表单中的输入域全部转化成 k1=v1&k2=v2 的形式传递给后台,Spring MVC通过@RequestParam注解接收(其实不写也行,就使用一个Map或者cmd对象)
- 第二种:EasyUI的Form表单组件
见Form组件的使用
窗口 - dialog - 与后端交互的更多相关文章
- 微信小程序 + thinkjs + mongoDB 实现简单的前后端交互
说明:这段时间跟老师学习了一下mongodb数据库,这次也是第一次搭建后台服务,出了不少差错,特此来复盘一下,非常感谢对我提供帮助的同学~ 一.使用 thinkjs + mongodb 创建后台服务 ...
- web前后端交互,nodejs
手机赚钱怎么赚,给大家推荐一个手机赚钱APP汇总平台:手指乐(http://www.szhile.com/),辛苦搬砖之余用闲余时间动动手指,就可以日赚数百元 web前后端交互 前后端交互可以采用混合 ...
- 微信App支付接入步骤&支付中前后端交互流程
最近对微信App支付(App端集成微信支付SDK)申请步骤,以及终端在进行微信支付时商户App.商户Server.微信App.微信支付Server的交互流程进行了简单了解.这篇文章应该算是学习笔记,分 ...
- Node之简单的前后端交互
node是前端必学的一门技能,我们都知道node是用的js做后端,在学习node之前我们有必要明白node是如何实现前后端交互的. 这里写了一个简单的通过原生ajax与node实现的一个交互,刚刚学n ...
- Django之META与前后端交互
Django之META与前后端交互 1 提交表单之GET 前端提交数据与发送 1)提交表单数据 2)提交JSON数据 后端的数据接收与响应 1)接收GET请求数据 2)接收POST请求数据 3)响应请 ...
- 前后端交互实现(nginx,json,以及datatable的问题相关)
1.同源问题解决 首先,在同一个域下搭建网络域名访问,需要nginx软件,下载之后修改部分配置 然后再终端下cmd nginx.exe命令,或者打开nginx.exe文件,会运行nginx一闪而过, ...
- springboot+mybatis+thymeleaf项目搭建及前后端交互
前言 spring boot简化了spring的开发, 开发人员在开发过程中省去了大量的配置, 方便开发人员后期维护. 使用spring boot可以快速的开发出restful风格微服务架构. 本文将 ...
- 百度ueditor的图片上传,前后端交互使用
百度ueditor的使用 一个文本编辑器,看了网上很多文档写的很乱,这里拾人牙慧,整理下怎么使用. 这个东西如果不涉及到图片附件上传,其实很简单,就是几个前端文件,直接引用,然后配置下ueditor. ...
- SSM-网站后台管理系统制作(4)---Ajax前后端交互
前提:Ajax本身就为前后端交互服务的,实现功能:用户输入信息,实时判断用户的情况,这也是现在登录界面普遍流行的做法.前端js通过注释识别Controller层,该层查询返回,和之前Google验证码 ...
随机推荐
- iOS开发之手势识别汇总
iOS开发之手势识别汇总 iOS开发中手势识别有六种: 轻击手势(TapGestureRecognizer), 轻扫手势 (SwipeGestureRecognizer), 长按手势(LongPres ...
- 常用jar包用途
jar包 用途 axis.jar SOAP引擎包 commons-discovery-0.2.jar 用来发现.查找和实现可插入式接口,提供一些一般类实例化.单件的生命周期管理的常用方法. jaxrp ...
- css文本格式详解
一.css文本主体内容: 二.css文本详解: 1.文本缩进 语法: text-indent:<length>|<percentage> 默认值为0. 属性值详解: < ...
- 双十一来了,别让你的mongodb宕机了
好久没过来吹牛了,前段时间一直赶项目,没有时间来更新博客,项目也终于赶完了,接下来就要面临双十一这场惊心动魄的处女秀考验, 我们项目中会有一个wcf集群,而集群地址则放在mongodb中,所以mong ...
- SQL Server:孤立用户详解
SQL Server 的用户安全管理分两层,整个SQL Server 服务器一层,每个数据库一层. 在服务器层的帐号,叫登录账户(SQL Server:服务器角色),可以设置它管理整个SQL Serv ...
- 数据库 SQL Server 到 MySQL 迁移方法总结
最近接手一起老项目数据库 SQL Server 到 MySQL 的迁移.因此迁移前进行了一些调查和总结.下面是一些 SQL Server 到 MySQL 的迁移方法. 1. 使用 SQLyog 迁移 ...
- 大数据挖掘: FPGrowth初识--进行商品关联规则挖掘
@(hadoop)[Spark, MLlib, 数据挖掘, 关联规则, 算法] [TOC] 〇.简介 经典的关联规则挖掘算法包括Apriori算法和FP-growth算法.Apriori算法多次扫描交 ...
- cocos之观察者模式应用实例
观察位置: 定义宏常量位置: 添加观察者回调函数位置: 回调函数实现位置:
- mysql服务器配置
mysql的配置文件 /etc/mysql/my.cnf 发现如下配置 # Instead of skip-networking the default is now to listen only ...
- 基于vitamio的网络电视直播源码
这个项目是基于vitamio的网络电视直播源码,也是一个使用了vitamio的基于安卓的网络直播项目源码,可能现在网上已经有很多类似这样的视频播放应用了,不过这个还是相对来说比较完整的,希望这个案例能 ...