在wordpress留言板如何添加一个手机号的字段
[重要通告]如您遇疑难杂症,本站支持知识付费业务,扫右边二维码加博主微信,可节省您宝贵时间哦!
wordpresss不管是制作个人博客,留言板都必不可少,然而就是一个询盘的表单。对于询盘信息最重要的就是客户的联系方式啦,wordpress默认是可以填写邮箱的。如果不是外贸网站,手机号就是最重要的联系方式。wordpress留言板中如何添加一个手机的字段。
wordpress中使用留言板功能只用一个函数 comment_form() 就可以搞定。 这函数默认会输出含有五个字段 comment
、author
、email
、url
、 cookies
的表单。comment作为填写留言信息的字段,当然是必不可少的。其他的字段则可以进行订制,或者增加新的字段。这里说下如何新增加一个手机号的字段。
wordprss中添加一个手机号的字段
worpdress提供了修改留言字段的一个钩子,这里可以修改是这四个字段(author
、email
、url
、 cookies
);
做个小测试,把这段代码放到主题文件中的 functions.php 中。找一个有留言的页面看下效果
add_filter('comment_form_default_fields', function ($fields) { echo "<!-- "; var_dump($fields); echo "-->"; return $fields; });
修改一下代码
add_filter('comment_form_default_fields', function ($fields) { $fields['tel'] = '<p class="comment-form-tel">' .'<label for="tel">联系电话</label> ' .'<input id="tel" name="tel" type="text" value="' . esc_attr($commenter['comment_tel']) . '" size="30" />' .'</p>'; return $fields; });
前台的显示修改完成以后,就剩下两个问题。
- 手机号如何保存
- 后台如何显示
手机号的保存
使用wordpress提供的 wp_postmeta
表,通过 update_comment_meta
函数把数据写入到这个数据表中。
add_action('wp_insert_comment', function ($comment_ID, $commmentdata) { $tel = isset($_POST['tel']) ? $_POST['tel'] : false; update_comment_meta($comment_ID, 'tel', $tel); }
手机号的后台显示
后台的显示,需要输出两个部分,第一个部分 表头的字段
, 第二 内容
# 后来评论显示电话的字段 add_filter('manage_edit-comments_columns', 'my_comments_columns'); function my_comments_columns($columns) { $columns['tel'] = __('联系电话'); return $columns; } # 后台评论显示电话的内容 add_action('manage_comments_custom_column', 'output_my_comments_columns', 10, 2); function output_my_comments_columns($column_name, $comment_id) { switch ($column_name) { case "tel" : echo get_comment_meta($comment_id, 'tel', true); break; } }
本文参阅与:https://www.liuhaolin.com/wordpress/73.html 三克油
PS延伸阅读,有一种比较简单的方式:
需要字段做一下修改,修改只有两种,第一删除,第二添加,修改的方法 (下面的代码写在模板文件中)
function my_fields($fields) {
// 添加一个字段
$fields['tel'] = '<p class="comment-form-tel">' . '<label for="qq">' . "联系电话" . '</label> ' .
'<input id="tel" name="tel" type="text" value="' . esc_attr($commenter['comment_tel']) . '" size="30" /></p>';unset($fields['url']); // 删除一个字段
//unset($fields['author']); // 删除作者字段
//unset($fields['email']); // 删除邮箱字段
return $fields;
}// 对留言板字段进行处理
add_filter('comment_form_default_fields', 'my_fields');// 输出处理后的留言板
comment_form();
默认情况新增加的字段并不会自动保存,所有添加保存的代码,代码放到 functions.php
中
add_action('wp_insert_comment', 'wp_insert_my_comment', 10, 2);
function wp_insert_my_comment($comment_ID, $commmentdata) {
$tel = isset($_POST['tel']) ? $_POST['tel'] : false;
update_comment_meta($comment_ID, 'tel', $tel);
}
这段代码就保存了评论中的 tel
字段;
wrdpress 定制化留言板(后台显示)
对于自己添加的字段,默认是后台是不会显示的。所以添加一下代码到 functions.php
中上后台可以显示新增加的字段
add_filter('manage_edit-comments_columns', 'my_comments_columns');
add_action('manage_comments_custom_column', 'output_my_comments_columns', 10, 2);# 添加字段的标题
function my_comments_columns($columns) {
$columns['tel'] = __('联系电话');
$columns['email'] = __('电子邮箱');
return $columns;
}# 添加字段的显示内容
function output_my_comments_columns($column_name, $comment_id) {
// die();
switch ($column_name) {
case "tel" :
echo get_comment_meta($comment_id, 'tel', true);
break;
case "email":
echo get_comment_author_email();
}
}
问题未解决?付费解决问题加Q或微信 2589053300 (即Q号又微信号)右上方扫一扫可加博主微信
所写所说,是心之所感,思之所悟,行之所得;文当无敷衍,落笔求简洁。 以所舍,求所获;有所依,方所成!