手把手一步一步的教你用wordpress自定义模板主题开发仿站,本教程包含了wordpress首页、列表页、文章页、搜索页、侧边栏、讨论留言、会员登陆注册、自定义留言表单、等常用的网站功能开发教程以及wordpress常用调用标签教程。本教程需要使用到-wordpress functions.php常用功能与常用插件

wordpress模板开发教程_php

一、wordpress导航菜单调用调用标签

<? wp_nav_menu() ?>                            方法一(默认菜单调用方法)

<?php                                          方法二(默认菜单调用方法,可更改样式)
  wp_nav_menu( array(
    'theme_location'  => '',                   //导航别名
    'menu'   => '',                            //期望显示的菜单
    'container'  => 'div',                     //容器标签
    'container_class' => '',                   //ul父节点class值
    'container_id'  => '',                     //ul父节点id值
    'menu_class'   => 'menu',                  //ul节点class值
    'menu_id'   => '',                         //ul节点id值
    'echo'  => true,                           //是否输出菜单,默认为真
    'fallback_cb' => 'wp_page_menu',           //菜单不存在时,返回默认菜单,设为false则不返回
    'before' => '',                            //链接前文本
    'after'  => '',                            //链接后文本
    'link_before'  => '',                      //链接文本前
    'link_after'  => '',                       //链接文本后
    'items_wrap'  => '<ul id="%1$s" class="%2$s">%3$s</ul>',   //如何包装列表
    'depth' => 0,                             //菜单深度,默认0
    'walker' => ''                            //自定义walker
  ) );

?>

二、wordpress首页模板主题开发调用标签

1、wordpress首页调用指定栏目循环标签

/**其中cat=20代表分类ID,posts_per_page=4代表显示几条记录 **/
<?php query_posts('cat=20&posts_per_page=4'); while(have_posts()): the_post(); ?>   
   <li>
   <a href="<?php the_permalink(); ?>" target="_blank">  //链接
   <img src=" <?php $url = wp_get_attachment_url(get_post_thumbnail_id($post->ID)); echo $url; ?>" title="<?php the_title();?>" /> //特色图片缩略图
   <h2><?php the_title();?></h2>   //文章标题一
   <h2><?php echo mb_strimwidth(get_the_title(), 0, 16, ''); ?></h2>   //可控字数:文章标题二
   <p><?php the_excerpt(); ?></p>  //文章简介方法一
   <p><?php echo mb_strimwidth(strip_tags(apply_filters('the_content', $post->post_content)), 0, 200,"……"); ?></p> //可控字数:文章简介方法二
   <p><?php the_date_xml()?></p>        //文章发布时间 方法一
   <p><?php the_time('F d, Y') ?></p>   //文章发布时间 方法二
   <p><?php the_time('y-m-d H:i:s') ?></p>      //文章发布时间 方法三
  </a>
   </li>   
<?php endwhile; wp_reset_query(); ?>

2、调用指定分类栏目名

//数字2指的是栏目id
<?php echo get_cat_name(2);?>

3、调用指定分类的栏目链接:

//数字2指的是栏目id
<?php echo get_category_link(2); ?>

4、调用指定分类的栏目别名:

//2为栏目id
<?php $cat = get_category(2);echo $cat->slug;?>

5、调用指定栏目子菜单

//child_of=3        为调用指定分类的ID号,
//sort_column=name  分类名
//hide_empty=0      是否隐藏没有文章的分类
<?php wp_list_cats('sort_column=name&optioncount=0&hierarchical=1&hide_empty=0&child_of=3'); ?>

6、调用指定id的文章

输出ID为13的文章标题 
<?php $id=13;  $title = get_post($id)->post_title;  echo $title; ?>

7、获取指定单页栏目id的标题与内容

获取单页栏目id为6的栏目名
<?php
    $page_id = 6;
    $page_data = get_page($page_id);
    echo $page_data -> post_title;
?>
获取单页栏目id为6的栏目内容
<?php
   $page_id = 6;
    $page_data = get_page($page_id);
    echo apply_filters('the_content', $page_data -> post_content);     
?>

8、友情链接调用标签(注:方法一与方法二为同一种方法,只不过一个输出默认样式,另一个可根据要求设置更灵活)

