美文网首页
WordPress自定义栏目的使用

WordPress自定义栏目的使用

作者: zhongzilu | 来源:发表于2016-04-16 13:43 被阅读4926次

    前言
    最近有个任务,要实现在公司官网上点击某个商品的购买按钮,就跳转到对应的淘宝店页面去。由于公司官网用的WordPress平台,我之前只是听说过,并没有实质性使用过,所以一开始就是一头雾水,再加上网站原本是由外包公司做的,交接时没有任何文档,因此我根本不知如何下手,但最后还是硬着头皮去做了。

    我思考着要完成这个任务我需要怎么做,由于网站上的内容都是动态从数据库中取的,所以如果我要实现点击购买按钮就跳转到对应网店的功能,就不可能在代码中把跳转的店铺地址写死了,必须要从数据库中去读取,并且还要和商品关联起来才行。

    这其中肯定涉及到把链接地址写入数据库,WordPress提供了一个管理后台,通过管理后台可以把数据写入数据库。

    打开后台,找到文章编辑页面,在右上方有个显示选项,展开后可以显示和隐藏模块。勾选自定义栏目

    显示选项
    在页面下方可以看到这个模块,在这里可以新增自定义的数据字段,并给它赋值。
    自定义栏目
    拿我的任务来举例,我点击购买按钮之后跳转到对应的商品淘宝店,所以商品淘宝店的地址就需要写入数据库,所以现在新增一个自定义字段,点击输入新栏目
    添加自定义栏目
    输入自定义名称和值,输入完成后点击添加自定义栏目
    添加自定义栏目
    添加完之后就是如下图所示
    添加自定义栏目成功
    自定义栏目添加成功了,那么问题来了,我们如何取到自定义栏目的值并显示在页面上呢?

    在WordPress中有个get_post_meta()的函数,官方的解释是:

    This function returns the values of the custom fields with the specified key from the specified post.

    翻译过来大概的意思是:该函数用于取出用户设置的自定义字段的值。

    用途

    该函数的用处很多,很多主题用来设置文章相应图片的设置,这与将远程图像设置为缩略图有异曲同工之妙,当然自定义字段还可以用于存储许多我们觉得更有用的东西,例如统计信息,等等。

    用法

    <?php $meta_values = get_post_meta($post_id, $key, $single); ?>```
    
    **参数解释**
    > `$post_id`文章的ID(如果在循环中,你可以用 get_the_ID()来设置),
    > `$key`自定义字段的名称(键值),
    > `$single`是否以字符串形式返回,false会返回数组形式。
    
    **缺省用法**
    

    <?php $value = get_post_meta(76, 'key'); ?>```

    实例

    if (have_posts()) ://如果有文章 
    while (have_posts()) : the_post(); //开启主循环 
    $value = get_post_meta(get_the_ID(),'custom_meta',true);
     endwhile;  
    endif;
    

    上面介绍完get_post_meta()函数,现在我们就来实现我的这个任务。
    在项目源代码中找到使用的主题的文件夹,我的文件夹位置为:htdocs/wp-content/themes/jitatheme/
    再找到function.php文件并打开,在这里我们将封装成一个获取地址的函数,代码如下:

    /***获取淘宝店铺商品的地址*/
    function getTB_Url($postID){ 
      $key = 'direct_to_tb'; 
      $url = get_post_meta($postID, $key, true); 
      return $url;
    }
    

    然后找到我们要修改的页面,用一个<a>标签来实现点击跳转。我们在<a>标签的href属性中来调用刚才封装的函数,代码如下:

    <a class="btn" href="<?php echo getTB_Url(get_the_ID()); ?>" target="_blank">点击购买</a>
    

    最后在页面上点击测试一下,跳转正确,任务完毕。

    总结

    • 了解了如何在WordPress后台管理界面添加自定义栏目
    • 了解了如何获取自定义栏目的值和get_post_meta()函数的使用

    相关文章

      网友评论

          本文标题:WordPress自定义栏目的使用

          本文链接:https://www.haomeiwen.com/subject/jjvjlttx.html