wp路径函数

<?php
 
/*
Template Name: Full-width layout
Template Post Type: post, page, product
*/

与WordPress打交道,经常遇到的一个问题就是获取路径,包括URL路径和服务器路径,在主题或插件中引用js或css文件需要URL地址,而include一些文件时则需要服务器路径。在WordPress中,不能认定wp-content目录一定位于/wp-content下,也不能认为admin的地址一定是/wp-admin,为了避免错误,了解WordPress中与获取路径相关的函数很重要。


wordpress path

以下均假设WordPress站点安装在https://www.solagirl.net下

站点路径相关函数
HOME_URL() >>
返回站点路径,相当于后台设置->常规中的"站点地址(URL)"。

1
2
3
4
$url = home_url();
echo $url;
 
//输出: https://www.solagirl.net
1
2
3
4
$url = home_url('/images/');
echo $url;
 
输出:https://www.solagirl.net/images/
SITE_URL() >>
如果WordPress安装在域名根目录下,则该函数与home_url()相同。

如果WordPress安装在子目录下,例如https://www.solagirl.net/wordpress,则site_url()返回WordPress实际安装地址,相当于后台->设置->常规中的“WordPress 地址(URL)”。

1
2
3
4
5
$url = site_url();
echo $url;
 
//假设WordPress安装在https://www.solagirl.net/wordpress下
//输出:https://www.solagirl.net/wordpress
ADMIN_URL() >>
返回后台地址,传递参数后也可返回后台menu的地址

1
2
3
4
$url = admin_url();
echo $url;
 
//输出:https://www.solagirl.net/wp-admin/
CONTENT_URL() >>
返回实际的wp-content目录,如果是默认安装,且装在根目录下,则如下所示

1
2
3
4
$url = content_url();
echo $url;
 
//输出:https://www.solagirl.net/wp-content
如果在wp-config.php中改变了wp-content目录的位置,则该函数会返回正确地址,例如wp-config.php中如下定义

1
2
define('WP_CONTENT_DIR', '/home/user/public_html/cdn');
define('WP_CONTENT_URL', 'http://sola-cdn.me');
则content_url()的返回值为

1
http://sola-cdn.me
INCLUDES_URL() >>
返回当前WordPress站点存放核心文件的目录wp-includes的地址,可以带一个$path作为参数。

1
2
3
4
$url = includes_url( '/js/');
echo $url;
 
//输出:https://www.solagirl.net/wp-includes/js/
WP_UPLOAD_DIR() >>
返回WordPress上传目录的地址,是一个数组,包含一系列与上传地址相关的信息。

1
<?php $upload_dir = wp_upload_dir(); ?>
提供如下信息给你

1
2
3
4
5
6
* 'path' - 上传目录的服务器绝对路径,通常以反斜杠(/)开头
* 'url' - 上传目录的完整URL
* 'subdir' - 子目录名称,通常是以年/月形式组织的目录地址,例如/2012/07
* 'basedir' - 上传目录的服务器绝对路径,不包含子目录
* 'baseurl' - 上传目录的完整URL,不包含子目录
* 'error' - 报错信息.
例如

1
2
3
4
$upload_dir = wp_upload_dir();
echo $upload_dir['baseurl'];
 
//输出:https://www.solagirl.net/wp-content/uploads
主题路径相关函数
GET_THEME_ROOT_URI() >>
获取存放主题的目录URI

1
2
3
echo get_theme_root_uri();
 
//输出:https://www.solagirl.net/wp-content/themes
GET_THEME_ROOT() >>
获取存放主题的目录的服务器绝对路径

1
2
3
echo get_theme_root();
 
//输出:<tt>/home/user/public_html/wp-content/themes</tt>
GET_THEME_ROOTS() >>
获取主题目录的目录名称,如果你的主题目录是/wp-content/themes,则

1
2
3
echo get_theme_roots();
 
//输出:/themes
GET_STYLESHEET_DIRECTORY() >>
获取当前启用的主题目录的服务器绝对路径,例如

1
/home/user/public_html/wp-content/themes/twentyeleven
可以用来include文件,例如