方法一、<?php wp_list_bookmarks( $args );?>
方法二、
<?php
 $args=array(
'orderby' => 'name',                 //根据名称排序
'order' => 'ASC',                    //升序或降序
'limit' => -1,                       //设置输出链接的最大条数 -1为输出全部
'category' => '',                    //字符串,链接分类id 有显示分类下链接 没有显示全部链接
'category_name' => '',               //字符串,链接分类名 有在链接前显示该分类名,没有显示所有链接分类名
'hide_invisible' => 1,               
'show_updated' => 0,
'echo' => 1,
'categorize' => 1,                   //布尔型,设置是否按各自分类显示 1 按照分类显示 0显示全部链接
'title_li' => __('Bookmarks'),       //字符串,链接标题的头文字或代码,默认是:Bookmarks设置是否按照列表的方式排列
'title_before' => '',                //字符串,分类标题前文字或代码
'title_after' => '',                 //字符串,分类标题后文字或代码
'category_orderby' => 'name',         //字符串,根据分类名称排序
'category_order' => 'ASC',            //字符串,分类链接的升降序排列
'class' => 'linkcat',                 //字符串,链接的class属性
'category_before' => '',              //字符串,分类链接前的文字或代码
'category_after' => '',               //字符串,分类链接后的文字或代码

);
wp_list_bookmarks( $args );           
?>

方法三、<?php get_links_list(); ?>

三、wordpress列表页模板主题开发(聚合页)调用标签

1、wordpress列表页循环调用标签

<?php if (have_posts()) : ?>
   <?php while (have_posts()) : the_post(); ?>
     <li class=" homebk1-item"> 
      <a href="<?php the_permalink(); ?>">    //链接
       <div class="homebk1-img"> 
        <img src="<?php $full_image_url = wp_get_attachment_image_src( get_post_thumbnail_id($post->ID), 'full'); echo $full_image_url[0]; ?>" />  //缩略图(特色图片)
       </div> 
        <h3><?php the_title();?></h3>  //标题方法一
        <h3><?php  wp_trim_words( get_the_title(), 10 );?></h3> //标题方法二 可限制字数
        <p><? the_excerpt(); ?></p>   //简介方法一
        <p><?php  wp_trim_words( get_the_excerpt(), 20 );?></p> //简介方法二 可限制字数
      </a> 
	   <p><?php the_date_xml()?> </p>
     </li> 
  <?php endwhile;?>
 <?php endif; ?>

2、当前分类栏目名,当前分类i栏目d,当前分类栏目链接

<?
	$category_title= single_cat_title('', false );
	$category_id = get_cat_ID($category_title);
	$category_link = get_category_link( $category_id );
	echo $category_title; //输出当前分类名
	echo $category_id;    //输出当前分类id
	echo $category_link   //输出当前分类链接
?>

3、当前分类栏目简介描述(Description)

<?php echo category_description(); ?>

4、当前分类所属的顶级分类栏目的分类名与分类链接

<a href="<?php echo get_category_link(get_category_root_id($cat)); ?>"><?php echo get_cat_name(get_category_root_id($cat)); ?></a>

4、wordpress分页标签 (方法三:functions添加分页代码)

<? posts_nav_link(); ?>  //方法一  官方默认调用方法
<?php if(function_exists('wp_page_numbers')) : wp_page_numbers(); endif; ?> //方法二 需用插件 wp-page-numbers
<?php kriesi_pagination($query_string); ?>  //方法三:自定义分页代码,可以根据需要更改分页代码-需在functions添加分页代码

5、栏目页面包屑调用标签 (方法二:functions添加面包屑代码)

//方法一 直接在需要放置面包屑的地方添加如下代码
<a href="<? bloginfo('url'); ?>">首页</a></li>> 
		<?
		if(is_category()){single_cat_title();}
		elseif(is_search()){echo $s;}
		elseif(is_single()){
			$cat=get_the_category();
			$cat=$cat[0];
			echo '<a href="'.get_category_link($cat).'">'.$cat->name. ' </a>';
		}elseif(is_page()){ 
			the_title();
		}elseif(is_404()){echo '404错误页面';}

?>

方法二  在functions.php文件下添加如下代码 

function wz(){
$cat=get_the_category();
$cat=$cat[0];
$positions = '<li><a href="'.get_category_link($cat).'">'.$cat->name. '</a></li>>'; 
if(!is_home() ){ 
	echo '<li><a href="'. get_settings('home') .'">'. '首页></a></li>';  
if(is_category()){
	echo $positions;
}
elseif(is_single()){
	echo $positions ;
    echo  the_title();
}
elseif(is_search()){echo $s;}
elseif(is_page()){ 
	the_title();
}elseif(is_404()){echo '404错误页面';}

 } 
}

//前台调用代码  <? wz(); ?>

6、调用当前栏目子菜单 (functions添加获取当前分类子分类列表代码)

