我的重力形式表格遇到了一些问题。这是一个多页表单,我需要使用第 2 页的帖子值填充第 1 页上的字段。但它不起作用。当然,第 2 页上的字段配置为"允许动态填充字段",并且字段的参数设置为"name"。这是我的代码:
add_filter('gform_field_value_name', 'name_population_function');
function name_population_function($value){
$name = $_POST['input_2'] . ' ' . ( ! empty( $_POST['input_3'] ) ? ( $_POST['input_3'] . ' ' ) : NULL ) . $_POST['input_1'];
return $name;
}
当我使用var_dump($name);
打印$name
变量的值时,它实际上是正确的。
如果我将$name
更改为$name = 'Last Middle First';
它将按应有的方式填充字段。
谢谢你的帮助。
编辑:出于测试目的,我将代码更改为:
add_filter('gform_field_value_name', 'name_population_function');
function name_population_function($value){
$name = 'Test';
if ( ! empty( $_POST['input_1'] ) && ! empty( $_POST['input_2'] ) ) {
$name = $_POST['input_2'] . ' ' . ( ! empty( $_POST['input_3'] ) ? ( $_POST['input_3'] . ' ' ) : NULL ) . $_POST['input_1'];
//var_dump( $name );
}
return $name;
}
如果我取消注释var_dump
该行,则变量$name
的值再次正确设置,但第 2 页上的字段预填充了值 Test
.可能第 1 页上也调用了此过滤器,那么插件是否有可能缓存此值?我不使用缓存插件,所以不知道为什么它不起作用。
与其让表单覆盖多个页面,不如使用 jQuery 创建具有 .hide
或.slideToggle
的多个页面的印象。这将解决您的问题,并使表单数据的提交更加容易。然后只需从过去的输入中调用值。
可以使用查询字符串来保存数据并动态填充字段。
http://siteurl.com/form-url/?your_parameter=value
add_filter('gform_field_value_author_email', 'populate_post_author_email');
function populate_post_author_email($value){
global $post;
$author_email = get_the_author_meta('email', $post->post_author);
return $author_email;
}
试试这个gform_pre_render过滤器。它将筛选器添加到窗体 ID 7。将 7 替换为重力表单的 ID。
add_filter('gform_pre_render_7', 'populate_form_pre_render');
function populate_form_pre_render($form){
$name ='';
foreach ($form['fields'] as &$field)
{
// replace 2 with the actual ID of your form field
if ( 2 == $field['id'] ){
if ( ! empty( $_POST['input_1'] ) && ! empty( $_POST['input_2'] ) ) {
$name = $_POST['input_2'] . ' ' . ( ! empty( $_POST['input_3'] ) ? ($_POST['input_3'] . ' ' ) : NULL ) . $_POST['input_1'];
//var_dump( $name );
}
$field['defaultValue']=$name;
echo '<pre>';
print_r($field);
echo '</pre>';
}
}
return $form;
}