随着互联网的快速发展,越来越多的企业和个人选择使用WordPress搭建自己的网站。WordPress作为一个开源的博客平台,拥有丰富的插件和主题,使得网站建设和维护变得简单易行。市面上的主题千篇一律,如何让自己的网站脱颖而出,就需要我们对其进行自定义结构的设计。本文将为大家介绍WordPress自定义结构的相关知识,帮助大家打造个性化的网站。
一、了解WordPress自定义结构
1. 什么是WordPress自定义结构?
WordPress自定义结构,即对WordPress网站的结构进行个性化设计,包括布局、样式、功能等方面。通过自定义结构,可以使网站更具特色,提升用户体验。
2. 自定义结构的优势
* 个性化:满足不同用户的需求,打造独特的网站风格。
* 提升用户体验:优化页面布局,提高网站访问速度。
* 增强SEO优化:有利于搜索引擎抓取网站内容,提高排名。
二、WordPress自定义结构的方法
1. 修改主题文件
修改主题文件是WordPress自定义结构最常见的方法。以下是一些常用的主题文件:
* functions.php:用于添加自定义函数和钩子。
* header.php:定义网站头部结构。
* footer.php:定义网站底部结构。
* sidebar.php:定义侧边栏结构。
示例:
“`php
// 在functions.php中添加自定义函数
function custom_excerpt_length($length) {
return 20;
}
add_filter(‘excerpt_length’, ‘custom_excerpt_length’);
// 在header.php中添加自定义样式
“`
2. 使用插件
WordPress插件可以帮助我们实现自定义结构的功能。以下是一些常用的插件:
* Customizr:提供丰富的自定义选项,包括布局、颜色、字体等。
* Jetpack:集成了多种功能,如自定义菜单、自定义字体等。
* Advanced Custom Fields (ACF):提供自定义字段,方便我们添加各种内容。
示例:
“`php
// 在Customizr插件中设置自定义布局
Customizr_Customize::add_customizer_section(‘custom_layout’, array(
‘title’ => ‘自定义布局’,
‘priority’ => 10,
‘description’ => ‘在这里设置自定义布局’,
));
“`
3. 编写自定义主题
如果对WordPress有一定了解,可以尝试编写自己的主题。编写自定义主题需要掌握HTML、CSS、PHP等技能。
示例:
“`php
/*
Theme Name: My Custom Theme
Description: 一个自定义主题
Template: bootstrap
*/
“`
三、自定义结构注意事项
1. 兼容性:确保自定义结构在不同设备和浏览器上都能正常显示。
2. 性能:避免使用过多的CSS和JavaScript,以免影响网站加载速度。
3. SEO:遵循搜索引擎优化原则,提高网站排名。
WordPress自定义结构是打造个性化网站的关键。通过修改主题文件、使用插件和编写自定义主题等方法,我们可以实现各种功能。在自定义结构的过程中,需要注意兼容性、性能和SEO等方面,确保网站稳定、快速地运行。希望本文能为大家提供一些参考和帮助。
方法 | 优点 | 缺点 |
---|---|---|
修改主题文件 | 操作简单,易于理解 | 修改量大,需要一定的技术基础 |
使用插件 | 功能丰富,易于上手 | 可能存在兼容性问题 |
编写自定义主题 | 个性化强,性能优越 | 技术门槛较高,需要一定时间 |
以上就是关于WordPress自定义结构的相关知识,希望对大家有所帮助。在打造个性化网站的过程中,不断尝试和优化,相信你一定能打造出属于自己的完美网站。
如何在wordpress 3.0中使用自定义分类法
WordPress 3.0五大新特征是WordPress为了迈向一个成功的内容管理系统努力的印证。之前,我们向大家介绍过WordPress3.0的新功能,自定义发布内容的类型,这篇文章将继续给大家讲一下WordPress3.0另一个比较突出的新功能,自定义分类法。什么是自定义分类法函数,它的实用性表现在哪里?究竟该如何使用?请看下面的教程:
什么是自定义分类法函数?
分类法函数顾名思义就是使用不同的方法来对事物进行分类的函数。大家都知道按照不同的分类标准,对某种事物的分类就会大相径庭,本教程将以台式电脑为例,依据下面完全不同的标准来分其结果就不一样:
随机存储的容量
硬盘驱动器的大小
CPU速度
CPU类型
安装的操作系统
等等
WordPress分类法函数历史简介
类别分类
WordPress2.3之前的版本只有一个最为普通的分类法函数,
叫做文章的“类别(Category)”。这个对于博客来说也还算过得去,因为你可以创建一个顶层分类“台式电脑”,一个子分类“RAM,”它同样也可以
有子子分类:“小于1 GB,”“1 GB,”“2 GB到4GB,”
等等。“台式电脑”下也可以创建一个叫做“操作系统的”第二个子分类,它下面的子子分类为“Windows XP,”“Mac OS,”“Red
Hat,”“Ubuntu,”等等。
当某种系统允许你将分类进行再次分为各种子分类,我们称之为层级结构。在WordPress2.3之前的系统里,你所能做到最好的就是创建一个庞大的分类层级,其中最高层代表最大的分类组。
标签分类法
WordPress2.3又增加了一种分类法,叫做标签,之前的分类通常都是事先想好了,具体到网站上内容的分类,而标签显得更加自由,可以说是一种即兴分类内容的方法。
举个例子,在写一篇关于某个台式电脑的文章时,标签允许制作输入一个或多个关键词,如“游戏”、“tivo功能”
、“嘈杂风扇”等等。像这些关键词可能并不适合于运用于整个网站内容的分类中,但是对某篇文章来说却是提供了另一种分类。网站访客以后就可以非常轻松找到
所有标记为“tivo功能”的文章。不过,标签的自由性却无法帮助我们创建一个固定的依据如操作系统、CPU类型值而做出的分类系统。因为标签是一维的,
不容许任何层级结构。
单级自定义分类法
WordPress2.8下,通过稍微修改网站的代码你可以添加自定义分类方案。这样你可以创建一个包含所有“操作系统”的文章列表,并与另一个包含所有
“随机存储器”的文章列表单独分开,当然还可以创建其他类似的列表。不过,它却无法像常见的“类别”分类法拥有内在的层级结构。
完全层次自定义分类法
最后,WordPress3上才可以拥有完全层级的自定义分类法。你将会发现这个完全层级自定义分类是多么强大,就拿操作系统来说,你可以将所有不同的
Windows变种放置到Windows父类别下。这样用户选择Windows操作系统的时候就可以看到所有相关的文章,而如果他们想只查找
Windows xp电脑相关的信息就可以选择Windows XP下的文章。
创建一个自定义分类法
编辑主题functions.php文件
WordPress3无法在管理后台创建自定义的分类法。如果不使用插件初次定义一个自定义分类法时,你将需要在主题 functions.php文件里添加点代码,其实也不难,跟着下面的指示就可以了。
在主题目录里找到“functions.php”文件,假设你使用的是WordPress3.0的默认主题“twentyten”,WordPress是安装在一个叫做“wp.”的目录下,那么functions.php文件的路径就是:
[website_root]/wp/wp-content/themes/twentyten/functions.php.
在代码中添加分类法
仍然以台式电脑为例,我们需要单独添加“随机存储器”、“硬盘驱动器”和“操作系统”这样的分类。在这里,仅仅是添加了分类法本身,也就是说设定完之后它们就像是一个“空的容器”,而你需要通过管理面板那命名管理不同分类,如“Windows XP”。
步骤一:使用一个函数创建所有的分类
首先,需要创建一个函数来创建所有需要的分类。这个函数叫做“build_taxonomies”,在functions.php文件的底端添加这个函数:
function build_taxonomies(){//定义分类法的代码将写在这里}
步骤二:定义分类法
接着,对于每个需要创建的分类法,我们需要启用某个WordPress函数以及正确的参数。下面就是该函数以及它相关的重要参数的解释。
register_taxonomy('internal_name','object_type', array('hierarchical'=>
{true|false},'label'=>'Human Readable Name','query_var'=>
{true|false},'rewrite'=>{true|false}));
internal_name:在WordPress内部,数据库和模板文件中这个分类法究竟该怎么称呼就是靠这个函数来实现的。
object_type:什么类型的内容才可以用这个分类法进行分了呢?可能的值有:“文章(post),页面(page)以及链接(link)”。
接着就是一组可选择的参数。本教程就使用最为重要的几个参数,其他参数大家也可以在官方的引用函数/ register_taxonomy Codex页面上找到。我们将使用到的参数有:
hierarchical:如果设置为”true”的话,意味着此分类法拥有的层级功能,就像WordPress“类别”的分类一样。反之,如果设置为‘false’,那么它就会像标签一样灵活没有分层的制约。
label:这是一个对用户可见的用户标记此分类法的一个标记。
query_var:如果设置为‘true’,那么选择该分类法后,我们可以要求WordPress为我们选择相关的文章,例如,依据操作系统分类法,如果选择“Windows”,WordPress系统就会为你列出所有Windows下的文章。
rewrite:如果设置为‘true’,在浏览一个页面时,WordPress将会使用友好的URL地址。例如,选择Windows操作系统之后列出的文章列表页面的URL地址将会是这样的:
添加操作系统分类法的代码如下:
register_taxonomy('operating_system','post', array('hierarchical'=> true,
'label'=>'Operating System','query_var'=> true,'rewrite'=> true));
请在前面提到的“build_taxonomies”函数里添加上面的代码。
更多信息:
参阅这里
第三步:调用Taxonomy-Creating函数
我们还需要在“functions.php”文件里添加几行代码,这样“build_taxonomies”函数才可以真正执行,
add_action('init','build_taxonomies', 0);
你可以在任何地方加这个代码,不过通常还是写在需要调用的函数前面比较好,代码就变成这样了:
//自定义分类法代码add_action('init','build_taxonomies', 0);
function build_taxonomies(){ register_taxonomy
('operating_system','post', array('hierarchical'=> true,'label'=>
'Operating System','query_var'=> true,'rewrite'=> true));}
给新的分类法添加类别
正确在“functions.php”添加了“操作系统”这个分类法之后,在管理后台的“文章”选项就应该会出现一个新的“操作系统”分类条目,点击该分类法名称,你就可以添加编辑所需要的类别。
像上图所示添加完所需的类别之后,你就可以像常见的文章分类目录一样对操作系统这个分类进行编辑。
添加更多分类法
如果你需要添加“随机存储器”和“硬盘驱动器”分类法,只要按照上面“操作系统”的例子做,并在functions.php文件加入下面的代码:
register_taxonomy('ram','post', array('hierarchical'=> true,
'label'=>'RAM','query_var'=> true,'rewrite'=> true));
register_taxonomy('hard_drive','post', array('hierarchical'=> true,
'label'=>'Hard Drive','query_var'=> true,'rewrite'=> true));
完成之后,functions.php文件里的代码应该像下面这样:
//自定义分类法代码 add_action('init','build_taxonomies', 0);
function build_taxonomies(){ register_taxonomy('operating_system','post',
array('hierarchical'=> true,'label'=>'Operating System','query_var'=> true,
'rewrite'=> true)); register_taxonomy('ram','post', array('hierarchical'=> true,
'label'=>'RAM','query_var'=> true,'rewrite'=> true));
register_taxonomy('hard_drive','post', array('hierarchical'=> true,
'label'=>'Hard Drive','query_var'=> true,'rewrite'=> true));}
使用新的分类法发布文章
在创建一篇新的文章时,你就会发现在编辑文章的页面会出现新的分类法选项,你就可以旋转任何你需要使用到的分类。
显示文章的不同分类法
到目前为止所做的一切对于网站的访客来说并没有太大的改善。我们希望能够显示某篇文章依据某种分类法所归属的类别,就像文章的类别和标签那样显示出来。
为了实现这点,我们还需要做一点点改善。
在各个分类法的页面显示它们下面的类别
在twentyten以及其他很多主题中,在一篇文章的文本下方会显示该文章所属的类别和标签。所以,下面我们打算如果某篇文章有使用了自定义的分类法对它进行分类的话,那么就在类别和标签的前面加上依据自定义分类法它所归属的分类。
为了实现这一点,我们需要对“single.php”模板文件进行一点修改,通常显示单篇文章都需要调用这个模板文件。single.php文件的路径
是: [website_root]/wp/wp-content/themes/twentyten/single.php.
第一步:找到添加代码的地方
打开single.php文件,找到下面这行代码:
<div class=”entry-utility”>
它的前面是:
<div id=”nav-below”>
In twentyten主题里面,div里包含了当前文章的所属类别、标签、永久链接以及其他数据。我们将在这个div的前面添加自定义分类的信息。
第二步:获取当前文章的分类法信息
Populate some variables for holding the taxonomy information output and
the different taxonomy information we may expect to find.
<?php//如果有自定义分类法信息就显示
//创建输出的内容$taxo_text=””;
//变量来存储所有可能的分类法列表
//检查“操作系统”这个类别
$os_list= get_the_term_list($post->ID,'operating_system','
<strong>Operating System(s):</strong>',',','');
在这里,需要调用WordPress函数“get_the_term”以及下面的参数:
$post->ID:当前文章的ID
‘operating_system’:我们的目标自定义分类,通过它来查询当前文章是否有被定义为“操作系统”分类法下的任何类别。
‘Operating System(s)’:如果得到数值返回,我们需要在它的前面加上这个字符串。
‘,‘:如果返回多个数值,我们需要用这个符号来分隔开来。
”:如果没有返回任何数值,我们希望在后面加上这个字符串。这样,结果后面就不需要添加任何东西。
同样地我们可以对其他两个分类法进行处理:
$ram_list= get_the_term_list($post->ID,'ram','<strong>RAM Option(s):
</strong>',',','');$hd_list= get_the_term_list($post->ID,'hard_drive','
<strong>Hard Drive Option(s):</strong>',',','');
更多信息:
参阅这里
第三步:对类别的结果进行格式化(如果有)
先查询是否有这三个分类法下的类别。如果有的话,将这些类别信息以及字符串添加到输出结果中输出。
// Add OS list if this post was so tagged if(''!=$os_list)
{$taxo_text.=”$os_list<br/>\n”;}
// Add RAM list if this post was so tagged if(''!=$ram_list)
{$taxo_text.=”$ram_list<br/>\n”;}
// Add HD list if this post was so tagged if(''!=$hd_list)
{$taxo_text.=”$hd_list<br/>\n”;}
第四步:显示类别结果(如果有)
检查经过以上步骤是否会有分类法信息需要输出。如果分类法信息存在,我们将会通过类别div来输出结果。
// Output taxonomy information if there was any
// NOTE: We won't even open a div if there's nothing to put inside it.
if(''!=$taxo_text){?><div class=”entry-utility”>
<?php echo$taxo_text;?></div><?}// endif?>
第五步:检查结果
查看文章,你将会发现所有的自定义分类法下的类别都会在文章的下方显示。
通过自定义分类法的类别浏览文章列表
通过上面的几个操作,现在每篇文章如果它们有被分类到哪个自定义分类法下的某个类别,那么相关的类别都会显示出来了。并且列出自定义分类法的类别的同时还
会有一个链接能将你转到到某个类别下的所有文章列表页面。例如,点击操作系统分类法旁边的“Mac OS”链接,理论上所有的“Mac
OS”类别的所有文章列表都将会呈现在你的眼前。
但是,在WordPress3.0中并没有像理论那样完美,我们还需要制作一个自定义的模板文件才能让文法归档成为可能。在WordPress中,读者已
经可以对指定某个 category和某个标签的所有文章进行浏览,当然我们也希望读者能够将所有自定义分类法下某个类别的文章也都能全部一览无余。
为了实现这一点,我们需要创建一个叫做“taxonomy.php”的模板文件,当需要列出自定义分类法下面某个类别的文章时,可以随时使用这个文件。
第一步:
打开“category.php”模板文件,复制它的内容并将这些内容粘贴到一个新创建的命名为“taxonomy.php”的文件中,保存这个taxonomy.php到主题目录下:
[website_root]/wp/wp-content/themes/twentyten/taxonomy.php.
第二步:获取当前分类法类别的相关信息
我们需要在taxonomy.php文件里能够获取被列出的分类法相关的信息。可能需要知道分类法下某个类别的名称以及描述。
只要在<?php get_header();?>下方,添加下面的代码:
$term= get_term_by('slug', get_query_var('term'),
get_query_var('taxonomy'));
第三步:显示类别名称和描述
有必要将页面的名称做些修改让访客知道他们在看的是什么样的内容。由于我们最开始也是从category.php模板文件着手的,我们可以将用与打印分类名称的代码做些修改,就可以显示我们需要的页面名称,甚至是描述。
从category.php文件中修改下面的代码:
printf( __('Category Archives:%s','twentyten'),'<span>'.
single_cat_title('', false).'</span>');
将其改成:
printf( __('Posts classified under:%s','twentyten'),
'<span>'.$term_name.'</span>');
这就修改了刚开始的静态文字,然后插入类别的名称。
添加下面的代码:
if(''!=$term_descr){ echo”<p>$term_descr</p>\n”;}
如果这个类别有描述,那么就会在标题的下方显示描述内容。
再完成对taxonomy.php的修改之后,访问下某篇授予某一个自定义分类法下的某个类别的文章,你将会看到文本的下方会有自定义类别显示,只要点击这些类别你就可以看到此类别的文章列表了。
如何自定义wordpress文章的固定链接
WordPress是一款开源网站建设程序,因其强大的功能和可扩展性而大受欢迎。关于WordPress扩展,主要是其插件众多,可以使用不同功能插件来扩展网站需求。WordPress所有固有的内容类型非常有限,毕竟其开始是以博客系统为基础的。对于像企业站需要的产品类型,电影站需要的国家属性等,显示不便。现在推荐一款自定义内容类型/字段分类法插件–Pods可以扩展你所需要的内容类型。
pods是一款用在 WordPress上的自定义内容类型的插件,但是 pods拥有的功能却完全不限于此。pods能够扩展现有的内容类型,比如为用户资料(user)增加一个“电话”字段。此外,它还有权限管理功能,类似于“members”插件。此外,还有高级自定义内容类型,改变“标题”这个字段名称。再此外,它还有内容关系的功能。
这篇文章我们除了介绍 pods的使用方法以外,还会介绍内容类型的列表页,内容页的制作,pods字段的前台模板调用,增加内容类型到菜单等等。
扩展已有
WordPress默认有三大内容类型:文章(posts)、页面(page)、媒体(attachment),可能“用户(user)”也算一个内容类型,因为“用户”也可以扩展。默认的分类法有:分类目录(category)、标签(tag)。默认的内容类型和分类法在项目中字段经常不够用。
扩展文章字段
1、安装好 pods后,点击“pods管理-添加”,点击“扩展已有”、选择“内容类型(文章、页面,等等)”,下方选择“文章”,点击“下一步”。
2、点击“添加字段”,比如添加一个“文章来源”的文本类型的字段,这里有几个选框。
代表的含义为:
标签:显示在发布时候的名称,可以为中文。
名称:内部使用,存在数据库里的名称,可用于模板调用,只能为字母、数字、下划线,不能以数字开头。
描述:发布时对字段的简要说明,选填。
字段类型:字段的类型,如,文本框、文本区域、文件等等。
选项:该字段是否为必填。
3、点击“添加字段”,完成添加,点击“Save Pod”保存添加。
这个时候去发布文章看看,在下方就多了个文章来源字段了。快点去用同样的方法可以为页面、媒体、用户、评论添加自定义字段吧。
创建新的
创建新的内容类型
进入到 pods的添加界面,选择“创建新的”,接下来选择“自定义内容类型”。
标签填写内容类型名称,可以为中文,比如填写个“电影”,点击下面的“高级”,在 pod name填写内容类型的机读名称,点击“下一步”,完成一个自定义内容类型的创建,你可以在左边栏找到“电影”这个内容类型。
为自定义内容类型添加字段。新创建的自定义内容类型,默认拥有“文章”这个内容类型的所有字段,比如标题、内容、日期等等,我们是在这些基础上添加新的需要的字段,比如现在添加一些字段:海报、地区、时长、年份等等。再去发布“电影”,你会发现下方多了刚刚添加的这些字段。
创建好自定义内容类型后,你会发现还有很多标签页:“管理字段”、标签、管理界面、高级选项。
标签:在后台显示的标签,根据需要修改。
管理界面:管理内容类型在后台的显示,尝试把菜单位置改为更大的值试试看。
高级选项:对自定义内容类型的设置,请把“拥有归档”勾上。
创建自定义分类法
打开 pods的添加界面,选择“创建新的”,接下来选择“自定义分类法”。
标签填写分类法名称,可以中文,比如填写“电影类型”,点击下面的“高级”,在 pod name填写分类法的机读名称,点击“下一步”,完成一个自定义分类法的创建。
创建完成以后,有几个标签页,主要关注以下几个:
高级选项中,“层级”,表示该分类法是否有层级关系,打上勾相当于“分类目录”分类法,不打钩相当于“标签”分类法,我建议打上勾。“相关内容类型”,为这个分类法应用到哪一个内容类型,比如我这里,勾上了“电影”。我在发布电影的时候,在右边栏就可以有电影类型选择了。
其他字段:这是为自定义分类法添加字段,这个按照需要开启,比如你想为电影类型中的科幻片分类添加一个略缩图字段等等。
创建自定义设置页面—制作主题选项
有没有觉得做主题的时候,为主题添加选项比较麻烦,pods有个超简单的方法,使用自定义设置页面轻松搞定。
打开 pods的添加界面,选择“创建新的”,接下来选择“自定义设置页面”,标签填写页面名称,可以使用中文,比如填写“主题选项”,菜单位置由自己选:在设置菜单、外观菜单下,新菜单,我这里选择添加到外观菜单。点击下面的“高级”,在 pod name填写自定义设置页面的机读名称,点击“下一步”,这样就完成了一个自定义页面的创建。
创建完成以后,可以去添加一些字段,比如我添加了:网站 logo、网站标题、网站关键字、网站描述、统计代码、网站备案号字段,要注意字段类型。
接下来保存后看看你的左边栏对应的菜单位置吧。
好了,pods的基础功能就这么一些,这些功能网上很多插件都能实现,其实更重要的内容,还在于他的组件,pods的组件给 pods扩充了非常多的功能,这才是 pods真正的强大之处。
pods组件
高级自定义内容类型
进入“pods管理-组件”,启用“Advance Content Type”。
这个时候,到 pods的添加页面,多了一项“高级内容类型”,选择它,这里我重新建立一个电影内容类型。点击“下一步”完成创建。
创建完成之后,会发现默认有了一些字段,这就是 WordPress默认的字段,你可以修改或者删除它。
编辑好字段以后,再去看看其他标签页。下面主要介绍重要的设置:
“管理界面”的“管理界面样式”,可以自己写个 WordPress管理后台页面。
“高级选项”的“标题字段”,如果修改了标题字段,或者想要改变标题字段,请在这里选择。
高级内容关系
进入“pods管理-组件”,启用“Advance Relationships”,这个时候在添加内容关系字段以后,你可以看到多了几行,这些高级的内容关系,可以创建更加复杂的内容关系。
权限与角色管理
进入“pods管理-组件”,启用“Roles and Capabilities”,如果你用过 members插件,你会发现这功能和 members功能很相似,一样的强大。可以对所有的权限分角色的管理,可以添加、编辑、删除用户角色。
更多组件
pods管理后台还有其他实用的组件,更多的组件功能,不一一介绍,看组件名字大概能清楚他的功能。pods官方有提供其他组件,一些是单独的插件,一些是配合 pods工作的组件。
前端调用
模板命名
我发现,虽然很多人都会用自定义内容类型,但是内容类型的列表页不好做,即使做好,又该怎么放到菜单上显示出来,比如将“电影”列表页放在菜单中,自定义内容类型绑定了一个自定义分类法,又该怎么去显示分类法中某个分类下的文章,比如“科幻片”这个电影分类。
模板命名规则:
自定义内容类型模板命名规则:archive-{post_type_name}.php如 archive-movies.php
自定义分类法模板命名规则:taxonomy-{taxonomy_name}.php如 taxonomy-movie_type.php
自定义内容类型内容页模板命名规则:single-{post_type_name}.php如 single-movies.php
将内容类型加入到菜单,需要安装一个插件“Custom Post Type's Archive in WP Nav Menu”,安装好之后,没有任何设置界面,进入到“外观-菜单”,你可以发现菜单编辑区域的左边有了一个custom post type archives,现在内容类型就在这里了,如果你发现内容类型不在这,那就请到 pods的内容类型管理界面的高级选项中确认你的“拥有存档”这个选项已经打上勾了。
注:可能由于缓存问题,如果发现添加了内容类型到菜单后,前台点击内容类型的菜单出现404页面,请到“设置-固定链接”,点击一下保存即可。
数据调用
后台配置好,其实最主要的,还是要能够显示出来才是最重要的,pods的显示方法有三种:
短代码方式显示,短代码请参考 pods短代码文档,配合 pods官方提供的 magic tags。
利用 pods的“page”和“template”组件,这两个组件可在 pods组件中开启,请参考文章。
利用模板函数,即将重点介绍。
这里只介绍模板函数方式调用 pods数据,因为这才是做主题开发时能使用的东西。
输出函数
Pods显示数据函数
pods_field_display($pod,$post->ID,'$field)
关于该函数的文档,请查看 pods官方文档。
function pods_field_display($pod,$id= false,$name= null,$single= false)
参数数据类型备注
$pod(string) Pod name,即为 pods机读名称
$id(mixed)(选填)某篇文章ID或slug,以查询该篇文章数据
$name(string|array)字段名称,或者关联数组的参数
$single(boolean)(选填)是否以数组的形式返回
图像字段输出函数
pods_field_display()不会真正的显示出一张图片,而是显示出图片的 URL,pods特地为图片显示定义了一个函数:
pods_image($image,$size='thumbnail',$default= 0,$attributes='',$force= false)
关于该函数文档,请查看官方文档。
function pods_image($image,$size='thumbnail',$default= 0,$attributes='',$force= false)
参数数据类型备注
$image(array|int|string)图片字段的数组,或ID,或guid
$size(string|array)图片大小样式
$default(int)如果图片不存在,则显示该图片$default
$attributes(string|array)图片属性(内部通过 wp_get_attachment_image获取)
$force(boolean)强制规定大小
图片有单张图片和多张图片,如不清楚单张与多张,请到 pods添加字段查看。如果字段是多张图片,那么会返回一个数组,所以,输出图像字段的代码为:
单张图片字段示例代码:
<?php
echo pods_image( get_post_meta($post->ID,$image_field_name, true),’original’);
?>
多张图片字段:
<?php
$images=get_post_meta($post->ID,’images’);
foreach($images as$image)
{
echo pods_image($image,’original’);
}
?>
输出字段注意事项:
yes/no字段:后台勾选“是”输出 1,不勾选输出空值。
Code字段:可执行 php脚本代码,输出 php代码执行结果。
Website字段:本人无法输出该字段内容,请勿使用。
因为 pods自定义字段也属于 WordPress内部自定义字段,所以依然可以使用 WordPress的 get_post_meta()输出,但是也并不是所有字段都能输出,经过测试,可直接使用 get_post_meta()函数输出的字段有:
Phone
Password
Pptext
Date time
Pnumber
Currency
Color
对于其他字段,请使用 pods_field_display();
模板代码段示例
在主循环中
代码示例:
<?php if(have_posts()):while(have_posts()): the_post();?>
<h1>
<a href=””>
<?php the_title();?>
</a>
</h1>
<!–标题–>
<div>
<div>
<span>年份:</span>
<?php echo pods_field_display('movie',$post->ID,'time');//显示(年份)time字段?>
</div>
<div>
<span>区域:</span>
<?php echo pods_field_display('movie',$post->ID,'zone');//显示(区域)zone字段?>
</div>
<div>
<span>时长:</span>
<?php echo pods_field_display('movie',$post->ID,'how_long');//显示(时长)how_long字段?>
<span>分钟</span>
</div>
<div>
<span>海报:</span>
<?php echo pods_image( get_post_meta($post->ID,'poster', true),'original');//显示海报字段?>
</div>
</div>
<!–显示自定义字段–>
<div>
<?php the_excerpt();?>
</div>
<!–内容摘要–>
<?php endwhile;endif;?>
万能循环示例代码
<?php query_posts('showposts=5&post_type=movie');while(have_posts()): the_post();?>
<h1>
<a href=””>
<?php the_title();?>
</a>
</h1>
<!–标题–>
<div>
<div>
<span>年份:</span>
<?php echo pods_field_display('movie',$post->ID,'time');//显示(年份)time字段?>
</div>
<div>
<span>区域:</span>
<?php echo pods_field_display('movie',$post->ID,'zone');//显示(区域)zone字段?>
</div>
<div>
<span>时长:</span>
<?php echo pods_field_display('movie',$post->ID,'how_long');//显示(时长)how_long字段?>
<span>分钟</span>
</div>
<div>
<span>海报:</span>
<?php echo pods_image( get_post_meta($post->ID,'poster', true),'original');//显示海报字段?>
</div>
</div>
<!–显示自定义字段–>
<div>
<?php the_excerpt();?>
</div>
<!–内容摘要–>
<?php endwhile;wp_reset_query();?>
自定义设置页面(调用主题选项数据)
请注意$id参数为 pods-settings-{slug_name},比如我的 pods name为 theme_option,那么$id的实参应该为'pods-settings-theme_option'。
<?php echo pods_field_display('theme_option','pods-settings-theme_option','site_logo');?>
<?php echo pods_field_display('theme_option','pods-settings-theme_option','site_title');?>
<?php echo pods_field_display('theme_option','pods-settings-theme_option','site_keyword');?>
<?php echo pods_field_display('theme_option','pods-settings-theme_option','site_description');?>
<?php echo pods_field_display('theme_option','pods-settings-theme_option','site_tongji');?>
<?php echo pods_field_display('theme_option','pods-settings-theme_option','site_beian');?>
如何自定义WordPress的登录页面
方法如下:
1.设计一个引人注目的登录标志
默认的WordPress登录标志由尺寸为80*80的“WordPress”字符组成。现在需要用设计的标志来代替默认的,应该事先将一个存储格式为.png的标志图像保存到“登录”文件夹中,注意图片尺寸可以和默认的一样也可以自定义。然后要在functiond.php文件的底部加上如下代码:
标志应该具有较强吸引力和较高的清晰度。此外,它最好和网站相关并且能告诉用户网站是一个怎样的网站。
2.改变标志图像的URL
如果想要改变标志图像URL并让它不再链接到WordPress主页,可以采取如下操作。需要使用如下示例代码去更换网站URL。
也可以通过对上面的代码做一个小的改动来更改标题标签,具体代码如下:
3.定制一个独特的样式表
完成图像标志定制之后,你需要进行样式表的定制。首先,要创建一个login_stlye.css文件然后在一个喜欢的编辑器中打开它。现在在新建的文件中加入如下代码。
这些代码能够帮助定制背景图片的尺寸和颜色,登录标签和登录表单。里面包含的参数仅供参考,可以根据自己的需要进行更改。
事实上,为了让改动生效,还要把下面的代码添加到functions.php文件中.
使用插件
使用代码来定制一个令人满意的登录页面是一种比较刻板的方法。有的人可能会觉得这样比较麻烦也不想花费心思去做。这种情况的话,一些WordPress插件可能会帮上你的忙,例如Custom Login, A5 Custom Login Page和 MS Custom Login。接下来我们就给大家仔细介绍一下这三种插件。
Custom Login用于登录屏幕定制,用户Hask密钥登录、邮件用户名登录和两步认证。这款插件已经被评为最受欢迎的用来自定义WordPress登录页面的插件之一。
A5 Custom Login Page提供给想要把登录页面设计到最好的用户。这款插件能够帮助设计引人注意的标志和你想要的页面风格。此外,这款插件的开发者允许用户在插件上复制粘贴整个样式表。
MS Custom Login能够帮助设计登录标志,背景图片,登录按钮的颜色等等。更重的是通过它你也可以使用一系列的登录表单尺寸。