js代码不执行

码龄两年 2015-10-20 10:37:18
我是刚刚开始学java web的大学生,最近老师布置了任务就是用spring mvc实现mysql数据库的增删改查,现在出现了一个很奇怪的问题,求各位大神给点意见,
就是比如我修改或新增用户时,点击esayui对话框中的保存没有反应,就是连报错都没有。
相关代码如下,下面是body中修改用户的按钮和easyui的对话框:
<div align="left">
<a href="#" class="easyui-linkbutton" iconCls="icon-add"
plain="true" onclick="newRecord()">新建用户</a> <a href="#"
class="easyui-linkbutton" iconCls="icon-edit" plain="true"
onclick="modifyRecord()">修改用户信息</a> <a href="#"
class="easyui-linkbutton" iconCls="icon-remove" plain="true"
onclick="removeRecord()">删除用户</a> <a href="#"
class="easyui-linkbutton" iconCls="icon-search" plain="true"
onclick="viewRecord();">查看</a>
</div>
<div id="editDlg" class="easyui-dialog"
style="width: 600px; height: 400px" closed="true"
buttons="#editDlg-buttons" data-options="modal:true">
<form id="userInfoEditForm" name="userInfoEditForm" method="post">
<table class="formTable">
<tr>
<td align="right" class="add_hidden">用户序号:</td>
<td class='add_hidden'><input class="easyui-validatebox"
name="pkId" required="true" id="pkId" style="width: 132px" /></td>
</tr>
<tr>
<td align="right">用户编号:</td>
<td><input class="easyui-validatebox" name="userId"
required="true" id="userId" style="width: 132px" /></td>
</tr>
<tr>
<td align="right">用户姓名:</td>
<td><input class="easyui-validatebox" name="userName"
required="true" id="userName" style="width: 132px" /></td>
</tr>
<tr>
<td align="right">年龄:</td>
<td><input class="easyui-numberbox" name="age" required="true"
id="age" style="width:132px" /></td>
</tr>
<tr>
<td align="right">性别:</td>
<td ><input class="easyui-validatebox" name="sex" required="true"
id="sex" style="width: 132px"/></td>
</tr>
<tr>
<td align="right">生日:</td>
<td><input class="easyui-datetimebox" name="birthday" required="true"
id="birthday" /></td>
</tr>

