利用JS如何获取form表单数据


Posted in Javascript onDecember 19, 2019

前言

本文主要给大家介绍的是关于利用JS获取form表单数据的相关内容,分享出来供大家参考学习,下面话不多说了,来一起看看详细的介绍吧

方法如下:

1.有的时候想偷点懒,页面上有大量的表单提交数据,每次单独获取都比较麻烦。代码冗余度也比较多,因此封装了一个方法。

2. 表单元素必须要有name属性,name属性是向后端提交的字段数据。

3.html代码

<h3>下拉框</h3>
 <select name="sel" id="sel" class="query">
  <option value ="sel-1">sel-1</option>
  <option value ="sel-2">sel-2</option>
 </select>
 <h3>输入框</h3>
 <input type="text" name="text1" class="query" value="hello" />
 <input type="text" name="text2" class="query" value="word" />
 <h3>密码框</h3>
 <input type="password" name="password" class="query" value="123456" />
 <h3>单选框</h3>
 单选1<input type="radio" name="radio" class="query" value="r1" checked />
 单选2<input type="radio" name="radio" class="query" value="r2" checked/>
 单选3<input type="radio" name="radio" class="query" value="r3" />
  <h3>复选框</h3>
 复选框1<input type="checkbox" name="check" id="" class="query" value="c1" checked/>
 复选框2<input type="checkbox" name="check" id="" class="query" value="c2" />
 复选框3<input type="checkbox" name="check" id="" class="query" value="c3" checked/>
 <h3>search</h3>
 <input type="range" name="range" id="" class="query" value="" />
 <input type="color" name="color" id="" class="query" value="" />
 <h3>
  <button type="button" id="save">
   提交
  </button>
 </h3>

4.此处引入了JQ库。

4.1js代码块

使用说明:调用方法的时候传入class名称即可。

// 封装方法,获取到form表单的数据。使用此方法,表单元素必须存在那么属性。
  //el:元素的class名称。
  function getParameter(el){
   var obj={};
   $(el).each(function(index,item){
    // 判断元素的类型
    if(item.type=="text" || item.type=="password" || item.type=="select-one" || item.type=="tel" || 
     item.type=="search" || item.type=="range" || item.type=="number" || item.type=="month" || 
     item.type=="email" || item.type=="datetime-local" || item.type=="datetime" || item.type=="date" || 
     item.type=="color"){
     //获取到name的值,name的值就是向后台传递的数据
     obj[$(this).attr("name")]=$(this).val();
    }else if(item.type=="checkbox"){
     var stamp=false;
     if($(this).attr("name") && !stamp){
      stamp=false;
      // 获取到复选框选中的元素
      var checkboxEl=$("input[name="+$(item).attr('name')+"]:checked");
      if(checkboxEl){
       var checkboxArr=[];
       // 取出复选框选中的值
       checkboxEl.each(function(idx,itm){
        checkboxArr.push($(itm).val());
       });
       obj[$(this).attr("name")]=checkboxArr.join(",");
      }
      
     }
    }else if(item.type=="radio"){
     // 获取到单选框选中的值
     var radio_val=$("input[name="+$(item).attr('name')+"]:checked").val();
     if(radio_val){
      obj[$(item).attr("name")]=radio_val;
     }
    }
   });
   return obj;
  }
  // 调用方法
  $("#save").click(function(){
   var parameter=getParameter(".query");


 
console.log(parameter); 


 });

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对三水点靠木的支持。

Javascript 相关文章推荐
通过JAVAScript实现页面自适应
Jan 19 Javascript
JavaScript中的Window窗口对象
Jan 16 Javascript
分别用marquee和div+js实现首尾相连循环滚动效果,仅3行代码
Sep 21 Javascript
jQuery的DOM操作之删除节点示例
Jan 03 Javascript
javasciprt下jquery函数$.post执行无响应的解决方法
Mar 13 Javascript
node.js中的url.resolve方法使用说明
Dec 10 Javascript
深入分析Cookie的安全性问题
Mar 01 Javascript
javascript:void(0)是什么意思及href=#与href=javascriptvoid(0)的区别
Nov 13 Javascript
详解Bootstrap按钮
Jan 04 Javascript
基于node下的http小爬虫的示例代码
Jan 11 Javascript
vue页面加载闪烁问题的解决方法
Mar 28 Javascript
vue 中基于html5 drag drap的拖放效果案例分析
Nov 01 Javascript
在Vue项目中使用Typescript的实现
Dec 19 #Javascript
JS数据类型STRING使用实例解析
Dec 18 #Javascript
JS精确判断数据类型代码实例
Dec 18 #Javascript
使用webpack/gulp构建TypeScript项目的方法示例
Dec 18 #Javascript
小程序简单两栏瀑布流效果的实现
Dec 18 #Javascript
js数据类型转换与流程控制操作实例分析
Dec 18 #Javascript
vue不操作dom实现图片轮播的示例代码
Dec 18 #Javascript
You might like
php数组函数序列之krsort()- 对数组的元素键名进行降序排序,保持索引关系
2011/11/02 PHP
smarty的section嵌套循环用法示例
2016/05/28 PHP
Yii中CGridView禁止列排序的设置方法
2016/07/12 PHP
DOMAssitant最新版 DOMAssistant 2.5发布
2007/12/25 Javascript
Input 特殊事件onpopertychange和oninput
2009/06/17 Javascript
firefox firebug中文入门教程 脚本之家新年特别版
2010/01/02 Javascript
javascript多种数据类型表格排序代码分析
2010/09/11 Javascript
js使用for循环查询数组中是否存在某个值
2014/08/12 Javascript
JavaScript中的anchor()方法使用详解
2015/06/08 Javascript
jQuery实现批量判断表单中文本框非空的方法(2种方法)
2015/12/09 Javascript
jQuery+css实现的时钟效果(兼容各浏览器)
2016/01/27 Javascript
在React 组件中使用Echarts的示例代码
2017/11/08 Javascript
使用vuepress搭建静态博客的示例代码
2019/02/14 Javascript
vue自定义指令directive的使用方法
2019/04/07 Javascript
JavaScript中十种一步拷贝数组的方法实例详解
2019/04/22 Javascript
Vue中多元素过渡特效的解决方案
2020/02/05 Javascript
javascript实现评分功能
2020/06/24 Javascript
jquery实现上传图片功能
2020/06/29 jQuery
Vue 解决父组件跳转子路由后当前导航active样式消失问题
2020/07/21 Javascript
通过实例解析js可枚举属性与不可枚举属性
2020/12/02 Javascript
Python解释执行原理分析
2014/08/22 Python
python编写的最短路径算法
2015/03/25 Python
详解Python中的正则表达式的用法
2015/04/09 Python
Python微信库:itchat的用法详解
2017/08/14 Python
python读取txt文件,去掉空格计算每行长度的方法
2018/12/20 Python
Python实现查找最小的k个数示例【两种解法】
2019/01/08 Python
Python列表嵌套常见坑点及解决方案
2020/09/30 Python
C面试题
2015/10/08 面试题
大学生学业生涯规划
2014/01/05 职场文书
情人节寄语大全
2014/04/11 职场文书
伊索寓言教学反思
2014/05/01 职场文书
商务英语专业求职信
2014/06/26 职场文书
幼儿教师师德师风自我评价
2015/03/05 职场文书
小学生法制教育心得体会
2016/01/14 职场文书
PHP设计模式(观察者模式)
2021/07/07 PHP
MySQL GTID复制的具体使用
2022/05/20 MySQL