打开APP
userphoto
未登录

开通VIP,畅享免费电子书等14项超值服

开通VIP
WordPress自定义栏目的使用
前言
最近有个任务,要实现在公司官网上点击某个商品的购买按钮,就跳转到对应的淘宝店页面去。由于公司官网用的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>
最后在页面上点击测试一下,跳转正确,任务完毕
本站仅提供存储服务,所有内容均由用户发布,如发现有害或侵权内容,请点击举报
打开APP,阅读全文并永久保存 查看更多类似文章
猜你喜欢
类似文章
首页幻灯片中图片无法显示的解决办法
WordPress 添加自定义栏目面板
WordPress 自定义字段 自定义域的使用方法
WordPress 技巧:给每个页面都设置不同的菜单
WordPress添加支付宝功能
WordPress模板标签之query posts
更多类似文章 >>
生活服务
热点新闻
分享 收藏 导长图 关注 下载文章
绑定账号成功
后续可登录账号畅享VIP特权!
如果VIP功能使用有故障,
可点击这里联系客服!

联系客服