在需要调用当前顶级分类栏目的子分类处添加如下代码
<?php
if(is_single()||is_category()) { //如果是文件页面或分类页
 if(get_category_children(get_category_root_id(the_category_ID(false)))!= "" ) {//如果有子分类
	echo '<ul class="sidebar-list1">';
	echo wp_list_categories("child_of=".get_category_root_id(the_category_ID(false)). "&depth=0&hide_empty=0&title_li=&orderby=id&order=ASC");
	echo '</ul>';
  }else{ 
	    //如果没有获取顶级分类
	   }
}
?>

7、不同分类栏目调用不同的模板 

category.php       //默认分类模板
方法一
category-10.php    //10是分类id categor后跟-id 系统会自动获取与之对应的模板 没有对应模板就找对应模板
方法二
category-别名.php  //后台分类目录名称后有一个别名  分类模板category-别名会自动调用别名相同的模板

四、wordpress内容页模板主题开发(文章页)调用标签

<?php the_title(); ?>              1、标题文章内容页调用标签
<?php the_excerpt(); ?>            2、简介文章调用标签
<? the_post_thumbnail(); ?>        3、缩略图文章页(特色图片)调用标签 方法一
<?php the_author(); ?>             4、作者文章页调用标签
<?php the_time('y-m-d H:i:s') ?>   5、发布时间文章也调用标签
<?php the_content(""); ?>          6、文章内容文章页调用标签
<?php the_permalink();?>           7、当前文章页链接地址
<? get_the_id()  ?>                8、当前文章页ID
<?php foreach((get_the_category()) as $category){echo $category->cat_name;}?>          9、当前文章所属分类栏目名
<?php foreach((get_the_category()) as $category){echo get_category_link($category);}?> 10、当前文章所属分类栏目链接
<? previous_post_link('上一篇: %link'); ?> <? next_post_link('下一篇: %link'); ?>       11、上一篇、下一篇调用
<?php comments_popup_link('0 条评论', '1 条评论', '% 条评论', '', '评论已关闭'); ?>      12、输出评论数
<?php echo get_avatar( get_the_author_email(), 36 ); ?>                                13、调用作者头像
<img src="<?php $full_image_url = wp_get_attachment_image_src( get_post_thumbnail_id($post->ID), 'full'); echo $full_image_url[0]; ?>" alt="" /> 3、特色图片调用标签方法二,只调用图片地址链接

wordpress上一篇下一篇案例
<div class="next">
      <div class="shang"><?php if (get_previous_post()) { previous_post_link('上一条: %link');} else {echo "没有了,已经是最后文章";} ?></div>
      <div class="xia"><?php if (get_next_post()) { next_post_link('下一条: %link');} else {echo "没有了,已经是最新文章";} ?></div>
</div>

 2、wordpress文章内容页面包屑调用标签,同上述列表页调用标签相同

3、文章内容single.php页面,根据文章所属不同分类选择不同的文章页模板(注:新创建content.php为文章默认页面,比如新闻栏目别名为new,新闻文章页为 content-new.php 如果没有该页面就自动调用默认content.php为文章页)

    3.1、不同分类下的文章调用不同模板

<?
the_post();
//获取当前文章id
$cat=get_the_category(get_the_id());
//获取当前文章分类
$name=$cat[0]->slug;
//加载content-$name.php  指定模板文件不存在 就调用默认文章模板content.php
get_template_part( 'content', $name ) 
?>

五、wordpress独立单页调用标签

1、不同独立页面调用不同模板

page.php       独立页默认模板文件

page-13.php    方法一 13为独立页id id对应不同页面id即可

page-about.php about为独立页别名  方法同上

2、当前单页栏目名 与 当前单页栏目内容

<?php wp_title('');?>  //当前栏目名
<?php the_content(""); ?> //当前栏目内容

六、wordpress系统公共产数调用标签

<? bloginfo('charset'); ?>                     调用网站编码
<? bloginfo('name'); ?>					       调用网站名称
<? bloginfo('description'); ?>                 调用网站描述
<? bloginfo('stylesheet_url'); ?>              调用网站css路径(绝对路径 href="<?php bloginfo('template_url'); ?>/css/abc.css" )
<? wp_head(); ?>                               wordpress钩子调用公共头部
<? wp_footer(); ?>                             调用公共底部
<?php get_sidebar(); ?>                        调用默认侧边栏
<?php get_template_part( 'link' ); ?>          调用自定义公共部分link.php
<?php   /*Template Name: about*/  ?>           自定义模板调用, 在自定义模板头部添加
<?php echo get_option('home'); ?>              输出网站首页网址|调用系统产数options表中home字段(其他字段同理)
<? wp_loginout(); ?>                           登陆|退出 ,获取退出链接(未登录显示登陆)陆
<? wp_register (); ?>                          获取注册链接(登陆成功显示管理站点)需在后台开启注册功能

