我无法让这个工作。并且似乎无法获得有关该过程的任何真实文档。
我在我的functions.php中有一个自定义短代码,它从外部API获取电子邮件地址。我想在WPCF7的“TO”(即收件人)字段中使用此短代码。但它一直给我一个错误警告“语法错误”。
我需要找到一种方法让收件人字段从我的functions.php文件中接受自定义短代码。
我已经尝试了the dynamic text plugin,但它不起作用。
以下是我的短代码
的示例function single_email() {
global $contact;
return $contact->email;
}add_shortcode( 'contact_email', 'single_email' );
使用“wpcf7_special_mail_tags”和“do_shortcode()”时可能会有什么问题?不太确定它是如何工作的。
使用WPCF7的4.4.2版。
答案 0 :(得分:1)
您可以查看以下代码吗?
wpcf7_add_shortcode('contact_email', 'single_email', true);
function single_email(){
global $contact;
return $contact->email;
}
答案 1 :(得分:1)
您可以在wp_options
表格中使用这样的方式创建新字段并使用这样的方式。
在您的联系页面上
<div class="contant">
<div class="section">
<div class="contact_pannel">
<h1>You can find us literally anywhere, just push a button and we’re there</h1>
<div class="lf_pannel">
<form action="" method="" id='myForm' onsubmit=" return pretendValidation(); ">
<h2>Use this form to send us a message:</h2>
<div class="fild">
<label class="label">Name</label>
<input name="Name" type="text" class="input">
</div>
<div class="fild">
<label class="label">Email</label>
<input name="Email" type="email" class="input" required=required >
</div>
<div class="fild">
<label class="label">Company</label>
<input name="Company" type="text" class="input">
</div>
<div class="fild">
<label class="label">Subject</label>
<input name="Subject" type="text" class="input">
</div>
<div class="fild">
<label class="label">Message</label>
<textarea class="input" style="height:90px;" id='Message'></textarea>
</div>
<input name="submitt" type="submit" id="submitt" style="display:none;">
<a href="javascript:void(0);" class="send_button margin_right23" onclick="document.getElementById('mailed').style.display = 'none'; document.getElementById('submitt').click();" >Send Message</a>
</form>
<div class=" wpcf7-display-none " id="mailed" role="alert">Your message was sent successfully. Thanks.</div>
</div>
<div class="rg_pannel">
<?php echo html_entity_decode( get_option('admin_address') );?>
</div>
</div>
</div>
</div>
<script>
function pretendValidation(){
jQuery(document).ready(function($) {
// We'll pass this variable to the PHP function example_ajax_request
var fruit = 'Banana';
// console.log($( "#myForm" ).serialize());
// This does the ajax request
$.post( "<?=get_template_directory_uri () ;?>/contact_ajax.php",
{ myForm: $( "#myForm" ).serialize(), Message: $( "#Message" ).val() },
function( data ) {
console.log( data ); // John
});
$('#myForm')[0].reset();
$( "#mailed" ).show( "slow" );
});
return false;
}
</script>
之后你必须像这样创建ajax页面
<强> contact_ajax.php 强>
<?php
/** Load WordPress Bootstrap */
require_once ( '../../../wp-load.php' );
// echo "1232".site_url();
// print_r($_REQUEST);
$params = array();
parse_str($_REQUEST['myForm'], $params);
$params['Message']= $_REQUEST['Message'];
// print_r($params);
$to = get_option('your_email_field_name');
// $to = "demo@youremail.in";
$subject = 'Fokus Tech Contact Form';
$message = "Hello,\n"
."Name: ".$params ['Name']."\n"
."Email: ". $params ['Email']."\n"
."Company: ".$params ['Company']."\n"
."Subject: ". $params ['Subject']."\n"
."Message: ".$params['Message'] ."\n"
;
$headers = 'From: no-repaly@you.com' . "\r\n" .
'Reply-To: no-repaly@you.com' . "\r\n" .
'X-Mailer: PHP/' . phpversion();
mail($to, $subject, $message, $headers);
?>