wordpress 为自定义类型文章新增自定义字段
2023-02-15 14:25:18wordpress 48人已围观
1、注册一个 Meta Box 示例:
add_action( 'add_meta_boxes', 'product_director' );//创建字段,注册作用 function product_director() {//创建字段时调用的函数 add_meta_box( 'product_director',//字段的唯一ID吧 '产品价格',//字段的名称,在表单上方显示 'product_director_meta_box',//回调函数 'product',//所添加的文章类型 'side', 'low' ); }2、创建回调函数product_director_meta_box
配置参数里面指定了回调函数product_director_meta_box,需要在这个函数里面创建表单:
function product_director_meta_box($post) { // 创建临时隐藏表单,为了安全 wp_nonce_field( 'product_director_meta_box', 'product_director_meta_box_nonce' ); // 获取之前存储的值 $value = get_post_meta( $post->ID, '_product_director', true ); ?> <label for="product_director"></label> <input type="text" id="product_director" name="product_director" value="<?php echo esc_attr( $value ); ?>" placeholder="输入产品价格"> <?php }3、提示:添加上面代码后,新建文章时,在右则就可以看到一个产品价格的输入框。 这时候表单还不能用,因为提交文章之后并没有保存这个 Meta Box 的内容,下面是验证保存内容的代码:
add_action( 'save_post', 'product_director_save_meta_box' );//在保存文章时,执行回调函数 function product_director_save_meta_box($post_id){//回调函数,显示表单,用于新建和编辑显示表单 // 安全检查 // 检查是否发送了一次性隐藏表单内容(判断是否为第三者模拟提交) if ( ! isset( $_POST['product_director_meta_box_nonce'] ) ) {//安全判断 return; } // 判断隐藏表单的值与之前是否相同 if ( ! wp_verify_nonce( $_POST['product_director_meta_box_nonce'], 'product_director_meta_box' ) ) {//主要是修改时,判断product_director_meta_box函数提交过来的是不是和之前的一样,一样就不再次提交了 return; } // 判断该用户是否有权限 if ( ! current_user_can( 'edit_post', $post_id ) ) {//判断有没有权限进行新建、编辑。。。。 return; } // 判断 Meta Box 是否为空 if ( ! isset( $_POST['product_director'] ) ) {//提交的字段为空字段 return; } $product_director = sanitize_text_field( $_POST['product_director'] );//过滤净化表单数据 update_post_meta( $post_id, '_product_director', $product_director );//这句就是sql语句吧,_product_director为保存在数据库的meta_key字段 }把上面的代码按顺序添加到主题的functions.php文件,至此,Meta Box注册完成,就可以开始添加参数了。
4、如何调用?
<?php if(get_post_meta($post->ID,'_product_director',true)){ echo get_post_meta($post->ID,'_product_director',true); } ?>5、把Meta Box添加把后台所有产品列表字段中显示,通过manage_$post_type_posts_custom_column实现。
add_action("manage_posts_custom_column", "product_custom_columns"); add_filter("manage_edit-product_columns", "product_edit_columns"); function product_custom_columns($column){ global $post; switch ($column) { case "product_director": echo get_post_meta( $post->ID, '_product_director', true ); break; } } function product_edit_columns($columns){ $columns['product_director'] = '产品价格'; return $columns; }

随机图文
织梦dedecms漏洞之安全设置 有效防护木马
安全设置前:备份网站文件及数据库 系统安全优化设置之前,做好备份工作。 安全设置一:删文件 安装完成后会有一些文件,可以说是冗余文件,完全没有作用,反而带来被黑的危险,删除即可,以下目录文件均可删除: 目录 删除原因pbootcms调取当前栏目的顶级栏目编码
适用范围:在列表页或详情页使用 调取当前栏目的顶级栏目编码 {sort:tcode}pbootcms自动清理runtime缓存文件释放你的空间压力
官方最新版已经解决此问题,可自行升级到官方最新版。 在pbootcms使用阿里云虚拟主机的时候,经常遇到一个问题就是runtime文件下的缓存文件太多,文件(夹)数量超标,导致网站后台登录不上去,或者是网站打不开。 下边我们做一个简单的二开,让系统能够自动清理缓存文件。 首先:打开/apps/home/c怎么才能防止pbootcms模板被复制
pbootcms的模板目录默认是/template/default/html/ 如果您没有修改过这个目录,那么辛辛苦苦做好的模板很有可能会被别人复制走。 下边我们介绍下怎么才能防止pbootcms模板被复制: 一,修改模板子目录,修改掉默认的html子目录就好(记得是字母,勿用汉字及特殊字符)。 二,将网站的图片,css,js等文件移出模板