七、wordpress自定义字段调用标签

1、自定义图片字段调用

<?php $image = get_field('pro-img1'); echo $image['url'];?>  //pro-img1为自定义图片的字段别名

案列:<img src="<?php $image = get_field('pro-img1'); echo $image['url'];?>" alt="<?php echo $image['alt']; ?>" />

2、自定义字段调用

<?php the_field('pro-cc'); ?>   //方法一 pro-cc为自定义字段别名
<?php $key="pro-cc"; echo get_post_meta($post->ID, $key, true); ?> //方法二

获取多个相同自定义字段值
<? $ziduan = get_post_meta($post->ID,'ziduan', false); ?>
<? foreach( $ziduan as $ziduan ){  echo  $ziduan  }?>

使用插件增加的字段
<?php echo get_field('seo-keywords'); ?>

八、wordpress搜索页调用标签

1、自定义wordpress模板主题搜索框制作

wordpress自定义全站搜索框
<form class="search-form" method="get" action="<?php bloginfo('home'); ?>"> 
       <input type="text" placeholder="搜索..." name="s" /> 
       <button type="submit"> <i class="iconfont icon-search"></i> </button> 
</form>

wordpress自定义搜索指定栏目分类  (value="" 为指定分类的id)
<form class="search-form" method="get" action="<?php bloginfo('home'); ?>"> 
       <input type="text" placeholder="搜索..." name="s" /> 
        <input type="hidden" name="cat" value="4,11,9,22,20,10,18,14,12,13,1" />
       <button type="submit"> <i class="iconfont icon-search"></i> </button> 
</form>

wordpress自定义不搜索该分类下的文章  (value="" 为指定分类的id)
<form class="search-form" method="get" action="<?php bloginfo('home'); ?>"> 
       <input type="text" placeholder="搜索..." name="s" /> 
       <input type="hidden" name="cat" value="-4,-11,-9,-22" />
       <button type="submit"> <i class="iconfont icon-search"></i> </button> 
</form>

2、wordpress搜索页search.php制作

获取搜索词
<? echo get_search_query()?>
搜索列表页 方法一 直接使用分类列表页循环方式即可
搜索列表页 方法二
       <?
		if(have_posts()){
		while(have_posts() ){
		the_post();
		?>

       <li> 
        <div class="shijian">
         <?php the_time('y-m') ?>
         <span><?php the_time('d') ?></span>
        </div> <a href="<?php the_permalink(); ?>" title="<?php the_title();?>"><?php the_title();?></a> 
		<p><? the_excerpt(); ?></p>
		<p></p>
	  </li> 
	 <? }
	
		}else{
			echo "没有搜索到文章";
		}
	?>

九、wordpresstag调用标签

wordpress tag标签调用,默认方式
<?php wp_tag_cloud(); ?> 
带参数方式调用
<?php wp_tag_cloud(‘number=50&orderby=count&order=DESC&smallest=12&largest=12&unit=px’); ?>

smallest:标签文字最小字号,默认为8pt;
largest:标签文字最大字号,默认为22pt;
unit:标签文字字号的单位,默认为pt,可以为px、em、pt、百分比等;
number:调用的标签数量,默认为45个,设置为“0”则调用所有标签;
format:调用标签的格式,可选“flat”、“list”和“array”,默认为“flat”平铺,“list”为列表方式;
orderby:调用标签的排序,默认为“name”按名称排序,“count”则按关联的文章数量排列;
order:排序方式,默认为“ASC”按正序,“DESC”按倒序,“RAND”按任意顺序。
exclude:排除部分标签,输入标签ID,并以逗号分隔,如“exclude=1,3,5,7”不显示ID为1、3、5、7的标签;
include:包含标签,与exclude用法一样,作用相反,如“include=2,4,6,8”则只显示ID为2、4、6、8的标签。

十、wordpress自定义评论留言表单调用标签

1、创建留言模板comments.php 在该模板中添加以下代码 ,在需要使用留言的地方添加   <? comments_template()  ?>  调用标签即可

