立即注册 找回密码

QQ登录

只需一步,快速开始

查看: 624|回复: 0

[Wordpress 通用教程] WordPress后台定制-通用字段option的添加和调用

[复制链接]
发表于 2023-12-1 22:02:37 | 显示全部楼层 |阅读模式
道勤网-数据www.daoqin.net

亲注册登录道勤网-可以查看更多帖子内容哦!(包涵精彩图片、文字详情等)请您及时注册登录-www.daoqin.net

您需要 登录 才可以下载或查看,没有账号?立即注册

x
wordpress构建的网站上我们经常要定义一些全站通用的数据,比如联系方式、公司简介等,这些数据可能会在网站的任何地方被调用,比如首页、相关内页、每个页面的头部和底部等。个人喜欢称这样的数据为通用字段。既然叫通用字段,顾名思义就是存在于数据库里的一条可以被随处调用的数据,WordPress的options表提供了这样的便利。需要注意的是通用字段和自定义字段的概念区别,前者保存在options表中,而自定义字段则保存在postmeta表中。options表一般用来保存一些网站全局设置和插件设置,而保存自定义字段的postmeta表则保存的是用于和文章、页面、菜单等关联的字段。
WordPress封装好的操作options表最重要的函数就是 update_option ,本文通过一个最简单的实例介绍通用字段的操作。
首先看下我要定制的这个后台功能截图:
08898.png
如图,在后台的Settings主菜单下增加一个Custom Setting子菜单。具体的设置页面只有两个字段,Site Intro和Phone Number。这是最简单的自定义设置页面了,下面开始代码:
1. 通过add_submenu_page函数给Settiings菜单下增加一栏:
  1. add_action('admin_menu', 'options_admin_menu');
  2. function options_admin_menu(){
  3.         add_submenu_page( 'options-general.php','Custom Setting', 'Custom Setting', 'administrator', 'custom-setting', 'customSetting' );
  4. }
复制代码


注意其中“options-general.php”指定了新增的子菜单添加在Settings主菜单下,如果要把菜单增加到其他地方,比如Tools主菜单下,换成”tools.php”,即可。更多选择请参考add_submenu_page的官方文档点这里
点击新增子菜单,页面地址就会跳转到/wp-admin/options-general.php?page=custom-setting
这里的custom-setting也是参数之一,可以自行命名。
最后一个参数customSetting是回调函数,后面会提到。
2. 详细的设置界面
以下就是第一步回调的执行函数,包含所有页面的内容和保存功能
  1. function customSetting(){ ?>
  2.         <div class="wrap">
  3.         <h2>Custom Setting</h2>
  4.         <?php
  5.         if ($_POST['update_options']=='true') {//若提交了表单,则保存变量
  6.                 update_option('site-intro', $_POST['site-intro']);
  7.                 update_option('phone-number', $_POST['phone-number']);
  8.                 //若值为空,则删除这行数据
  9.                 if( empty($_POST['site-intro']) ) delete_option('site-intro' );
  10.                 if( empty($_POST['phone-number']) ) delete_option('phone-number' );
  11.                 echo '<div id="message" class="updated below-h2"><p>Saved!</p></div>';//保存完毕显示文字提示
  12.         }
  13.         //下面开始界面表单
  14.         ?>
  15.         <form method="POST" action="">
  16.                 <input type="hidden" name="update_options" value="true" />
  17.                 <table class="form-table">
  18.                                 <tr>
  19.                                         <th scope="row">Site Intro:</th>
  20.                                         <td><input type="text" name="site-intro" id="site-intro" value="<?php echo get_option('site-intro'); ?>" /></td>
  21.                                 </tr>
  22.                                 <tr>
  23.                                         <th scope="row">Phone Number:</th>
  24.                                         <td><input type="text" name="phone-number" id="phone-number" value="<?php echo get_option('phone-number'); ?>" /></td>
  25.                                 </tr>
  26.                 </table>
  27.                 <p><input type="submit" class="button-primary" name="admin_options" value="Update"/></p>
  28.         </form>
  29.         </div>
  30.         <?php
  31.         add_action('admin_menu', 'customSetting');
  32. }
复制代码
以上两段代码复制到主题的functions.php内即可。
update_option函数只有两个参数,使用起来确很灵活。首先,如果数据库的options表中没有名称为“site-intro”数据,而我用
  1. update_option('site-intro', $_POST['site-intro']);
复制代码
这条命令就可以在数据库自动创建这条数据,并且设置成我想要的值,而无需先做有没有数据的判断。
如果要删除一条options数据,只要用delete_option即可:
  1. delete_option( 'site-intro' );
复制代码
delete_option的官方文档点这里
最后,在前台调用option也很简单,用get_option即可:
  1. echo get_option( 'site-intro' );
复制代码
通常我们还会用get_option命令取出一些WordPress默认带有的变量,比如网站名称、网站URL等:
  1. echo get_option( 'blogname' ); //在General设置里填写的网站名称
  2. echo get_option( 'siteurl' ); //在General设置里填写的网站地址
  3. echo get_option( 'admin_email' ); //安装WordPress时填写的管理员邮箱
  4. echo get_option( 'template' ); //当前调用的主题名称
  5. //...
复制代码
具体可以看看get_option的官方文档


道勤主机提供365天*24小时全年全天无休、实时在线、零等待的售后技术支持。竭力为您免费处理您在使用道勤主机过程中所遇到的一切问题! 如果您是道勤主机用户,那么您可以通过QQ【792472177】、售后QQ【59133755】、旺旺【诠释意念】、微信:q792472177免费电话、后台提交工单这些方式联系道勤主机客服! 如果您不是我们的客户也没问题,点击页面最右边的企业QQ在线咨询图标联系我们并购买后,我们为您免费进行无缝搬家服务,让您享受网站零访问延迟的迁移到道勤主机的服务!
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

关闭

道勤网- 推荐内容!上一条 /2 下一条

!jz_fbzt! !jz_sgzt! !jz_xgzt! 快速回复 !jz_fhlb! !jz_lxwm! !jz_gfqqq!

关于我们|手机版|小黑屋|地图|【道勤网】-www.daoqin.net 软件视频自学教程|免费教程|自学电脑|3D教程|平面教程|影视动画教程|办公教程|机械设计教程|网站设计教程【道勤网】 ( 皖ICP备15000319号-1 )

GMT+8, 2024-5-5 17:34

Powered by DaoQin! X3.4 © 2016-2063 Dao Qin & 道勤科技

快速回复 返回顶部 返回列表