Wordpress Contact Form 7 根据 url 动态选择下拉字段

Posted

技术标签:

【中文标题】Wordpress Contact Form 7 根据 url 动态选择下拉字段【英文标题】:Wordpress Contact Form 7 dynamically select dropdown field based on url 【发布时间】:2020-11-24 19:48:23 【问题描述】:

我有以下情况。我有 Contact Form 7 插件和几个具有不同服务的页面。每个页面都有一个联系表格,边栏中的选择下拉列表包含所有服务。 当您在特定服务中时,如何实现这一点,默认情况下会根据服务(可能通过 URL)自动选择下拉字段? 我没有找到这样的话题,我对这是如何发生的非常感兴趣。最好没有插件。在此先感谢:)

【问题讨论】:

【参考方案1】:

假设你有 3 个服务,服务 A,服务 B,服务 C,这样如果你在一个属于服务 B 的页面,URL 为domain.com/service-b/my-page,换句话说,该 URL 本身有足够的信息来确定此页面是服务 B 的一部分。有 2 种方法可以继续在您的下拉列表中实现自动选择,

1 在客户端,页面加载后使用 javascript

使用以下脚本选择正确的选项,

(function($)
$(document).ready(function()
  //determine the current page,
  let page = window.location.href, opt='';
  //comment the following line for your site, this is only for this example test.
  page = 'http://example.com/service-b/my-page';

  switch(true)
    case page.indexOf('service-b')>0:
      opt='serviceb';
      break;
    case page.indexOf('service-c')>0:
      opt='servicec';
      break;
    case page.indexOf('service-a')>0:
      opt='servicea';
      break;
  

  $('select[name="select-services"]').find('option[value="'+opt+'"]').prop('selected', 'selected');
)
)(jQuery)
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<select name="select-services">
 <option value="">select a service</option>
 <option value="servicea">Service A</option>
 <option value="serviceb">Service B</option>
 <option value="servicec">Service C</option>
</select>

2 另一种方法是在页面加载之前使用 php 修改服务器端的选择选项,并挂钩过滤器“do_shortcode_tag”,一旦执行 cf7 表单简码,就会触发该过滤器。将以下代码放入您的主题functions.php 文件中,

add_filter('do_shortcode_tag','set_service',10,3);
function set_service($html, $attr, $tag)
  //check this is a cf7 shortcode.
  if('contact-form-7' !== $tag)
    return $output;
  
  //if you have several forms, you can also check this is the right form using $attr['id']
  //determine which page you are on
  global $wp;
  $serv='';
  switch(true)
    case false !== strpos($wp->request, 'service-a' ):
      $serv='servicea';
      break;
      case false !== strpos($wp->request, 'service-b' ):
      $serv='serviceb';
      break;
    case false !== strpos($wp->request, 'service-c' ):
      $serv='servicec';
      break;
  
  return str_replace('value="'.$serv.'"', 'value="'.$serv.'" selected="selected"', $html);

【讨论】:

非常感谢您的回答。不幸的是,我不能同时处理这两个问题。 JavaScript 解决方案在 .find - 'missing) after argument list' 周围给我一个语法错误,而 php 解决方案我的整个联系表格消失了。显然我做的不对。你有什么想法吗? 对不起,我在 js 代码中做了一个类型,我已经更正了它并将其设置为一个 jsfiddle 示例,您可以运行测试并查看它是否有效。以上是非此即彼的解决方案,要么是客户端使用 JavaScript 的 1,要么是服务器端使用 PHP 的解决方案 2,您不需要两者。 是的,当然,我也无法调整。现在一切都与 javascript 解决方案完美结合。非常感谢您快速正确的回答:) 感谢您的反馈!声望低于 15 人的投票将被记录,但不会更改公开显示的帖子得分。抱歉:(很快我就会有 15 个 :) 没错,但你可以选择答案......除非你希望得到另一个答案。【参考方案2】:

你可以试试 wp filter hook:

add_filter( 'do_shortcode_tag','sercice_check',10,3);

function sercice_check($output, $tag, $attr)

// Checking your contact form id
// [contact-form-7 id="659" title="My Service"]

  if(  isset( $attr['id'] ) &&  $attr['id'] == 659 ) //you can even check for specific attributes
    global $wp;

    $service='';

    // Site url like : www.mysite.com/service/service-a/
    switch(true)

        case false !== strpos($wp->request, 'service-a' ):
            $service='Service A';
        break;

        case false !== strpos($wp->request, 'service-a' ):
            $service='Service B';
        break;
    

    return str_replace('value="'.$service.'"', 'value="'.$service.'" selected="selected"', $output);
  

  return $output;

【讨论】:

以上是关于Wordpress Contact Form 7 根据 url 动态选择下拉字段的主要内容,如果未能解决你的问题,请参考以下文章

Wordpress Contact Form 7 集成 WP Webhook 不工作

wordpress插件Contact Form 7 邮件收不到附件

Wordpress Contact form 7 html整合问题

WordPress Contact-Form 7 收到的邮件内容为空

wordpress Contact form 7验证未与相应的输入对齐

谁会使用wordpress的Contact Form 7插件?