zoukankan      html  css  js  c++  java
  • ajax

    $.ajax({
       type: "POST",
       url: "some.php",
       data: "name=John&location=Boston",
       success: function(msg){
         alert( "Data Saved: " + msg );
       }
    });

    后来我就想了一下,我要提交form表单有没有办法呢?但是我不可能每个fom的input都写一次var demo=$("#divname").val();的.

    后来,今天我看到一个方法,就是.map,就做出一下想法了,可以借鉴哟;
    html代码如下,下面我要提交Form 的id为dlg_form的所有input数据,
    <form id="dlg_form" method="post">
        <div class="fitem">
          <label> 房间:</label>
          <input name="RoomName" style="padding: 2px; 135px; border: 1px solid #A4BED4;" required />
        </div>
        <div class="fitem">
          <label> 建筑:</label>
          <input name="RoomName" class="easyui-combobox" style="padding: 2px; 141px; " required />
        </div>
        <div class="fitem">
          <label> 部门:</label>
          <input name="RoomName" class="easyui-combobox" style="padding: 2px; 141px; " required />
        </div>
        <fieldset>
          <legend>
          <label>
            <input type="checkbox" id="ktkzq" name="ktkzq" value="ktkzq"/>
            空调控制器</label>
          </legend>
          <div class="fitem">
            <label> 端口:</label>
            <input name="kt_dk" id="kt_dk" disabled="disabled" class="easyui-combobox" style="padding: 2px; 141px; " required />
          </div>
          <div class="fitem">
            <label> 地址:</label>
            <input name="kt_dz" id="kt_dz" disabled="disabled" class="easyui-combobox" style="padding: 2px; 141px; " required />
          </div>
          <div class="fitem">
            <label> 工作方式:</label>
            <input name="kt_gzfs" id="kt_gzfs" disabled="disabled" class="easyui-combobox" style="padding: 2px; 141px; " required />
          </div>
          <div class="fitem">
            <label> 是否启用:</label>
            <input name="kt_sfqy" id="kt_sfqy" disabled="disabled" class="easyui-combobox" style="padding: 2px; 141px; " required />
          </div>
        </fieldset>
        <fieldset>
          <legend>
          <label>
            <input type="checkbox" id="dgkzq" name="dgkzq" value="dgkzq"/>
            灯光控制器</label>
          </legend>
          <div class="fitem">
            <label> 端口:</label>
            <input name="dg_dk" id="dg_dk" disabled="disabled" class="easyui-combobox" style="padding: 2px; 141px; " required />
          </div>
          <div class="fitem">
            <label> 地址:</label>
            <input name="dg_dz" id="dg_dz" disabled="disabled" class="easyui-combobox" style="padding: 2px; 141px; " required />
          </div>
          <div class="fitem">
            <label> 工作方式:</label>
            <input name="dg_gzfs" id="dg_gzfs" disabled="disabled" class="easyui-combobox" style="padding: 2px; 141px; " required />
          </div>
          <div class="fitem">
            <label> 是否启用:</label>
            <input name="dg_sfqy" id="dg_sfqy" disabled="disabled" class="easyui-combobox" style="padding: 2px; 141px; " required />
          </div>
        </fieldset>
        <div class="fitem">
          <label style=" 100px;">
            <input type="checkbox" id="zongbiao" name="zongbiao" value="zongbiao"/>
            安装了总表:</label>
        </div>
        <div class="fitem">
          <label> 总表电能节点:</label>
          <input name="zbdnjd" id="zbdnjd" disabled="disabled" class="easyui-combobox" style="padding: 2px; 141px; " required />
        </div>
      </form>
    是不是很多,如果要你每个input都写的话,是不是要吐血?
    看看我的方法,首先我们把所有的input的name和value都取下来,
    js代码如下:
    var str_data=$("#dlg_form input").map(function(){
     return ($(this).attr("name")+'='+$(this).val());
    }).get().join("&") ;

    alert(data);

    ps:你alert一下,你会发现,这里面的架构就是divname=xxx&divname2=xxxx等等,

    然后在回头看看ajax提交的:

    $.ajax({
       type: "POST",
       url: "some.php",
       data: "name=John&location=Boston",
       success: function(msg){
         alert( "Data Saved: " + msg );
       }
    });

    有没有发现,只要我们把我们上面获取到的,放到data里面就可以了?

    完整的代码,修改后应该是

    $.ajax({
       var str_data=$("#dlg_form input").map(function(){
      return ($(this).attr("name")+'='+$(this).val());
    }).get().join("&") ;
       type: "POST",
       url: "some.php",
       data: str_data,
       success: function(msg){
         alert( "Data Saved: " + msg );
       }
    });

    ok,就这么简单,如果适用的话,可以拿去用哟...

    非自己创作,转自别处。。。。。。

    关于php的疑难杂症
  • 相关阅读:
    selenium基础(元素定位)
    python函数基础(函数的定义和调用)
    python语句结构(控制语句与pass语句)
    python语句结构(range函数)
    while语句结构(for循环)
    python语句结构(while循环)
    python语句结构(if判断语句)
    python基础语法(运算符及优先级)
    python基础语法(变量与数据类型)
    requests上传文件,又要上传data的处理
  • 原文地址:https://www.cnblogs.com/renmengke/p/4985396.html
Copyright © 2011-2022 走看看