我有基于用户的创建行。当你点击“添加新行”时,会克隆和追加一些内容。多个Ajax请求,只有一个插入数据库?
每个克隆的内容都有自己的textarea,每一行都有一个行键。
<input type="hidden" name="rowkey" value="0">
我使用jQuery来重写rowkey值以匹配.each()
创建的行。
ajax post中的最终结果是每行都有一个新的ajax请求。阿贾克斯后看起来像这样
rowkey: 0
application[rows][0][elements][html]: Some HTML here
一个新行
rowkey: 1
application[rows][1][elements][html]: Some More HTML here
另一个Ajax请求然后又如果另一行创建
rowkey: 2
application[rows][2][elements][html]: Some More More HTML here
我以前也使用过这种方法,但现在使用update_post_meta
在wordpress中工作,它只更新wp_postmeta
表,仅使用上面所述的最后一个ajax请求,在这种情况下为rowkey: 2
。通常我可以把它变成一个数组。
这里是update_post_meta
$application['rows'][$_POST['rowkey']] = $_POST['application']['rows'][$_POST['rowkey']];
$application = esc_sql(json_encode($application));
// Update the post's meta field
update_post_meta($post_id, 'MY_DATABASE', $application);
注:这是一个函数内部和$post_id
用作论据有任何问题,只是让所有的阿贾克斯后的值到数据库中,而不是最后。只是扔在那里我记得使用ARRAY_A
不知道这是否与此有关。
的meta_value
数据库表看起来像这样
"rows":{"1":{"elements":{"html":"2"}}}
当它应该是这样的:不是很确定这是否是100%准确的,但它应该类似于
"rows":{"1":{"elements":{"html":"1"}}, {"2":{"elements":{"html":"2"}}, {"3":{"elements":{"html":"3"}} }
最后一句话:我希望这已经够清楚了,不会太长。我真的可以在这里使用帮助。我会非常乐意提供更多的信息,我真的想弄清楚这一点。任何你需要的信息都可以问。
是的,我有一种感觉就是这样,我从另一个应用程序中获得了这种技术,并且在过去没有任何问题使用它。感谢您的答案让我实现这一点,我知道这绝对是在正确的轨道上..我很快发布回来:) –