重力表单插件 - 动态填充表单字段不起作用



我的重力形式表格遇到了一些问题。这是一个多页表单,我需要使用第 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;
}

最新更新