如何用Ajax传一个数组数据

PHP接收多个同名复选框信息不像ASP那样自动转换成为数组,这给使用带来了一定不便。但是还是有解决办法的,就是利用javascript做一下预处 理。多个同名复选框在javascript中还是以数组的形式存在的,所以在表单提交之前可以利用javascript把复选框中的信息组合成一个字符数 组赋值给表单中的隐藏元素,然后用PHP中的explode函数解析此数组,这样就可以实现复选框信息的传递了。下面举例说明。

假设有这样一个表单:

<form name="form1" id="form1" method="post" action="http://www.nowamagic.net/index.php" onSubmit="return Checker()"> 
<input type="checkbox" name="item" value="1">1<br> 
<input type="checkbox" name="item" value="2">2<br> 
<input type="checkbox" name="item" value="3">3<br> 
<input type="checkbox" name="item" value="4">4<br> 
<input type="hidden" name="items" value=""> 
<input type="submit" value="Submit"> 
</form> 

这个表单有四个名字都是item的复选框,当用户单击Submit按钮的时候,Checker函数会被调用,并且如果Checker返回true表单 就被提交,返回false表单就不会被提交。这里Checker函数就是我们要编写的预处理函数。在HTML的header部分添加下面的 javascript:

function Checker() 
{ 
    form1.items.value = ""; 
    if ( !form1.item.length ) // 只有一个复选框,form1.item.length = undefined 
    { 
        if ( form1.items.checked ) 
            form1.items.value = form1.item.value; 
    } 
    else 
    { 
        for ( i = 0 ; i < form1.item.length ; i++ ) 
        { 
            if ( form1.item(i).checked ) // 复选框中有选中的框 
                { 
                    form1.items.value = form1.item(i).value; 
                    for ( j = i + 1 ; j < form1.item.length ; j++ ) 
                    { 
                        if ( form1.item(j).checked ) 
                        { 
                            form1.items.value += " "; //用空格做分割符 
                            form1.items.value += form1.item(j).value; 
                        } 
                    } 
                    break; 
                } 
          } 
      } 
      return true; 
}

这样就可以把所有选中的复选框的value组合成为一个字符串数组,在myphp.php使用这样的语句:

$items = explode(" ", $HTTP_POST_VARS["items"]);  

就可以把这些选项分离出来成为数组。需要注意的是选项中的value不能包含分割符(这里是空格)。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 工厂模式类似于现实生活中的工厂可以产生大量相似的商品,去做同样的事情,实现同样的效果;这时候需要使用工厂模式。简单...
    舟渔行舟阅读 12,375评论 2 17
  • 一、JS前言 (1)认识JS 也许你已经了解HTML标记(也称为结构),知道了CSS样式(也称为表示),会使用HT...
    凛0_0阅读 7,732评论 0 8
  • Swift版本点击这里欢迎加入QQ群交流: 594119878最新更新日期:18-09-17 About A cu...
    ylgwhyh阅读 25,663评论 7 249
  • 文/文郎画竹 很多小伙伴在投保时,大多没有要亲自了解的意识,往往都是把需要告知的告诉代理人后让代理人帮忙填写,然后...
    文郎画竹阅读 3,749评论 1 2
  • 第一次使用git推送到GitHub时失败,原因是在GitHub上建立仓库时已经初始化了一个readme文件,因此,...
    安公子_阅读 1,677评论 0 1