您现在的位置是:首页 > cms教程 > WordPress教程WordPress教程
WordPress模板开发实例
吴军卓2025-03-02WordPress教程已有人查阅
导读页面模板文件:一个完整的主题中必须包含index.php和style.css首页模板-index.php,这个模板决定你博客的主页长什么样子文章模板-single.php,这个模板决定你单篇博客长什么样
页面模板文件:一个完整的主题中必须包含index.php和style.css
首页模板-index.php,这个模板决定你博客的主页长什么样子
文章模板-single.php,这个模板决定你单篇博客长什么样子
搜索模板-search.php,这个决定你搜索博客之后的文章列表页长什么样子
存档模板-archive.php,这个决定你通过分类,标签等分类过滤之后的文章列表长什么样子
错误页面-404.php,做技术的,这个就不用解释啦
获取模板路径:
常用函数:
the_ID():
is_page($page):是否为某一个页面
参数:$page 页面ID,页面标题或者页面别名,可选,默认值为空
返回的值:逻辑值(true/false)
is_sticky($post_ID):判断当前页面类型是否为置顶文章,$post_ID (可选) 文章ID
is_singular() :非列表页
is_home() || is_front_page() ==== 判断是否主页
is_single() ==== 文章页
is_page() ==== 页面
is_category() ==== 文章分类页,eg:is_category(4) 、 is_category(‘movies’)
is_tag() ====文章标签页
is_archive() ==== 归档页
is_404() ==== 404页
is_search() ==== 搜索结果页
is_feed() ==== 订阅页
home_url() === 获取根域名
add_query_arg(array()) ===获取页面别名,如果带上根域名:home_url(add_query_arg(array()))
获取网站信息:bloginfo( $show ); 同:get_bloginfo($show),区别在于后者返回数据,而不是打印出来。
$show (字符串string) (可选)你需要输出的信息的关键词, 默认: name
'name' - 显示在 设置 > 常规 中设置的“站点标题”。 该数据是从 wp_options 这个数据表中检索到的 "blogname"记录。'description' - 显示在 设置 > 常规 中设置的“副标题”。该数据是从 wp_options 这个数据表中检索到的 "blogdescription" 记录。'wpurl' - 显示在 设置 > 常规 中设置的 “WordPress 地址 (URL)”。该数据是从 wp_options 这个数据表中检索到的 "siteurl" 记录。 可以考虑使用 site_url() 来代替,尤其是在使用 子目录路径方式,而不是使用 子域名 来配置多站点时(bloginfo将返回根网站的URL,而不是子站点的URL)。'siteurl' / 'url' - 显示在 设置 > 常规 中设置的 “站点地址(URL)”)”。该数据是从 wp_options 这个数据表中检索到的 "home"记录。 可以考虑使用 home_url() 代替。'admin_email' - 显示在 设置 > 常规 中设置的 “电子邮件地址”。该数据是从 wp_options 这个数据表中检索到的 "admin_email"记录。'charset' - 显示在 设置 > 常规 中设置的“页面和feed的编码”。该数据是从 wp_options 这个数据表中检索到的"blog_charset" 记录。(注:3.5.1+好像已经没有这个选项了)'version' - 显示你当前使用的 WordPress 版本。该数据是在 wp-includes/version.php 检索到的 $wp_version 这个字段的值。'html_type' - 显示WordPress HTML 页面中的内容类型(默认: "text/html")。该数据可以从 wp_options 这个数据表中检索到的 "html_type" 记录。主题和插件可以通过使用 pre_option_html_type 过滤器覆盖默认值。'text_direction' - 显示 WordPress HTML 页面的文本方向。可以考虑使用 is_rtl() 代替。'language' - 显示WordPress的语言。'stylesheet_url' - 显示当前使用的主题的 CSS文件(通常为 style.css)路径。可以考虑使用 get_stylesheet_uri() 代替。'stylesheet_directory' - 显示当前使用的主题的样式表路径。可以考虑使用 get_stylesheet_directory_uri() 代替。'template_url' / 'template_directory' - 当前主题的 URL 路径 。在子主题中, get_bloginfo('template_url') 和 get_template() 都将返回父主题的目录。可以考虑使用 get_template_directory_uri() (用于父主题目录)或get_stylesheet_directory_uri() (用于子主题目录)代替。'pingback_url' - 显示通告文件 XML-RPC 的URL (xmlrpc.php)'atom_url' - 显示 Atom feed URL (/feed/atom)'rdf_url' - 显示 RDF/RSS 1.0 feed URL (/feed/rfd).'rss_url' - 显示 RSS 0.92 feed URL (/feed/rss).'rss2_url' - 显示 RSS 2.0 feed URL (/feed).'comments_atom_url' - 显示评论的 Atom feed URL (/comments/feed).'comments_rss2_url' - 显示评论的 RSS 2.0 feed URL (/comments/feed).
读取列表: wordpress获取分类下文章列表四种方法
读取文章略缩图,就是文章中包含的图片,自动提取出来:
属性:
single_cat_title( '', false ) 或者 the_archive_title('<b>','</b>'):获取分类名称
get_the_archive_description:分类描述
遍历列表:
<?php endwhile; ?>
这里调用分页代码
<?php endif; ?>
分页:
系统自带分页:
首页模板-index.php,这个模板决定你博客的主页长什么样子
文章模板-single.php,这个模板决定你单篇博客长什么样子
搜索模板-search.php,这个决定你搜索博客之后的文章列表页长什么样子
存档模板-archive.php,这个决定你通过分类,标签等分类过滤之后的文章列表长什么样子
错误页面-404.php,做技术的,这个就不用解释啦
获取模板路径:
<? echo get_template_directory_uri() ?> 模板路径
<?php bloginfo(’stylesheet_url’); ?> 模板style.css路径
get_template_directory() 文件路径常用函数:
bloginfo('name');
bloginfo('url');
bloginfo(’description’);
get_the_ID():文章或页面或者循环中,可以使用该函数直接获取the_ID():
is_page($page):是否为某一个页面
参数:$page 页面ID,页面标题或者页面别名,可选,默认值为空
返回的值:逻辑值(true/false)
is_sticky($post_ID):判断当前页面类型是否为置顶文章,$post_ID (可选) 文章ID
is_singular() :非列表页
is_home() || is_front_page() ==== 判断是否主页
is_single() ==== 文章页
is_page() ==== 页面
is_category() ==== 文章分类页,eg:is_category(4) 、 is_category(‘movies’)
is_tag() ====文章标签页
is_archive() ==== 归档页
is_404() ==== 404页
is_search() ==== 搜索结果页
is_feed() ==== 订阅页
home_url() === 获取根域名
add_query_arg(array()) ===获取页面别名,如果带上根域名:home_url(add_query_arg(array()))
获取网站信息:bloginfo( $show ); 同:get_bloginfo($show),区别在于后者返回数据,而不是打印出来。
$show (字符串string) (可选)你需要输出的信息的关键词, 默认: name
'name' - 显示在 设置 > 常规 中设置的“站点标题”。 该数据是从 wp_options 这个数据表中检索到的 "blogname"记录。'description' - 显示在 设置 > 常规 中设置的“副标题”。该数据是从 wp_options 这个数据表中检索到的 "blogdescription" 记录。'wpurl' - 显示在 设置 > 常规 中设置的 “WordPress 地址 (URL)”。该数据是从 wp_options 这个数据表中检索到的 "siteurl" 记录。 可以考虑使用 site_url() 来代替,尤其是在使用 子目录路径方式,而不是使用 子域名 来配置多站点时(bloginfo将返回根网站的URL,而不是子站点的URL)。'siteurl' / 'url' - 显示在 设置 > 常规 中设置的 “站点地址(URL)”)”。该数据是从 wp_options 这个数据表中检索到的 "home"记录。 可以考虑使用 home_url() 代替。'admin_email' - 显示在 设置 > 常规 中设置的 “电子邮件地址”。该数据是从 wp_options 这个数据表中检索到的 "admin_email"记录。'charset' - 显示在 设置 > 常规 中设置的“页面和feed的编码”。该数据是从 wp_options 这个数据表中检索到的"blog_charset" 记录。(注:3.5.1+好像已经没有这个选项了)'version' - 显示你当前使用的 WordPress 版本。该数据是在 wp-includes/version.php 检索到的 $wp_version 这个字段的值。'html_type' - 显示WordPress HTML 页面中的内容类型(默认: "text/html")。该数据可以从 wp_options 这个数据表中检索到的 "html_type" 记录。主题和插件可以通过使用 pre_option_html_type 过滤器覆盖默认值。'text_direction' - 显示 WordPress HTML 页面的文本方向。可以考虑使用 is_rtl() 代替。'language' - 显示WordPress的语言。'stylesheet_url' - 显示当前使用的主题的 CSS文件(通常为 style.css)路径。可以考虑使用 get_stylesheet_uri() 代替。'stylesheet_directory' - 显示当前使用的主题的样式表路径。可以考虑使用 get_stylesheet_directory_uri() 代替。'template_url' / 'template_directory' - 当前主题的 URL 路径 。在子主题中, get_bloginfo('template_url') 和 get_template() 都将返回父主题的目录。可以考虑使用 get_template_directory_uri() (用于父主题目录)或get_stylesheet_directory_uri() (用于子主题目录)代替。'pingback_url' - 显示通告文件 XML-RPC 的URL (xmlrpc.php)'atom_url' - 显示 Atom feed URL (/feed/atom)'rdf_url' - 显示 RDF/RSS 1.0 feed URL (/feed/rfd).'rss_url' - 显示 RSS 0.92 feed URL (/feed/rss).'rss2_url' - 显示 RSS 2.0 feed URL (/feed).'comments_atom_url' - 显示评论的 Atom feed URL (/comments/feed).'comments_rss2_url' - 显示评论的 RSS 2.0 feed URL (/comments/feed).
读取列表: wordpress获取分类下文章列表四种方法
读取文章略缩图,就是文章中包含的图片,自动提取出来:
//文章列表缩略图
if( !function_exists('my_auto_thumbnail')){
function emtx_auto_thumbnail($pID,$thumb='thumbnail') {
$blogimg = FALSE;
if (has_post_thumbnail()) {
$blogimg = wp_get_attachment_image_src(get_post_thumbnail_id($pID),$thumb);
$blogimg = $blogimg[0];
}
elseif ($postimages = get_children("post_parent=$pID&post_type=attachment&post_mime_type=image&numberposts=0")) {
foreach($postimages as $postimage) {
$blogimg = wp_get_attachment_image_src($postimage->ID, $thumb);
$blogimg = $blogimg[0];
}
}
elseif (preg_match('/<img [^>]*src=["|\']([^"|\']+)/i', get_the_content(), $match) != FALSE) {
$blogimg = $match[1];
}
if($blogimg) {
$blogimg = '<aclass="img-thumbnail" href="'. get_permalink().'"><img src="'.$blogimg.'" alt="'.get_the_title().'" /></a>';
}
return $blogimg;
}
}
使用方法:
if(my_auto_thumbnail($post->ID)){
echo my_auto_thumbnail($post->ID);
}
分类:属性:
single_cat_title( '', false ) 或者 the_archive_title('<b>','</b>'):获取分类名称
get_the_archive_description:分类描述
遍历列表:
<?php if(have_posts()) : ?><?php while(have_posts()) : the_post(); ?>
<?php the_title(); the_permalink(); ?>
这里显示列表数据<?php endwhile; ?>
这里调用分页代码
<?php endif; ?>
分页:
系统自带分页:
the_posts_pagination( array(
'mid_size' => 3,
'prev_text' =>'上一页',
'next_text' =>'下一页',
'before_page_number' => '第',
'after_page_number' => '页',
) );
自定义分页:加入 functions.php
//自定义分页
function my_fenye() {
$p = 3;
if ( is_singular() ) return;
global $wp_query, $paged;
$max_page = $wp_query->max_num_pages;
if ( $max_page == 1 ) return;
echo '<ul class="pagination">';
if ( empty( $paged ) ) $paged = 1;
if ( $paged > 1 ) my_to_link( 1, '首页' );
// echo '<li class="page-item">' . get_previous_posts_link('上一页') . '</li>';
for( $i = $paged - $p; $i <= $paged + $p; $i++ ) {
if ( $i > 0 && $i <= $max_page ) $i == $paged ? print "<li class='page-item active'><a>{$i}</a></li>" : my_to_link( $i );
}
// echo '<li class="page-item">' . get_next_posts_link('下一页') . '</li>';
if ( $paged != $max_page ) my_to_link( $max_page, '尾页' );
echo '<li class="page-item disabled"><a class="page-link" href="#">共 '.$max_page.' 页</a></li>';
echo '</ul>';
}
function my_to_link( $i, $title = '' ) {
if ( $title == '' ) $title = "{$i}";
echo "<li class='page-item'><a href='", esc_html( get_pagenum_link( $i ) ), "'>{$title}</a></li>";
}
调用:
<?php my_fenye();?>
本文标签:
很赞哦! ()
相关教程
图文教程
wordpress网站下载到本地运行测试
作为站长而言,有时候我们可能会碰到更换服务器或者为网站做一个整体布局修改和升级,我们首先需要做的就是对数据库和整个wordpress网站的 主题和插件等等相关文件进行本地备份。
使用代理服务器解决WordPress升级慢的方法
更新WordPress版本有两种方法,在后台点击自动升级或者手动下载新的版本替换旧的。为了方便,一般选择前者自动升级。
wordpress文章保存位置在哪
wordpress中的文章是存放在mysql数据库中的post表的。登录后可见,需要wordpress主题支持该功能,目前支持登录后可见的主题有Duxmeng
wordpress怎么安装主题,wordpress主题安装方法
wordpress怎么安装主题,主题安装教程方法一首先实现登陆wordpress站点,点击外观-主题。然后点击添加,选择适合你的或者你喜欢的主题。
相关源码
-
(自适应响应式)高端珠宝首饰奢侈品pbootcms模板下载本模板为珠宝首饰及奢侈品行业打造,采用PbootCMS内核开发,具备卓越的视觉表现力与商业转化能力。自适应设计确保在手机端呈现产品细节,后台数据实时同步,助您高效展示钻石查看源码 -
(PC+WAP)红色家装设计智能家居家具建材pbootcms网站源码下载本模板基于PbootCMS系统开发,为智能家居、家装设计及家具建材行业设计。采用现代化布局风格,突出家居设计行业特色,适合展示各类家居产品、设计方案和建材信息。查看源码 -
(自适应html5)重工业钢铁机械设备网站pbootcms响应式模板下载为重工业领域打造的响应式网站模板,助力企业高效展示产品与服务,基于PbootCMS开发的工业级网站模板,特别适合钢铁制造、机械设备生产等重工业企业使用。查看源码 -
宽屏自适应搬家家政快递物流公司网站模板该宽屏大气的响应式网站模板专为搬家公司、家政服务及物流快递企业设计,基于PbootCMS内核开发,通过自适应布局确保手机、PC等多终端体验一致,助力企业高效构建专业在线服务平台。查看源码 -
(带手机版)绿色生态农业种植农产品网站pbootcms源码下载本模板基于PbootCMS内核开发,为生态农业企业量身打造,适用于农业种植、有机农场、农产品电商等业务场景。模板设计充分体现绿色环保理念,突出农业特色,同时保持简洁大气的视觉效果,帮助农业企业建立专业形象。查看源码 -
(自适应响应式)英文外贸电子产品手机配件网站pbootcms模板专业级外贸网站模板基于PbootCMS内核开发,为电子产品跨境贸易企业设计。采用响应式布局技术,确保电脑、平板、手机等设备访问时自动适配显示效果。数据实时同步管理,一次编辑全平台生效。查看源码
| 分享笔记 (共有 篇笔记) |