1
<?php include( get_stylesheet_directory() . '/includes/myfile.php'); ?>
GET_STYLESHEET_DIRECTORY_URI() >>
获取当前启用的主题目录的URI,例如

1
2
3
echo get_stylesheet_directory_uri();
 
//输出:https://www.solagirl.net/wp-content/themes/twentyeleven
可以使用在需要主题目录URI的场合,例如图片

1
<img src="<?php echo get_stylesheet_directory_uri() ?>/images/aternus.png" alt="" title="" width="" height="" />
GET_TEMPLATE_DIRECTORY_URI() >>
如果当前启用的主题是一个child theme,该函数返回parent theme的主题目录URI,用法与get_stylesheet_directory_uri()类似。

GET_TEMPLATE_DIRECTORY() >>
如果当前启用的主题是一个child theme,该函数返回parent theme的主题目录的服务器绝对路径,用法与get_stylesheet_directory()类似。

GET_TEMPLATE() >>
获取当前启用主题的主题目录名称,例如现在启用的主题为twentyeleven,则

1
2
3
echo get_stylesheet();
 
//输出:twentyeleven
GET_STYLESHEET() >>
获取当前启用主题的主题目录名称,与get_template()的区别是,如果用了child theme,则返回child theme的目录名称。

插件路径相关函数
PLUGINS_URL() >>
获取当前插件的目录的URI,例如一个插件位于/wp-content/plugins/myplugin下,该目录下放有插件的主文件名为myplugin.php,在myplugin.php中执行下面的代码,结果如下

1
2
3
echo plugins_url();
 
//输出:https://www.solagirl.net/wp-content/plugins
1
2
3
echo plugins_url('',__FILE__);
 
//输出:https://www.solagirl.net/wp-content/plugins/myplugin
1
2
3
echo plugins_url('js/myscript.js',__FILE__);
 
//输出:https://www.solagirl.net/wp-content/plugins/myplugin/js/myscript.js
PLUGIN_DIR_URL() >>
返回当前插件的目录URI,例如

1
2
3
echo plugin_dir_url( __FILE__ );
 
//输出:https://www.solagirl.net/wp-content/plugins/myplugin/
注意结尾有反斜杠。

PLUGIN_DIR_PATH() >>
返回当前插件目录的服务器绝对路径,例如

1
2
3
echo plugin_dir_path( __FILE__ );
 
//输出:/home/user/public_html/wp-content/plugins/myplugin/
可以用来引用文件,例如

1
2
3
4
5
<?php
define( 'MYPLUGINNAME_PATH', plugin_dir_path(__FILE__) );
require MYPLUGINNAME_PATH . 'includes/class-metabox.php';
require MYPLUGINNAME_PATH . 'includes/class-widget.php';
?>
PLUGIN_BASENAME() >>
返回调用该函数的插件文件名称(包含插件路径)

例如在插件myplugin下的myplugin.php文件中调用该函数,结果如下

1
2
3
echo plugin_basename(__FILE__);
 
//输出:myplugin/myplugin.php
如果在myplugin/include/test.php文件中调用(test.php通过include引用到myplugin.php中),结果如下

1
2
3
echo plugin_basename(__FILE__);
 
//输出:myplugin/include/test.php
路径相关常量
WordPress中还有一组用define定义的常量代表路径。

WP_CONTENT_DIR
wp-content目录的服务器绝对路径,例如

1
/home/user/public_html/wp-content
WP_CONTENT_URL
wp-content目录的URI地址,例如

1
https://www.solagirl.net/wp-content
WP_PLUGIN_DIR
插件目录的服务器绝对路径,例如

1
/home/user/public_html/wp-content/plugins
WP_PLUGIN_URL
插件目录的URI地址,例如

1
https://www.solagirl.net/wp-content/plugins
TEMPLATEPATH
当前启用主题目录的服务器绝对路径,相当于get_template_directory()例如

1
/home/user/public_html/wp-content/themes/twentyeleven
STYLESHEETPATH
当前启用主题目录的服务器绝对路径,相当于get_stylesheet_directory(),与TEMPLATEPATH的区别在于如果使用child theme,该常量指向child theme目录。

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值