我有一个代表机构的实体。因此,该机构有多个地址(地址实体),每个地址都有街道、邮政编码等。
问题是:我有一根树枝,可以显示有关该机构的所有信息,包括该机构所在的地址表。
我想要的只是单击表中的一个地址并弹出一个窗口来编辑地址(然后保存按钮会将地址的 id 传递给控制器函数)。
做这个的最好方式是什么?这里的问题是,在有人点击点击之前,我没有地址的 ID。然后我必须用正确的信息填写表格。
这是我所拥有的:
地址表(在树枝中):
<tbody>
{% for local in locais %}
<tr class="odd gradeX">
<td>{{ local.name}}</td>
<td>{{ local.address}}</td>
<td>{{ local.postalCode}}</td>
<td><a title="Editar" class="label label-info"
onclick="editLocal('{{ local.name}}',
'{{ local.address}}',
'{{ local.postalCode }}'
'{{ local.id }}');">
<i class="icon-edit icon-white"></i></a></td>
</tr>
{% endfor %}
</tbody>
然后我有以下 javascript 函数来填充编辑本地表单:
function editLocal(name, address, postalCode, id){
oFormObject = document.forms['editLocal'];
oFormObject.elements['fccn_corebundle_localtype_id'].value = id;
oFormObject.elements['fccn_corebundle_localtype_name'].value = name;
oFormObject.elements['fccn_corebundle_localtype_address'].value = address;
oFormObject.elements['fccn_corebundle_localtype_postalCode'].value = codigoPostal;
$('#editLocal').modal('show');
};
这里一切正常!表格会弹出正确的信息!
然后我想要的只是获取 id 并将其与编辑后的信息一起传递给控制器,这样我就可以保留现有的本地实体!
我有以下!
<form id="editLocal" class="form-horizontal"
action= "{{ path('FccnEduroamEntidadeBundle_editLocal',
{ 'idLocal': editLocalForm.vars.value.id }) }}"
method="post" {{ form_enctype(editLocalForm) }}>
{{ form_row(editLocalForm.name) }}
{{ form_row(editLocalForm.address) }}
{{ form_row(editLocalForm.postalCode) }}
{{ form_rest(editLocalForm) }}
<div class="form-actions">
<button class="btn" type="submit">Guardar</button>
</div>
</form>
这里的问题是editLocalForm.vars.value.id绝对没有返回任何东西!但是当我在 chrome 上检查这个标签时,我有:
<input type="hidden" id="fccn_corebundle_localtype_id" name="fccn_corebundle_localtype[id]" value="1">
有一个更好的方法吗?任何帮助将非常感激。
谢谢。
阿方索