一、 WordPress 模板基本文件
- style.css 样式表文件
- index.php 主页文件
- single.php 日志单页文件
- page.php 页面文件
- archvie.php 分类和日期存档页文件
- searchform.php 搜索表单文件
- search.php 搜索页面文件
- comments.php 留言区域文件 (包括留言列表和留言框)
- 404.php 404 错误页面
- header.php 网页头部文件
- sidebar.php 网页侧边栏文件
- footer.php 网页底部文件
二、 WordPress Header 头部 PHP 代码
- 注: 也就是位于<head> 和</head> 之间的 PHP 代码
- <?php bloginfo('name'); ?>
- WordPress 主题样式表文件 style.css 的相对地址
- <?php bloginfo('stylesheet_url'); ?>
- <?php bloginfo('pingback_url'); ?>
- <?php bloginfo('template_url'); ?>
- <?php bloginfo('version'); ?>
- <?php bloginfo('atom_url'); ?>
- <?php bloginfo('rss2_url'); ?>
- <?php bloginfo('url'); ?>
- <?php bloginfo('name'); ?>
- <?php bloginfo('html_type'); ?>
- <?php bloginfo('charset'); ?>
三、 WordPress 主体模板 PHP 代码
- <?php if(have_posts()) : ?>
- <?php while(have_posts()) : the_post(); ?>
- <?php the_time('m-d-y') ?>
- <?php comments_popup_link(); ?>
- <?php the_category(', ') ?>
- <?php edit_post_link(); ?>
- <?php get_links_list(); ?>
- <?php comments_template(); ?>
- <?php wp_list_pages(); ?>
- <?php next_post_link('%link') ?>
- <?php previous_post_link('%link') ?>
- <?php wp_get_archives() ?>
- 显示较新日志链接 (上一页) 和较旧日志链接 (下一页)
- <?php posts_nav_link(); ?>
- <?php bloginfo('description'); ?>
四、其它的一些 WordPress 模板代码
- <?php the_search_query(); ?>
- <?php echo get_num_queries(); ?>
五、 WordPress 调用的常用方法
- 1 、 WordPress 最新文章的调用可以使用一行很简单的模板标签 wp_get_archvies 来实现. 代码如下:
- <?php get_archives('postbypost', 10); ?>
- <?php wp_get_archives('type=postbypost&limit=20&format=custom'); ?>
- 后面这个代码显示你博客中最新的 20 篇文章,其中 format=custom 这里主要用来自定义这份文章列表的显示样式。具体的参数和使用方法你可 以参考官方的使用说明- wp_get_archvies 。 (fromat=custom 也可以不要,默认以 UL 列表显示文章标题。)
补充: 通过 WP 的 query_posts() 函数也能调用最新文章列表, 虽然代码会比较多一点,但可以更好的控制 Loop 的显示,比如你可以设置是否显示摘要。具体的使用方法也可以查看官方的说明。
- <?php
- $rand_posts = get_posts(『numberposts=10&orderby=rand』);
- foreach( $rand_postsas$post ) :
- ?>
- <!–下面是你想自定义的 Loop–>
- <li><a href="<?php%20the_permalink();%20?>"><?php the_title(); ?></a></li>
- <?php endforeach; ?>
- 3. WordPress 调用最新留言
下面是我之前在一个 WordPress 主题中代到的最新留言代码,具体也记不得是哪个主题了。该代码直接调用数据库显示一份最新留言。其中 LIMIT10 限制留言显示数量。绿色部份则是每条留言的输出样式。
- <?php
- global$wpdb;
- $sql = "SELECT DISTINCT ID, post_title, post_password, comment_ID,
- comment_post_ID, comment_author, comment_date_gmt, comment_approved,
- comment_type,comment_author_url,
- SUBSTRING(comment_content,1,30) AS com_excerpt
- FROM $wpdb->comments
- LEFT OUTER JOIN $wpdb->posts ON ($wpdb->comments.comment_post_ID =
- $wpdb->posts.ID)
- WHERE comment_approved = '1' AND comment_type = " AND
- post_password = "
- ORDER BY comment_date_gmt DESC
- LIMIT 10";
- $comments = $wpdb->get_results($sql);
- $output = $pre_HTML; foreach ($commentsas$comment) {
- $output .= "n<li>".strip_tags($comment->comment_author)
- .":" . 」 <a href="". get_permalink($comment->ID) .
- "#comment-". $comment->comment_ID . "" title="on" .
- $comment->post_title . "">" . strip_tags($comment->com_excerpt)
- ."</a></li>";
- } $output .= $post_HTML;
- echo$output;?>
- 4.WordPress 调用相关文章
在文章页显示相关文章
- <?php
- $tags = wp_get_post_tags($post->ID);
- if ($tags) {
- $first_tag = $tags[0]->term_id;
- $args=array(
- 'tag__in' => array($first_tag),
- 'post__not_in'=> array($post->ID),
- 'showposts'=>10,
- 'caller_get_posts'=>1
- );
- $my_query = new WP_Query($args);
- if( $my_query->have_posts() ) {
- while ($my_query->have_posts()) : $my_query->the_post(); ?>
- <li><a href="<?php%20the_permalink()%20?>" rel="bookmark" title="<?php the_title_attribute(); ?>"><?php the_title();?> <?php comments_number(' ','(1)','(%)'); ?></a></li>
- <?php
- endwhile;
- }
- }
- wp_reset_query();
- ?>
- <?php $posts = get_posts( "category=4&numberposts=10" ); ?>
- <?php if( $posts ) : ?>
- <ul><?php foreach( $postsas$post ) : setup_postdata( $post ); ?>
- <li>
- <a href="<?php%20the_permalink()%20?>" rel=」bookmark" title="<?php the_title(); ?>"><?php the_title(); ?></a>
- </li>
- <?php endforeach; ?>
- </ul>
- <?php endif; ?>
- <?php
- global$wpdb;
- $sql = "SELECT DISTINCT ID, post_title, post_password, comment_ID,
- comment_post_ID, comment_author, comment_date_gmt, comment_approved,
- comment_type,comment_author_url,
- SUBSTRING(comment_content,1,14) AS com_excerpt
- FROM $wpdb->comments
- LEFT OUTER JOIN $wpdb->posts ON ($wpdb->comments.comment_post_ID =
- $wpdb->posts.ID)
- WHERE comment_approved = '1' AND comment_type = " AND
- post_password = "
- ORDER BY comment_date_gmt DESC
- LIMIT 10";
- $comments = $wpdb->get_results($sql);
- $output = $pre_HTML;
- foreach ($commentsas$comment) {
- $output .= "
<li>".strip_tags($comment->comment_author) - .":" . " <a href="" . get_permalink($comment->ID) .
- "#comment-" . $comment->comment_ID . "" title="on " .
- $comment->post_title . "">" . strip_tags($comment->com_excerpt)
- ."</a></li>";
- }
- $output .= $post_HTML;
- echo$output;?>
- 7.WordPress 调用含 gravatar 头像的评论输出
- <?php
- global$wpdb;
- $sql = "SELECT DISTINCT ID, post_title, post_password, comment_ID, comment_post_ID, comment_author, comment_date_gmt, comment_approved,comment_author_email, comment_type,comment_author_url, SUBSTRING(comment_content,1,10) AS com_excerpt FROM $wpdb->comments LEFT OUTER JOIN $wpdb->posts ON ($wpdb->comments.comment_post_ID = $wpdb->posts.ID) WHERE comment_approved = '1' AND comment_type = " AND comment_author != '笔者' AND post_password = 」 ORDER BY comment_date_gmt DESC LIMIT 10";
- $comments = $wpdb->get_results($sql);
- $output = $pre_HTML;
- foreach ($commentsas$comment) {
- $output .= "
<li>".get_avatar(get_comment_author_email('comment_author_email'), 18). " <a href="" . get_permalink($comment->ID) . "#comment-" . $comment->comment_ID . "" title="" . $comment->post_title . " 上的评论">". strip_tags($comment->comment_author) .": ". strip_tags($comment->com_excerpt) ."</a></li>"; - }
- $output .= $post_HTML;
- $output = convert_smilies($output);
- echo$output;
- ?>
上面代码把 comment_author 的值改成你的 ID,18 是头像大小,10 是评论数量。
- <?php $count_posts = wp_count_posts(); echo$published_posts = $count_posts->publish;?>
- <?php $count_posts = wp_count_posts(); echo$draft_posts = $count_posts->draft; ?>
- <?php echo$wpdb->get_var("SELECT COUNT(*) FROM $wpdb->comments");?>
- <?php echofloor((time()-strtotime("2008-8-18"))/86400); ?>
- <?php echo$count_tags = wp_count_terms('post_tag'); ?>
- <?php $count_pages = wp_count_posts('page'); echo$page_posts = $count_pages->publish; ?>
- <?php echo$count_categories = wp_count_terms('category'); ?>
- <?php $link = $wpdb->get_var("SELECT COUNT(*) FROM $wpdb->links WHERE link_visible = 'Y'"); echo$link; ?>
- <?php $users = $wpdb->get_var("SELECT COUNT(ID) FROM $wpdb->users"); echo$users; ?>
- <?php $last = $wpdb->get_results("SELECT MAX(post_modified) AS MAX_m FROM $wpdb->posts WHERE (post_type = 'post' OR post_type = 『page』) AND (post_status = 'publish' OR post_status = 'private')");$last = date('Y-n-j', strtotime($last[0]->MAX_m));echo$last; ?>
- is_author('Elite Hacker')
- 上面是通过不同的判断实现以年、月、日、时间等方式来显示归档
- 判断是否翻页,比如你当前的 blog 是 http://domain.com 显示 http://domain.com?paged=2 的时候,这个判断将返 回真,通过这个函数可以配合 is_home 来控制某些只能在首页显示的界面,例如:
//这里写你想显示的内容,包括函数
或者:
- <?php if(is_home() && !is_paged() ):?>
//这里写你想显示的内容,包括函数
显示 Blogroll 中的链接;
<!–smilies–>- <?php
- function<s/ol/li .= "
- pan> wp_smilies() { - global$wpsmiliestrans;
- if ( !get_option('use_smilies') or (emptyempty($wpsmiliestrans))) return;
- $smilies = array_unique($wpsmiliestrans);
- $link=";
- foreach ($smiliesas$key => $smile) {
- $file = get_bloginfo('wpurl').'/wp-includes/images/smilies/'.$smile;
- $value = " ".$key." ";
- $img = "<img src="{$file}" alt="{$smile}" />";
- $imglink = htmlspecialchars($img);
- $link .= "<a href="#commentform" title="{$smile}" onclick="document.getElementById('comment').value += '{$value}'">{$img}</a> ";
- }
- echo '<div>'.$link.'</div>';
- }
- ?>
- <?php wp_smilies();?>
- <!–smilies—>
- 将以上代码复制到 comments.php 中合适的位置:
留着自己学习之用!