您现在的位置是:首页 > 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();?>
本文标签:
很赞哦! ()
相关教程
图文教程
Centos7怎么搭建wordpress
1.安装mysql2.关闭firewalld与selinuxsystemctl stop firewalld.service #临时关闭firewalldsetenforce 0 #临时关闭se
WordPress开启导航菜单功能的实现方法
步骤一:开启导航菜单功能。步骤二:在后台创建菜单,并设置菜单项目,将菜单项目和第一步注册的菜单建立关系。步骤三:早模版文件中调用导航菜单
WordPress怎么做SEO优化
WordPress教程给大家分享最 的优化指南:首先WordPress SEO方面可以说是非常有优势,而做好SEO优化就是WordPress网站流量的保证;
Wordpress中删除不用的图片的方法
默认情况下,WordPress 会将你上传的图片自动生成几种不同大小的缩略图,但是有些WordPress主题根本就不会调用这些缩略图,它们就成了多余的啦。
相关源码
-
(自适应)幽默笑话脑筋急转弯搞笑趣图博客pbootcms模板下载本模板基于PbootCMS系统开发,专为幽默笑话、搞笑趣图类网站设计。采用轻松活泼的布局风格,突出娱乐内容分享特色,适合各类笑话、段子、搞笑图片等内容展示。查看源码 -
(自适应响应式)HTML5中小学早教教育机构类网站pbootcms模板下载基于PbootCMS内核开发的响应式模板,为早教中心、培训学校等教育机构打造,提供从技术架构到视觉呈现的全套网站建设方案。查看源码 -
帝国cms7.5自适应作文新闻资讯教育网站模板本模板基于帝国CMS7.5内核开发,为教育机构、培训学校等知识传播单位打造。通过自适应设计确保在手机、平板、电脑等设备上均能获得专业浏览体验查看源码 -
pbootcms响应式蓝色旅游旅行社pbootcms网站源码下载为旅游公司、旅行社定制的响应式网站模板,聚焦旅游线路展示、景点推荐及预约服务场景。采用PbootCMS内核开发,自适应技术确保PC与手机端数据实时同步查看源码 -
(自适应)绿色LED灯具照明灯饰灯光灯泡pbootcms网站源码下载本模板基于PbootCMS内核开发,为LED照明、灯具制造及相关光电技术企业量身打造。设计充分考虑了照明行业的展示需求,从产品陈列到技术说明,从光源展示到工程案例,每一个细节都体现出专业照明行业的特点。查看源码 -
(自适应响应式)蓝色外贸英文产品介绍展示网站模板本模板采用手工编写的DIV+CSS架构,代码精简高效。适配手机端浏览,数据实时同步更新。内置SEO优化框架,支持独立设置各页面标题、关键词及描述。开源代码结构清晰,便于二次开发。查看源码
| 分享笔记 (共有 篇笔记) |

