嗨朋友们!我在这里有一个网页我正在显示我的产品详细信息,在此页面中我需要以下要求
Display products should have filtering options:
a. From lower to higher price
b. From Higher to lower price
c. Newly created
d. Alphabetical order
我想知道如何实现上述要求。请帮帮我。
抱歉我的英文不好<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xml:lang="en-us" xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>CodeIgniter Shopping Cart</title>
<link href="<?php echo base_url(); ?>assets/css/core.css" media="screen" rel="stylesheet" type="text/css" />
<script type="text/javascript" src="<?php echo base_url(); ?>assets/js/jquery-1.3.2.min.js"></script>
<script type="text/javascript" src="<?php echo base_url(); ?>assets/js/core1.js"></script>
</head>
<body>
<div id="cart_data">
<a href="<?php echo base_url(); ?>cart1/show_cart">View Cart </a>
<div id="cart_message"> </div>
<div id="wrap">
<?php $this->view('products1'); ?>
<!--
<div class="cart_list">
<h3>Your shopping cart</h3>
<div id="cart_content">
<?php //echo $this->view('cart1.php'); ?>
</div>
</div>-->
</div>
<!-- <p style="text-align: justify;"><div id="pagination"> <?php //echo $links; ?> </div></p>-->
</div>
</body>
</html>
答案 0 :(得分:0)
您没有说产品是否存储在数据库中。如果他们不是,他们可能应该是。
然后,如果您的产品存储在数据库中,使用$ this-&gt; db-&gt; order_by('field_name desc | asc')订购它们很简单;请注意,您没有要求“过滤”您要求“订购”
所以,请阅读有关codeigniter使用的MVC方法的文档。制作一个产品模型,用于处理创建产品表,添加,删除和提取产品,以及您需要的订购。制作一个控制器来协调这些任务,并创建视图来显示数据。
想想你希望产品表做的事情,并找出你需要存储的东西来实现这一点 - 所以根据你的描述,产品表需要类似的东西:
create table products (
id int unsigned auto_increment,
name varchar(255) not null,
price float unsigned not null,
primary key (id))
ENGINE=InnoDB default CHARSET=utf8 COLLATE=utf8_unicode_ci;
然后你可以将结果作为一个对象数组得到类似的东西:
function get_records($order_by)
{
return $this->db->from('products')
->order_by($order_by)
->get()
->result();
}
顺序依次为
a:价格asc
b:价格描述
c:id desc
d:名称asc