</table>
</form>
</div>
<div id="editDlg-buttons">
<a href="javascript:void(0)" class="easyui-linkbutton"iconCls="icon-ok" onclick="saveInfo()">保存</a>
<a href="javascript:void(0)" class="easyui-linkbutton" iconCls="icon-cancel" onclick="closeDlg()">关闭</a>
</div>
以修改信息为例,下面是相关的js函数:
function modifyRecord() {
var row = $('#infoTable').datagrid('getSelected');
if (row) {
$('#editDlg').dialog('open').dialog('setTitle', '修改用户信息');
//不可修改项
$('#userId').attr("disabled", "disabled");
$('#pkId').attr("disabled", "disabled");
$('#userInfoEditForm').form('load', row);
url = '<%=request.getContextPath()%>/manager/userController/modifyUser.do';
} else {
$.messager.alert('提醒', '请选择需要修改的行', 'warning');
}
}
function saveInfo(){
$('#userInfoEditForm').form('submit', {
url : url,
onSubmit : function() {
return $(this).form('validate');
},
success : function(result) {
var result = eval('(' + result + ')');
if (result.errorMsg) {
$.messager.show({
title : 'Error',
msg : result.errorMsg
});
} else {
$.messager.alert('info',result.success,'info',function(){
$('#editDlg').dialog('close');
$('#infoTable').datagrid('reload');
});
}
},error:function(XMLHttpRequest, textStatus, errorThrown){
$.messager.alert('error','严重错误,联系管理员');
}
});
}
点击修改用户信息之后,把弹出的对话框填好,点击保存,就是没有任何反应,没有跳转到url指向的controller中的方法,也没有报错;加了debugger发现是SavaInfo中$('#userInfoEditForm').form('submit'之后的代买没有执行,非常奇怪,跪求各位了!
...全文
648 点赞 收藏 23
写回复
23 条回复
切换为时间正序
当前发帖距今超过3年,不再开放新的回复
发表回复
独恋幽兰 2015-11-17
url = '<%=request.getContextPath()%>/manager/userController/modifyUser.do'; 这一行有问题吧,在script里面是不能写jsp脚本的,你换成绝对路径测试一下
回复
为啥要用submit方法呢?直接用onclick事件调用ajax提交啊,那个也好调试得多
回复
koskinen 2015-10-26
估计是SUbmit的代码有小错误
回复
我要爆炸啦 2015-10-26
F12打断点,慢慢调试。。。
回复
wish907 2015-10-26
清缓存,设alert看看到底哪里不执行
回复
用chrom打开你的这个页面,然后右键审查元素,选择Sources ,找到你的js 文件,然后再你需要的地方设置断点,然后刷新页面,一步步操作,一步步调试
回复
梦临城下 2015-10-21
看jquery的包引进来没有
回复
十年基民 2015-10-21
点按钮没反应。一般都是js报错了,谷歌浏览器,F12看一下就知道了~
回复
从小就很呆 2015-10-21
既然跳不进后台,肯定是你的请求url有问题,看看是不是写错了
回复
glzmzd 2015-10-21
js当然不报错== 在断点的后面加alert运行试试 alert成功就说明是这个alert之后的代码有问题。一直alert总能找到错误的地方的
回复
码龄两年 2015-10-20
引用 8 楼 rui888 的回复:
你这个也不报错,代码看不出来,除非调试,往源代码里面再调。
我不大会调试,哎,其实错误已经找出来了,就是js代码不执行,跳不到后台啊,但是不知是什么原因导致不执行,下午拿着代码去找老师问问吧,老师太严厉,估计又要被骂一顿
回复
兔子托尼啊 2015-10-20
你这个也不报错,代码看不出来,除非调试,往源代码里面再调。
回复
码龄两年 2015-10-20
引用 6 楼 rui888 的回复:
url : url, 地址对不?其次,js问题你打断点调试看看具体是什么问题。 后台进去没。
url如果不对控制台应该会报404错误吧? 我用debugger调试,发现就是SavaInfo中$('#userInfoEditForm').form('submit'这句之后的语句没有执行。 后台指的是url对应的controller吗?没有跳进去
回复
兔子托尼啊 2015-10-20
url : url, 地址对不?其次,js问题你打断点调试看看具体是什么问题。 后台进去没。
回复
码龄两年 2015-10-20
引用 4 楼 djy18178 的回复:
代码太长懒得看 说点查问题的方法 你这个是js问题? 自己看看代码执行到哪了 哪里没执行 然后用火狐或者谷歌浏览器 F12开发者控制台 看看哪里报错?
太长的话,那就看我加颜色的地方吧,我用的是谷歌浏览器,f12控制台没有任何报错,就是点保存没有反应,就是SavaInfo中$('#userInfoEditForm').form('submit'之后的代码没有执行。。。
回复
放纵的青春 2015-10-20
代码太长懒得看 说点查问题的方法 你这个是js问题? 自己看看代码执行到哪了 哪里没执行 然后用火狐或者谷歌浏览器 F12开发者控制台 看看哪里报错?
回复
码龄两年 2015-10-20
引用 1 楼 li4562258fj155 的回复:
记得应该是on才对 把.form(....换成.on(...试试
我刚刚试了把form换成on,但是没有什么改观
回复
码龄两年 2015-10-20
恩 我刚刚把form换成on,结果是一样的,。
回复
小胖9040 2015-10-20
记得应该是on才对 把.form(....换成.on(...试试
回复
代码与酒 2015-10-20
加几处alert看看,代码太长,懒得看
回复
加载更多回复
相关推荐
发帖
Web 开发
创建于2007-09-28

8.0w+

社区成员

Java Web 开发
申请成为版主
帖子事件
创建了帖子
2015-10-20 10:37
社区公告
暂无公告