|
data:image/s3,"s3://crabby-images/9df89/9df89c83e8c1e31438585f2c965544b2676fc113" alt="" |
|
ขอความช่วยเหลือจากพี่ๆหน่อยค่ะ คือหนูจะทำ search ให้มันโชว์สินค้าตามที่ยูเซอร์พิมเข้าไป แล้วให้มันโชว์เปน paging ด้วยอ่าค่ะ แต่เจอเออเรอร์เต็มๆเรยค่ะ |
|
data:image/s3,"s3://crabby-images/7fedc/7fedcaf09fd5bee73954d02b4483c86d0230d420" alt="" |
|
|
data:image/s3,"s3://crabby-images/e45aa/e45aaee0f4fc905d19252793523fee033b94fae1" alt="" |
data:image/s3,"s3://crabby-images/231a7/231a78f05c0c0ed37737b99e26cea23b39ccf6d3" alt="" |
|
คือหนูเขียนเวปให้มันโชว์สินค้าซึ่งจะให้ยูเซอร์เลือกดูสินค้าได้จากตรง menubar แล้วก็ search ได้อ่ะค่ะ หนูเลยแบ่งเป็น if else ว่า ถ้า search ไม่เท่ากับ ค่าว่าง ก็ให้เซิชตาม keyword ส่วน else มันก็จะเปนกดตรง menubar หนูอธิบายเริ่มงง เดี๋ยวช่วยดูcode หน่อยนะคะ
Code (PHP)
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>Untitled Document</title>
<link rel="stylesheet" type="text/css" href="mystyle.css" />
<script type="text/javascript" src="myjs.js">
</script>
<script type="text/javascript" src="framework.js">
</script>
<script>
function addCart(id){
var data = "id=" + id;
var url = "add_cart.php";
ajaxLoad('post', url, data, "cart");
}
function readCart() {
ajaxLoad('post', "read_cart.php", null, "cart");
}
</script>
</head>
<body>
<div>
<? include('menubar.php'); ?>
</div>
<? include('onlineshop.inc.php');?>
<table width="1000" align="center" border="0">
<tr>
<td align="left"> <? include('sidemenu.php');?>
<table id="cart" bgcolor="#FF0066">
<tr> <td> <script> readCart(); </script> </td></tr>
</table>
</td>
<td>
<table width="100%" border="0">
<tr> <td width="30%"> </td>
<td width="50%"> </td>
<td> </td>
</tr>
<?php include("paging.inc.php");
$current_page=1;
if(isset($_GET['page']))
{
$current_page=$_GET['page'];
}
$rows_per_page = 9;
$start_row = paging_start_row($current_page,$rows_per_page);
$keyword=$_GET["search"];
if($keyword != "")
{
$argId=$_GET["search"];
// อันนี้ไม่เกี่ยวนะคะ^^
/*$sql= "SELECT * from product, color,material, category WHERE ( (product.Product_Des LIKE '%".$argId."%') OR
((product.Color_Id = color.Color_Id)AND product.Color_Id= (SELECT Color_Id FROM color WHERE Color_Name LIKE '%".$argId."%')) OR
((product.Mat_Id = material.Mat_Id)AND product.Mat_Id= (SELECT Mat_Id FROM material WHERE Mat_Name LIKE '%".$argId."%')) OR
((product.Cat_Id = category.Cat_Id)AND product.Cat_Id= (SELECT Cat_Id FROM category WHERE Cat_Name LIKE '%".$argId."%'))
) AND Size_Id='s1' LIMIT $start_row, $rows_per_page ;"; */
// ใช้อันนี้นะคะ คือจะเลือกโปรดักขึ้นมาโชว์ โดยให้มันเช็คในเดต้าเบสว่า description ของโปรดักมันตรงกับkeywordไม๊ หรือ color_id ของตาราง product มันตรงกับ color_id ของ color ไม๊ ประมานนี้อ่ะค่ะ แล้วตรงหลังสุดที่เลือกเฉพาะไซส์ s1 ก็เพราะว่าถ้าไม่กำหนดมันจะโชว์โปรดักซ้ำๆกันเพราะโปรดักนึงมีหลายไซส์
$sql= "SELECT * from product, color,material, category WHERE ( (product.Product_Des LIKE '%".$argId."%') OR
((product.Color_Id = color.Color_Id)AND product.Color_Id= (SELECT Color_Id FROM color WHERE Color_Name LIKE '%".$argId."%'))) AND Size_Id='s1' LIMIT $start_row, $rows_per_page ;";
}
// ส่วนตรงนี้จะเปนการโชว์โปรดักเมื่อยูเซอร์กดจาก menubar ค่ะ
else
{
$argId=$_GET["argId"];
$sql = "SELECT SQL_CALC_FOUND_ROWS * FROM product WHERE (Cat_Id ='$argId' OR Color_Id='$argId' OR Wearer_Id='$argId' OR Mat_Id='$argId') AND Size_Id='s1' LIMIT $start_row, $rows_per_page;";
}
$result=mysql_query($sql);
$found_rows=mysql_query("SELECT FOUND_ROWS();");
$total_rows=mysql_result($found_rows,0,0);
// ส่วนนี้เปนการเรียกใช้ paging อ่ะค่ะ หนูแยกฟังก์ชั่นไว้อีกหน้านึงค่ะ
$total_pages = paging_total_pages($total_rows, $rows_per_page);
if($total_rows==0){
echo "<caption><b> no result </b></caption>";
}
else {
$stop_row = paging_stop_row($start_row, $rows_per_page, $total_rows);
echo "<caption><b> product no.". ($start_row +1) . "-" . "$stop_row from total $total_rows </b></caption>";
}
$count=0;
echo "<table border=0 align=center >";
while($objResult = mysql_fetch_array($result))
{
$PID = $objResult['Product_Id'];
$Pname = $objResult['Product_Name'];
$Pdesc1 = $objResult['Product_Des'];
$Pdesc = substr($Pdesc1,0,80). "..." ;
$Pprice = $objResult['Product_Prices'];
$Ppic = $objResult['Product_Pict'];
if($count==0)
{
echo "<tr> <td width=220 ><div id=product> <img align=center width=115 src='$Ppic?Product_Id=$PID'> </div>";
echo "<div id=productName> <br><b> <a href='product_detail.php?PID=$PID'> $Pname </a> </b></div>";
echo "<div id=product> <br> $Pdesc </div>";
echo "<div id=product> <br> $Pprice Baht</div>";
echo "<div id=product> <br> <input type=button value='add to cart' > </div>";
echo "</td>";
$count++;
}
else if($count==1)
{
echo "<td width=220 > <div id=product> <img width=115 src='$Ppic?Product_Id=$PID'> </div>";
echo "<div id=productName> <br><b><a href='product_detail.php?PID=$PID'> $Pname </a> </b> </div>";
echo "<div id=product> <br> $Pdesc </div>";
echo "<div id=product> <br> $Pprice Baht</div>";
echo "<div id=product> <br> <input type=button value='add to cart' > </div>";
echo "</td>";
$count++;
}
else if($count==2)
{
echo "<td width=220 > <div> <img width=115 src='$Ppic?Product_Id=$PID'> </div>";
echo "<div id=productName> <br><b><a href='product_detail.php?PID=$PID'> $Pname </a> </b> </div>";
echo "<div id=product> <br> $Pdesc </div>";
echo "<div id=product> <br> $Pprice Baht</div>";
echo "<div id=product> <br> <input type=button value='add to cart' > </div>";
echo "</td>";
echo "</tr>";
$count=0;
}
} echo "</table>";
?>
<p align="right"> <br />
<?php
$page_range=5;
$qry_str="argId=$argId";
//$total_pages = paging_total_pages($total_rows, $rows_per_page);
$pagenum = paging_pagenum($current_page, $total_pages, $page_range, $qry_str);
?>
<?
echo "page:" . $pagenum;
?>
</p>
</table>
</td>
</tr>
</table>
<div>
<? include('footer.php'); ?>
</div>
</body>
</html>
เวลาหนูกดเลือกสีจาก menubar มันจะขึ้นตามปกติ คือไม่เออเรอร์อ่ะค่ะ แบบนี้ค่ะ.. สมมติว่าเลือกสีเทานะคะ..
data:image/s3,"s3://crabby-images/640b6/640b6e8bfd93a088c5ca6f22ec14a8424f702f61" alt="โชว์โปรดักแบบนี้ โชว์โปรดักแบบนี้"
แต่ถ้าหนูพิมสีลงไปในช่องsearch มันจะกลายเปนแบบนี้อ่ะค่ะ..
data:image/s3,"s3://crabby-images/3bdc8/3bdc88135de0397252c84d32b7dcf6677ad40c2e" alt="รูปที่ผิด รูปที่ผิด"
มันขึ้นโปรดักเดิมเปนพืดเลยค่าาา --"
ถ้าพี่ๆรู้ว่าผิดตรงไหนบอกหนูหน่อยน๊าค๊า
ขอบคุณมากค่า
Tag : PHP, MySQL
data:image/s3,"s3://crabby-images/f1944/f19447657087fec8fe853572ff7e2abde431999d" alt=""
|
ประวัติการแก้ไข 2011-12-06 10:33:27
|
data:image/s3,"s3://crabby-images/e1105/e1105d0e74a2d0eb06807f9a8bb7837265dd1b25" alt="" |
data:image/s3,"s3://crabby-images/92e09/92e0905a512f79cb2effe389f0706c0250452af0" alt="" |
data:image/s3,"s3://crabby-images/693ac/693ac66a71272d9b5660bb393d6a6a04364e4b31" alt="" |
data:image/s3,"s3://crabby-images/d2a47/d2a4711f1cb0ada479d82db711d17ea838ad4608" alt="" |
Date :
2011-12-06 10:29:39 |
By :
gellarjung |
View :
870 |
Reply :
1 |
|
data:image/s3,"s3://crabby-images/8ff8f/8ff8f25048dbb4f7de5f0118d14bcabdc18143ef" alt="" |
data:image/s3,"s3://crabby-images/7fd72/7fd72b1fac36218a06fb8209da6ac85fd043bc59" alt="" |
data:image/s3,"s3://crabby-images/cb795/cb79529c393c790a02b4efc08e9785df7594357b" alt="" |
data:image/s3,"s3://crabby-images/86f8b/86f8b258aff3f9b396166d63cdd10a0bdaa6a65b" alt="" |
|
|
|
data:image/s3,"s3://crabby-images/5416e/5416e7b34fe0f455da9044a6446378b16b8e0b2b" alt="" |
data:image/s3,"s3://crabby-images/84116/841160e53c788c51332da0ac62480d0c293dc438" alt="" |
|
data:image/s3,"s3://crabby-images/8a41b/8a41b2577cb9d0716104f821c8da48a5a3adeb45" alt="" |
data:image/s3,"s3://crabby-images/fc71b/fc71b0128ed13d03ddb4422fb4f7a3f7f2deb2e4" alt="" |
|
|
data:image/s3,"s3://crabby-images/f3b89/f3b89ccde25850c65b928bee7cddda844ab028bb" alt=""
|
Load balance : Server 05
|