将复杂form表单序列化serialize-object.js

前端技术 2017/09/30 jQuery

        jQuery有个方法$.fn.serialize,可将表单序列化成字符串;还有个方法$.fn.serializeArray,可将表单序列化成数组。那如果要将表单序列化成对象或者JSON格式数据,该如何操作呢?

在实际项目开发中,我们可能会遇到复杂表单的提交处理,我们使用Ajax异步来将这个足够复杂的表单提交给后端处理。常规的办法是将表单各个字段组成字符串或者json格式,然后post给后端PHP处理,这样的话稍微复杂的表单就会让前端会非常累,因为要一个个表单字段处理。而jQuery自带的$.fn.serialize和$.fn.serializeArray都不能满足需求。幸好,我给大家介绍一款序列化json和对象的jQuery插件——jquery.serialize-object.js。

我用实例来演示如何将复杂的表单序列化:

HTML5

以下是一个普通的表单,不算复杂,仅用作演示,实际项目中的表单比这复杂多了。


  
    Email
    
      
    
  
       技能                          HTML5                              Javascript                              PHP                              Python                              MySQL                              Redis              
  
       月薪                         5000以下           5000-10000           10000-20000           20000以上                         自我评价                                        提交        

细心的朋友会发现,我把每个表单元素命名成如name="user[email]"这样的格式,这么做就是为了好序列化成json或object。别着急,来看jQuery调用代码。

jQuery

首先载入jquery库和jquery.serialize-object.js,在我打包的源码中这两个js文件,其中jQuery是引用的CDN资源。


当我们填写完表单后,点击提交按钮,整个表单元素被序列化成JSON数据,然后通过post异步提交给了post.php处理,来看代码:

$(function(){
    $(document).on(\'click\', \'#subbtn\', function(event) {
        event.preventDefault();
        
        var json_data = $(\'#myform\').serializeJSON();
        $.post(\'post.php\', json_data, function(data) {
            console.log(data);
        });
    });
});

上述代码中,我们只需要使用$(\'#myform\').serializeJSON()就可以获得整个表单所有字段的数据,并以json格式序列化,这时post的数据变成以下格式:

{"user":{"email":"demo@example.com","skill":["html5","javascript","PHP","MySQL"],"salary":"5000","intro":"的撒的\\r\\n天654\\r\\n第三方"}}

得到的是一个json格式的数据,看起来是不是很爽了。

当然jquery.serialize-object.js还提供了一个序列化对象的方法:serializeObject,使用如下代码可以得到一个javascript object对象:

var obj_data = $(\'#myform\').serializeObject();

PHP

前端将表单数据序列化成json格式的数据了,而且通过Ajax一次性POST给到PHP,那么PHP该怎么获取这些表单数据呢?由于前端post过程属于原生的数据post,PHP不能通过$_POST[]来接收表单数据,而要通过php://input来接收post数据。

$data = file_get_contents(\'php://input\');
print_r(json_decode($data, true));

PHP接收到post数据后,可以将其转成数组就可以很好的操作数组了。

更多有关表单数据序列化的内容,请参考jQuery Serialize Object项目github地址:https://github.com/macek/jquery-serialize-object



本文地址:https://www.stayed.cn/item/26

转载请注明出处。

本站部分内容来源于网络,如侵犯到您的权益,请 联系我

我的博客

人生若只如初见,何事秋风悲画扇。