WordPress中创建自定义PHP页面的两种方法

方案一:制作页面模板

制作页面模板是一个最简单、方便的解决方案,但功能也有一定的局限性。要创建页面模板:

  1. 在当前启用的主题文件夹(wp-content/themes/your_theme_name)下创建一个 sample-template.php 的 PHP 文件;
  2. 将 page.php 的内容复制到刚才创建的文件中;
  3. 增加自定义的 PHP 代码;
  4. 在文件的最顶端增加一段注释:
    1. Template Name: Sample Template

     

接下来进入 WordPress 后台,新建页面后就能找到“Sample Template”这个模板来使用了,这个方法比较简单,网上能够百度谷歌的资料也很多,因此只是简略地说一下。

方案二:调用 WordPress 的 API

这种方法的自由度较高,并且可以创建非WordPress格式的URL,非常有用。比如我们要把 example.com/some-custom-url-request 转交给主题文件夹下的 /custom/some-custom-url-request.php 来处理,就可以用这种方式来处理。这种方法用到 template redirect 钩子,template redirect 是 WordPress 在预处理好所有参数设置之后决定调用主题模板的时候调用的。

我们只需在主题的 function.php 文件的尾部加上:

  1. function loadCustomTemplate($template) {

  2. if(!file_exists($template))return;

  3. $wp_query->is_page = true;

  4. $wp_query->is_single = false;

  5. $wp_query->is_home = false;

  6. $wp_query->comments = false;

  7. // if we have a 404 status

  8. if ($wp_query->is_404) {

  9. // set status of 404 to false

  10. unset($wp_query->query["error"]);

  11. $wp_query->query_vars["error"]="";

  12. $wp_query->is_404=false;

  13. // change the header to 200 OK

  14. header("HTTP/1.1 200 OK");

  15. function templateRedirect() {

  16. $basename = basename($_SERVER['REQUEST_URI'], '?' . $_SERVER['QUERY_STRING']);

  17. loadCustomTemplate(TEMPLATEPATH.'/custom/'."/$basename.php");

  18. add_action('template_redirect', 'templateRedirect');

 

这样就实现了 WordPress 查找 /custom 文件夹下的 php 文件,并且将相匹配的 URL 请求转交给对应的 php 文件来处理的效果,与此同时,这个 php 文件还保持了对 WordPress API 的调用,因此留给我们的空间非常大。

例如如果我们在 /custom 文件夹下创建一个 hello.php 的文件如下:

  1. <div id="post-999" class="page type-page status-publish hentry">

  2. <h2 class="post-title">My custom page</h2>

  3. <div class="post-content">

  4. <?php echo "Hello World"; ?>

  5. <div class="clear"></div>

  6. </div><!-- END .post-content -->

  7. <div class="clear"></div>

  8. </div><!-- #post-## -->

  9. </div><!-- END #content -->

  10. <div class="clear"></div>

 

那么只要输入 example.com/hello 就能显示 Hello World,并且具有主题的框架和 CSS 样式,非常方便好用。

主机差评君首发于zhuji188.com,转发请标明来源https://zhuji188.com/130.html
THE END
分享
二维码
< <上一篇
下一篇>>