<div>
	<h3>评论</h3>
	<div>
	<ul>
		<? if(!comments_open() ){?>                          //判断评论功能是否已关闭,如果关闭提示 评论功能已经关闭
		<li><a href="#respond">评论功能已经关闭</a></li>  
		<? }else if( post_password_required()){?>            //post_password_required()设置输入密码才能查看文章  编辑文章右侧设置密码保护
		<li><a href="#respond">请输入密码查看评论内容</a></li>
		<? }else if(!have_comments()){?>                      // 判断当前文章是否有评论
		<li><a href="#respond">还没有评论说两句吧</a></li>
		<? }else{wp_list_comments(); }?>                      //获取所有评论
	</ul>
	</div>
	<div>
		<? if(get_option('comment_registration') && !is_user_logged_in() ){ ?> // 判断用户是否有登陆 
			<p>
			你必须 <a href="<? echo wp_login_url(get_permalink()); ?>">登陆</a>才可以发布评论
			</p>
		<? }else if(comments_open()){comment_form();} ?>      //输出评论窗口
	</div>

</div>

十一、wordpress自定义会员登陆注册调用标签

1、wordpress会员中心链接地址调用标签

<li><? wp_loginout(); ?></li> 如果是登陆状态 显示注销按钮 如果未登陆显示 登陆按钮
<li><? wp_register(); ?></li> 如果是否登陆状态 显示管理站点 否则不显示

<a href="<?php echo site_url('wp-login.php', 'login') ?>">登陆</a>                      登陆链接调用标签
<a href="<?php echo site_url('wp-login.php?action=register', 'login') ?>">注册会员</a>   注册会员链接调用标签
<a href="<?php echo get_option('home'); ?>/wp-login.php?action=lostpassword">忘记密码</a>  忘记密码链接调用标签
<a href="<?php bloginfo('siteurl');?>/wp-admin/profile.php">[个人中心]</a>               个人中心链接调用标签
<?php global $current_user;get_currentuserinfo();echo get_avatar( $current_user->user_email, 32); ?>  获取当前用户头像
<?php global $user_identity, $user_level; echo $user_level;  ?>                                      获取当前用户名

2、wordpress判断是否为登陆状态,如果不是显示登陆和注册按钮;如果为登陆状态显示个人像,和退出登陆按钮 

<?php if(!is_user_logged_in()){ ?>
    <a href="<?php echo site_url('wp-login.php', 'login') ?>">登陆</a>|
	<a href="<?php echo site_url('wp-login.php?action=register', 'login') ?>">注册会员</a>
  <?}else{?>
    <?php global $current_user;get_currentuserinfo();echo get_avatar( $current_user->user_email, 32); ?>  //当前用户头像  32为设置头像尺寸为32
    <a href="<?php bloginfo('siteurl');?>/wp-admin/profile.php"> <?php global $user_identity, $user_level; echo $user_level;  ?> [个人中心 ] </a>
	<a href="<?php echo wp_logout_url( get_permalink() ); ?>">[退出]</a>
  <?}?>

十二、wordpress自定义侧边栏制作

1、wordpress分类列表页侧边栏

<?php if ( is_single() ) :
global $post;
$categories = get_the_category();
foreach ($categories as $category) :
    ?>
    <li class="widget widget_recent_entries" id="<?php $category -> term_id; ?>-posts">
        <h2 class="widgettitle"><?php echo $category -> name; ?></h2>
        <ul>
        <?php
        $posts = get_posts('numberposts=5&category='. $category->term_id);
        foreach($posts as $post) :
        ?>
            <li>
            <a href="<?php the_permalink(); ?>"><?php the_title(); ?></a>
            </li>
        <?php endforeach; ?>
        </ul>
    </li>
<?php
endforeach; endif ;
 ?>

2、wordpress侧边栏,当前文章页所在分类栏目下的文章列表

<?php if ( is_single() ) :
global $post;
$categories = get_the_category();
foreach ($categories as $category) :
    ?>
    <li class="widget widget_recent_entries" id="<?php $category -> term_id; ?>-posts">
        <h2 class="widgettitle"><?php echo $category -> name; ?></h2>  //当前文章所在栏目
        <ul>//下方为循环输出 所在栏目分类下的文章列表
        <?php
        $posts = get_posts('numberposts=5&category='. $category->term_id); //5为循环条数
        foreach($posts as $post) :
        ?>
            <li>
            <a href="<?php the_permalink(); ?>"><?php the_title(); ?></a>
            </li>
        <?php endforeach; ?>
        </ul>
    </li>
<?php
endforeach; endif ;
 ?>

wordpress模板开发教程_wp_02

wordpress自定义模板主题开发仿站教程就先总结到这里,更多wordpress教程或者有什么问题可以关注我,或留言。