i have html form has 2 divs, 1 div fixed area means inputs not dynamic, , second div dynamic means have button can clone div many times want.
this jquery clode cloning new div:
$('#btn-addsection').click(function (e) { var me = $(this); e.preventdefault(); var lastrepeatinggroup = $('.repeating-section').last(); var cloned = lastrepeatinggroup.clone(false) cloned.insertafter(lastrepeatinggroup); var attrs = ['for', 'id', 'name']; var tags = section.find('input, label'), idx = section.index(); tags.each(function () { var $this = $(this); if ($this.is('input')) { $this.val(''); } $.each(attrs, function (i, attr) { var attr_val = $this.attr(attr); if (attr_val) { $this.attr(attr, attr_val.replace(/_\d+$/, '_' + (idx))) } }) }) });
the above code clone div , add underscore "_" plus next index field can identify field second or third, etc. div cloned.
when post server use:
var formdata = $('#form-newquote :input').serializearray();
this save method on server:
public jsonresult savequote(quotemodel model) { var response = this.jsonresponse; response = new jsonresponse { data = null, message = string.empty, num = 0, success = true, code = null }; return json(response, jsonrequestbehavior.allowget); }
this quotemodel
:
the red mark many many cloned items. problem how send jquery server dynamic fields on server can map them quoteselectionmode
object.
any clue?
you should use $('form').serialize()
instead. have never used serializearray
. looking @ documentation, creates array of objects
name
, value
properties don't think modelbinder
able map quotemodel
.
changing serialize()
still won't bind sections
property because of how you're handling name
attribute.
it's crucial set name
attribute whenever you're dealing properties collcetions
of objects. in case, inputs should like:
<input type="text" name="sections[0].propertname" /> <input type="text" name="sections[0].propertname2" /> <select name="sections[0].propertname3" />
when cloned, should produce this:
<input type="text" name="sections[1].propertname" /> <input type="text" name="sections[1].propertname2" /> <select name="sections[1].propertname3" />
besides this, make sure in ajax, you've given same parameter name controller:
$.ajax({ url: "/controllername/savequote", data: { model: formdata }, ...........
also, consider using knockout
kind of recurring templates. cloning using jquery error-prone , you'll have write lot of junk code. in ko, observalblearray.push(new viewmodel())
, you're set.
Comments
Post a Comment