如何在Wordpress中创建添加以进行比较
How to create add to compare in Wordpress?
我不想使用任何插件。我尝试使用 cookie 创建比较页面,但仍然遇到问题。任何人都可以让我知道如何在wordpress中创建比较产品吗?
使用循环,我得到以下输出,其中我添加了"添加到比较"链接或按钮
<table>
<tr>
<td> Product ID</td>
<td>Product Name</td>
<td><a href="#">Add To Compare</a></td>
</tr>
<tr>
<td> 123</td>
<td>P-one</td>
<td><a href="#">Add To Compare</a></td>
</tr>
<tr>
<td>234</td>
<td>P-2</td>
<td><a href="#">Add To Compare</a></td>
</tr>
<tr>
<td>345</td>
<td>P-3</td>
<td><a href="#">Add To Compare</a></td>
</tr>
<tr>
<td>456</td>
<td>P-4</td>
<td><a href="#">Add To Compare</a></td>
</tr>
</table>
我的逻辑不清楚。我不知道我应该怎么做才能构建添加以比较产品页面。但是我尝试以下步骤来创建比较产品页面:
我创建了两种自定义帖子类型:
- 主营产品
- 子产品
主要产品 是子产品的父帖子。这意味着子产品是主要产品的子产品。
主要产品是品牌的帖子,子产品是我们添加产品及其与这些品牌相关的详细信息的帖子。
我有一个叫BARADA(假设:P)的品牌,他们的产品是:
- 巴拉塔·庞
- 巴拉塔·
- 巴拉塔·普三
- 巴拉塔·普福尔
它们都具有相同的规格,例如宽度,长度,高度。
在主产品自定义模板中,我添加了此循环以从子产品获取其子帖子
<table>
<thead>
<tr>
<th><h4>Product Name</h4></th>
<th><h4>Any Info</h4></th>
<th><h4>Select to Compare</h4></th>
</tr>
</thead>
<tbody>
<?php
$childargs = array(
'orderby' => 'post_title',
'order' => 'ASC',
);
$compi = 1;
$child_posts = types_child_posts("subproducts",$childargs);
foreach ($child_posts as $child_post) {
$variid = $child_post->ID;
$variname = "compareid".$compi++;
?>
<tr>
<td><?php echo $child_post->post_title; ?></td>
<td><?php echo get_post_meta($child_post->ID, 'any-info-cutomfield', TRUE); ?></td>
<th><a href="" onclick="setting_my_first_cookie('<?php echo $variid; ?>','<?php echo $variname; ?>')">Compare</a>
<a href="" onclick="setting_my_first_cookie_delete('<?php echo $variid; ?>','<?php echo $variname; ?>')">Remove</a>
</th>
</tr>
</tbody>
<?php
// Accessing an individual cookie value
echo $_COOKIE[$variid];
echo $_COOKIE[$variname];
?>
<?php
}
?>
上面的代码获取主页的子产品,并在表格中显示它们,并带有 Add 以比较 buton。 在$variid
中,我存储了子产品的ID和它们的名称$variname
。
使用 Onclick,我将这些数据发送到 javascript 函数以创建 cookie。
Javascript:
<script type="text/javascript">
function setting_my_first_cookie(variid,variname) {
var d = new Date();
d.setTime(d.getTime() + (30*24*60*60*1000));
var expires = "expires="+d.toUTCString();
document.cookie = variname + "=" + variid + "; " + "expires; path=/; domain=.domain.com";
}
</script>
<script type="text/javascript">
function setting_my_first_cookie_delete(variid,variname) {
document.cookie = variname + '=; expires=Thu, 01 Jan 1970 00:00:01 GMT; path=/; domain=.domain.com';
}
</script>
在比较页面上,我可以检索这些数据以显示这些产品的比较。 但是存在一些问题。就像我不知道如何为要比较的产品添加限制一样。
你能给我逻辑来添加要比较的产品吗?其他人实际上是怎么做到的?我该怎么做?请引导我走向正确的方向。
您可以使用 $_SESSION,这可能是处理逻辑的更简洁的方式。 添加/删除项目的函数如下(未经测试的代码):
$_SESSION['barata_products'] = [];
function add_products(varid) {
array_push($_SESSION['barata_products'],varid);
}
function remove_product(varid) {
$product_index = array_search(varid,$_SESSION['barata_products']);
unset($_SESSION['barata_products'][$product_index]);
}
function remove_all_products() {
$_SESSION['barata_products'] = [];
}
//helper function to check if the session array is greater than your desired amount, where x is number of products within the array.
function more_than_x(session,x) {
$_SESSION['barata_products'].count() > x ? true : false
}
如果您需要更漂亮的WordPress会话逻辑,请查看此博客
您可以简单地使用 ajax 为每个产品创建一个会话,例如:
$(document).ready(function(){
$('.product').click(function(){
var product_id = $(this).attr('id');
$.ajax({
method: 'POST',
url : "YOUR PHP FILE NAME",
data : {product_id:product_id},
success : function(resp){
alert("Product is added to be compared");
}
});
});
});
PHP文件代码:
<?php
session_start();
$product_id = $_POST['product_id'];
if(!is_array($_SESSION['ids']))
{
$_SESSION['ids'] = array();
}
else
{
array_push($_SESSION['ids'], $product_id);
}
?>
然后,您可以使用该$_SESSION
变量将所有产品 ID 获取到比较模板中。
- underline-js:将键对象与数组键对象进行比较,如果存在,则移除现有的添加新的
- 如何在多变量比较的基础上添加ng类
- 添加/删除要与Jquery进行比较的产品
- 在JavaScript中将项目从一个数组添加到另一个数组之前比较两个数组
- 主干中的比较器在添加新模型时需要排序调用
- 如何在当前日期/特定日期中添加min,并在javascript中比较两个日期
- 将选项卡中的 URL 与数组中的 URL 进行比较,并向数组添加更多内容
- MongoDB:将Days字段添加到DB中的Date Type字段中,然后与当前日期进行比较
- 比较 URL 字符串和菜单字符串,然后使用 jQuery 添加类
- 如何在Wordpress中创建添加以进行比较
- 比较表数据,如果表数据为,则添加CSS
- 比较两个数组和公共对象会添加到新数组中
- 比较和添加项到对象数组
- 比较两个对象数组,并向匹配的对象添加一个新属性
- 比较值并为不匹配的单词添加错误类
- JS:比较数组和添加新的项目或删除不再在数组中的项目
- 由于将比较方法添加到数组原型而导致测试失败.如何更新代码或测试?
- 如何比较两个 javascript 数组并添加和删除不同的项目
- Rails 3插件nested_form与JavaScript在嵌套表单中动态添加表单字段的比较
- 在javascript中比较两个映射并向一个映射添加键