利用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(笔记)
Oct 06 Javascript
Javascript查询DBpedia小应用实例学习
Mar 07 Javascript
IE6已终止操作问题的2种情况及解决
Apr 23 Javascript
JavaScript使用位运算符判断奇数和偶数的方法
Jun 01 Javascript
JavaScript数组迭代器实例分析
Jun 09 Javascript
jQuery实现鼠标点击弹出渐变层的方法
Jul 09 Javascript
Vue.js 2.0 和 React、Augular等其他前端框架大比拼
Oct 08 Javascript
jqGrid翻页时数据选中丢失问题的解决办法
Feb 13 Javascript
关于vuex的学习实践笔记
Apr 05 Javascript
微信小程序实现上传图片功能
May 28 Javascript
解决百度Echarts图表坐标轴越界的方法
Oct 17 Javascript
Vue中Table组件行内右键菜单实现方法(基于 vue + AntDesign)
Nov 21 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实现对站点内容外部链接的过滤方法
2014/09/10 PHP
php使用递归计算文件夹大小
2014/12/24 PHP
[原创]php获取数组中键值最大数组项的索引值
2015/03/17 PHP
PHP实现多图上传和单图上传功能
2018/05/17 PHP
PHP的imageTtfText()函数深入详解
2021/03/03 PHP
Javascript实现仿WebQQ界面的“浮云”兼容 IE7以上版本及FF
2011/04/27 Javascript
jQuery登陆判断简单实现代码
2013/04/21 Javascript
js使用html()或text()方法获取设置p标签的显示的值
2014/08/01 Javascript
2014最热门的JavaScript代码高亮插件推荐
2014/11/25 Javascript
了不起的node.js读书笔记之node.js中的特性
2014/12/22 Javascript
判断浏览器的内核及版本号方法汇总
2015/01/05 Javascript
使用Object.defineProperty实现简单的js双向绑定
2016/04/15 Javascript
js删除Array数组中指定元素的两种方法
2016/08/03 Javascript
浅谈js在html中的加载执行顺序,多个jquery ready执行顺序
2016/11/26 Javascript
vue实现全选、反选功能
2020/11/17 Javascript
收藏AngularJS中最重要的核心功能
2017/07/09 Javascript
详解vue-router 路由元信息
2017/09/13 Javascript
Vue 动态组件与 v-once 指令的实现
2019/02/12 Javascript
spring+angular实现导出excel的实现代码
2019/02/27 Javascript
一篇文章,教你学会Vue CLI 插件开发
2019/04/17 Javascript
JS块级作用域和私有变量实例分析
2019/05/11 Javascript
Python 检查数组元素是否存在类似PHP isset()方法
2014/10/14 Python
Python更新数据库脚本两种方法及对比介绍
2017/07/27 Python
Python中的random.uniform()函数教程与实例解析
2019/03/02 Python
弄懂这56个Python使用技巧(轻松掌握Python高效开发)
2019/09/18 Python
python自动化实现登录获取图片验证码功能
2019/11/20 Python
Pyinstaller打包Scrapy项目的实现步骤
2020/09/22 Python
python3爬虫中引用Queue的实例讲解
2020/11/24 Python
Club Monaco加拿大官网:设计师男女服装
2019/09/29 全球购物
院领导写的就业推荐信
2014/03/09 职场文书
环保倡议书300字
2014/05/15 职场文书
2014年部门工作总结
2014/11/12 职场文书
我的兄弟姐妹观后感
2015/06/15 职场文书
运动会宣传稿100字
2015/07/23 职场文书
中国文明网2015年“向国旗敬礼”活动网上签名寄语
2015/09/24 职场文书
苹果macOS 13开发者预览版Beta 8发布 正式版10月发布
2022/09/23 数码科技