- 浏览: 1020971 次
- 性别:
- 来自: 天津
文章分类
- 全部博客 (445)
- Java (22)
- J2EE (18)
- Flex (102)
- Flex-blazeds (1)
- Flex-FABridge (2)
- Flex4 (3)
- CheckStyle (2)
- PowerDesigner (0)
- POI (2)
- Java2Word (2)
- 杂项 (15)
- 日记 (3)
- 数据库-oracle (41)
- 数据库-SQLServer (7)
- 中间件 (1)
- 英语 (8)
- C# (43)
- ASP.net (72)
- ASP.net MVC (28)
- 微软-Entity Framework (19)
- JavaScript (22)
- JQuery (31)
- EasyUI (3)
- VS2010 (4)
- CVS (1)
- Tomcat (3)
- Linux (1)
- 遗留问题 (1)
- iphone (1)
- MAC (0)
- 系统 (2)
- Web Service (4)
- Cache Manager (1)
- PMP (1)
- WCF (10)
- BootstrapJs (1)
- Web API (6)
- Go语言 (0)
- 网络协议 (2)
- Redis (10)
- RabbitMQ (10)
- Git (3)
- Kafka (5)
- ELK (5)
- Nginx (3)
- 测试 (2)
最新评论
-
ygm0720:
Table行拖拽自己实现 -
程乐平:
Flex4开发视频教程(27集)下载http://bbs.it ...
Flex4教程 -
liuweihug:
Jquery+asp.net 后台数据传到前台js进行解析的办 ...
AJAX $.toJSON的用法或把数组转换成json类型 -
weilikk:
谢谢谢谢!!
javascript IE下不能用 trim函数解决方法 -
gxz1989611:
vigiles 写道请问楼主:[Fault] exceptio ...
blazeds推送技术至Flex
最近修改一个 js 函数,却发现自己需要学习的还很多
函数的主要目的是想知道 form 表单中的值有没有被改变,原来的函数采用的是 if…else/if 结构,在这里,我还是把代码贴出来吧:
// 函数 ;
function IsFormChanged(name) {
var isChanged = false;
// var form = document.getElementById(name);
var form = document.forms[name];
for (var i = 0; i < form.elements.length; i++) {
var element = form.elements[i];
var type = element.type;
if (type == "text" || type == "hidden" || type == "textarea" || type == "button") {
if (element.value != element.defaultValue) {
isChanged = true;
alert("1");
break;
}
} else if (type == "radio" || type == "checkbox") {
if (element.checked != element.defaultChecked) {
isChanged = true;
alert("2");
break;
}
} else if (type == "select-one"|| type == "select-multiple") {
for (var j = 0; j < element.options.length; j++) {
if (element.options[j].selected != element.options[j].defaultSelected) {
isChanged = true;
alert("3");
break;
}
}
} else {
// etc...
}
}
alert( isChanged?" 你改变了表单的默认值 ":" 表单的值没有改变 ");
return isChanged;
}
这个函数思路很清晰了,但是,我准备采用另外一个方式来重写它,我采用的是 switch ,于是,一开始,我把 if…else/if 都改成 switch ,可是,发现不能验证,后来,我发现了: for 循环中使用 switch ,然后用 break 的话,退出来的是 switch 结构,循环还要继续的,而我需要的是直接退回 for 循环。上网找了一些解决办法,最后发现把 switch 部分的分离出来单独写成一个函数比较好,但是,考虑到这个函数最终只会在一个函数中使用,就是我们的判断 form 表单默认值的函数,而且,由于项目开发的需要,我把一些公用的函数都封装起来,所以,最后我把函数改写成了如下的形式:
var Form={
IsFormChanged:function(id){
/*IsFormChangedCase 这个函数我本来是放在外面的,和 IsFormChanged 的级别是一样的,但是现在只有 IsFormChanged 这个函数使用这个,其原因是因为 switch 和 for 中都是用 break 的缘故,所以,我最终把这个函数作为 IsFormChanged 函数的一个变量来使用。
*/
var IsFormChangedCase=function(element){
var isChanged = false;
switch(element.type){
case "text":
case "hidden":
case "textarea":
case "button":
if(element.value != element.defaultValue)
isChanged= true;
break;
case "radio":
case "checkbox":
if(element.checked != element.defaultChecked)
isChanged= true;
break;
case "select-one":
case "select-multiple":
for (var j = 0; j < element.options.length; j++){
if(element.options[j].selected != element.options[j].defaultSelected){
isChanged= true;
break;
}
}
break;
}
return isChanged;
};
var str=false;
var form = document.getElementById(id);
for (var i = 0; i < form.elements.length; i++){
var element = form.elements[i];
if(IsFormChangedCase(element)){
str=true;
break;
}
}
return str;
}
}
// 这个只是测试函数
function test()
{
var ret=Form.IsFormChanged("frm2");
alert( ret?" 你改变了表单的默认值 ":" 表单的值没有改变 ");
return ret;
}
http://www.codestore.net/store.nsf/unid/DOMM-4UTKE6
发表评论
-
js插件库系列导航
2016-06-02 13:41 586此系列为了建立一个有用的js插件和解决方案库,希望对您有 ... -
js Tree - 树形菜单插件
2016-06-02 13:41 1340js Tree - 树形菜单 ... -
easyui input 取值 赋值
2016-05-13 15:49 947$("#userdlg_useraccount& ... -
Jquery easyUI dialog的close和destroy
2016-05-13 15:48 4422之前在用easyUI的时候遇到一个问题,一直困扰着我。 ... -
谈谈Firefox23如何禁用JavaScript
2013-10-18 13:07 1417Firefox23取消了一个很人性化的功能,就是在GUI界面 ... -
Javascript弹出窗口总结
2013-01-15 10:40 3345//关闭,父窗口弹出对话框,子窗口直接关闭this.Resp ... -
jquery-validation 使用
2012-11-06 10:19 5748一、用前必备 官方 ... -
jQuery blockUI插件在ajax提交的时候的用法(block不起作用)
2012-10-23 10:36 5723在开发过程中出现一个问题,就是在IE7,8,9 ,Chrome ... -
AJAX $.toJSON的用法或把数组转换成json类型
2012-09-27 15:35 202551. html页面全部代码 <html> ... -
JQuery dialog弹出对话框解决Asp.net服务器控件无法执行后台代码的方法
2012-09-07 16:55 5513搜索相关问题发现,其中主要问题是出在:JQuery会把Dial ... -
jquery dialog 详解
2012-09-07 16:49 12324还是先看例子吧。另外如果要拖动、改变dialog的大小的话 ... -
jquery操作dropdownlist和radiobuttonlist
2012-08-13 19:08 3061jquery获取ASP.NET服务器端控件dropdownli ... -
JS中showModalDialog 详细使用
2012-04-11 16:51 1186基本介绍: ... -
Window_Open详解
2012-04-11 16:51 968一、window.open()支持环境: Jav ... -
DIV中的image控件,放大,缩小,还原,拖拽
2012-02-10 11:21 5295<!DOCTYPE html PUBLIC " ... -
控制 iframe 内图片放大缩小
2012-02-09 09:09 4133index.asp 页面 <html> & ... -
Jquery框架
2011-11-15 15:52 14351. DWZ 官方网址:http://code. ... -
MVC 分页 JQuery Pager
2011-11-07 13:00 3201导入的包 <script type=" ... -
Jquery与.net MVC结合,通过Ajax
2011-10-14 09:55 2638在工作中做了这么一个东西。 Html端: @using T ... -
jQuery插件ASP.NET应用之AjaxUpload
2011-10-14 09:49 2362本次使用AJAXUPLOAD做为上传客户端无刷上传插件,其最新 ...
相关推荐
jQuery oform beta 0.1.5 - form 表单美化插件源代码 版权:zhang yang soft 交流E-Mail:oceancode@163.com 浏览器支持:IE、Firefox、Opera , google chrome (谷歌) 版本说明: 1. beta 0.1.0 版 支持input...
版权:zhang yang soft ...浏览器支持:IE、Firefox、Opera , google chrome (谷歌) 版本说明: 1. beta 0.1.0 版 支持input text/button 美化 时间:2010-01-25 ...jquery oform 美化 插件 开源
下面,我们将详细解读jQuery EasyUI API中文文档中关于Form表单的知识点。 首先,了解如何将一个普通的HTML表单转化为一个支持Ajax提交的表单。这可以通过为表单元素绑定jQuery EasyUI的Form插件来实现。例如,首先...
在本文中,我们将深入探讨如何使用jQuery来控制表单输入框(`<input>`元素)显示默认值的方法。这个功能在很多场景下都非常实用,比如创建提示性文本,当用户聚焦输入框时自动清除,失去焦点且未输入内容时恢复...
本文将详细讲解如何使用jQuery的`$.ajax`方法来提交Form表单,以及如何通过自定义函数实现更灵活的表单提交。 首先,传统的HTML Form表单提交会导致页面刷新,用户体验不佳。为了实现无刷新提交,我们可以利用...
这些示例涵盖了EasyUI的各个组件,从基础的按钮(Button)到复杂的表单(Form)和数据管理(DataGrid)。通过实际操作,我们可以直观地看到组件的使用方法、样式调整和事件绑定,这对于初学者来说是极其宝贵的资源。...
它使表单能够将默认值或消息绘制到 input/textarea 元素中。 文本是从元素的标题属性中获取的。 我怎样才能使用这个插件? 当然,首先您需要当前版本的 jQuery 库。 转到 jQuery 网站并获取一份副本。 接下来,...
在jQuery 1.2版本中,如果你指明了一个JSONP回调函数,你就可以从其它的域中载入JSON类型的数据,写法类似于 "myurl?callback=?" 。jQuery会自动调用正确的方法名称来代替查询字符串,执行你指定的回调函数。...
在网页开发中,jQuery是一个非常流行的JavaScript库,它极大地简化了DOM操作、事件处理、动画效果和Ajax交互。"jQuery复制移除表单元素代码.zip"这个资源包含了一个使用jQuery 1.7.2版本实现的功能,即动态复制和...
### jQuery实现form表单元素序列化为json对象的方法 首先,需要理解jQuery中的`serializeArray()`方法。该方法可以序列化表单元素(form),返回一个包含表单值的键值对数组,其中键是输入字段的name属性,值则是...
在网页设计和开发中,`form` 表单是用户与服务器进行数据交互的重要组成部分,而日期输入控件则是表单中常见的一种元素,用于收集用户的日期或时间信息。在HTML5中,引入了内置的日期输入类型,使得创建和处理日期...
用于添加 ajax-ify 表单的 jQuery 插件。 它能做什么 你有一个表格。 提交表单时,您需要进行一些 PHP 处理,但您不想离开页面。 该插件使用 ajax 提交表单,返回响应,并相应地调用成功、失败和工作方法。 所以它...
通过本文的示例,我们可以利用jQuery的选择器功能`.forminput`来选取所有的`class="forminput"`的input元素,并使用`.each()`方法迭代每个元素,调用`.setDefauleValue`方法来设置它们的默认值。 ### 总结 使用...
本文将深入探讨如何利用jQuery UI中的input滑动条功能来创建一个房屋表单搜索条件的滑动条。通过这个功能,用户可以更直观地调整和选择他们对房屋搜索的特定条件,例如价格范围、房间数量等。 首先,我们需要在项目...
jQuery AJAX表单验证 预期数据格式 { " success " : false , " errors " : { " email " : [ " Email is not valid " ], " password " : [ " Password is not valid " , " Password is too short " ] } } 选项 ...
它仅取决于jQuery。 可以在拖曳模式下使用:属性网格(当前实现)/常规形式(路线图)。 易于自定义CSS。 支持的输入:text / checkbox / textarea / html / color / date / number / radio / select。 验证...
在本文中,我们将深入探讨jQuery Validate的一些关键功能和用法。 首先,我们需要引入jQuery库以及jQuery Validate插件的JavaScript文件。在HTML文档的`<head>`或`<body>`部分,我们可以添加如下代码: ```html ...