一、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 the_permalink(); ?>"><?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 the_permalink() ?>" 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 the_permalink() ?>" 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 .= "\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;?>
- 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 .= "\n<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 .= "\n- 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 中合适的位置:
留着自己学习之用!
本文由 远方的雪山 作者:萨龙龙 发表,转载请注明来源!
评论:
2 条评论,访客:0 条,博主:0 条