在线竞拍系统的PHP实现框架(二)


Posted in PHP onOctober 09, 2006

上回说完了商品的列表显示方法。下面来谈谈显示商品详细信息的方法,这与我们在论坛中常用的显示帖子的方法大同小异。

********显示详细信息的文件***********
detail.php

<?php
include "config.inc.php";

//显示商品详细信息
//用全局变量来做,可以方便地取到多个字段的值。
//有id,名字,价格,介绍,当前价,单位,图片,结束时间。
function ReadDetail(){
global $WARE_TABLE;
global $id,$name,$price,$description,$cprice,$unit,$image,$endtime;

$SQL="select id,name,description,price,unit,endtime,reply,curprice,photo from $WARE_TABLE where id='$id'";
$result=mysql_query($SQL) or die(mysql_error());

//下面这一句,也可以用list(...)来做,但我习惯这样分开,看起来是麻烦点,不过清楚些,特别是有要处理的字段时,这样就很有必要了。

$row=mysql_fetch_array($result);
$name=$row[name];
$price=$row[price];
$description=$row[description];
$unit=$row[unit];
$cprice=$row[curprice];
$endtime=date("Y-m-j",$row[endtime]);
if($row[photo]==1) $image=$row[id].".jpg";
else $image="";
}

//读最新10个买家信息
function ReadBuyer(){
global $BID_TABLE;
global $id,$buyer,$buyprice,$date,$num;

$SQL="select id,buyer,email,price from $BID_TABLE where parentid='$id' order by id desc";
$result=mysql_query($SQL) or die(mysql_error());
$k=mysql_num_rows($result);

$num=($k>10)? 10:$k; //判断一下,是不是多于10个。

for($i=0;$i<$num;$i++){
$row=mysql_fetch_array($result);
$buyer[]=$row[buyer];
$buyprice[]=$row[price];
$date[]=date("Y-m-j H:i:s",$row[id]);
}
}

//显示10个买家信息。
function ShowBuyer(){
global $buyer,$buyprice,$date,$num;

for($i=0;$i<$num;$i++){
echo "<tr><td width=25%>".$date[$i]."</td>";
echo "<td width=40%>".$buyer[$i]."</td>";
echo "<td width=35%>".$buyprice[$i]."</td></tr>";
}
}

ReadDetail();
ReadBuyer();

?>

完成了上面的处理,就可以html中用<? echo $name?>或<? echo $price;?>等来取到要显示的信息了,这些我就不详述了。

就是这句,要根据是否有图片分别显示文字或图片。
<? if($image=="") echo "没有照片"; else echo "<img src=photo/$image>"; ?>

在显示商品详细资料时,也应让用户可以投标,所以此时要对用户下的新价做出一个判断,我比较懒,就直接用deamweaver来做这个表单的校验了,只把其中的英文说明改成中文,不过由于在判断新出价的方面有点特殊,所以对dw生成的函数做了一点点改动。

<script language="JavaScript">
<!--
function MM_findObj(n, d) { //v3.0
var p,i,x; if(!d) d=document; if((p=n.indexOf("?"))>0&&parent.frames.length) {
d=parent.frames[n.substring(p+1)].document; n=n.substring(0,p);}
if(!(x=d[n])&&d.all) x=d.all[n]; for (i=0;!x&&i<d.forms.length;i++) x=d.forms[i][n];
for(i=0;!x&&d.layers&&i<d.layers.length;i++) x=MM_findObj(n,d.layers[i].document); return x;
}

function MM_validateForm() { //v3.0
var i,p,q,nm,test,num,min,max,errors='',args=MM_validateForm.arguments;
for (i=0; i<(args.length-2); i+=3) { test=args[i+2]; val=MM_findObj(args[i]);
if (val) { nm=val.name; if ((val=val.value)!="") {
if (test.indexOf('isEmail')!=-1) { p=val.indexOf('@');
if (p<1 || p==(val.length-1)) errors+='- '+nm+' 必须是正确的email地址.n';
} else if (test!='R') { num = parseFloat(val);
if (val!=''+num) errors+='- '+nm+' 必须是数值.n';
if (test.indexOf('inRange') != -1) { p=test.indexOf(':');
min=test.substring(8,p); max=test.substring(p+1);
//**********改动部分*********
var k=(num-min)/max;
//判断要大于当前价,并且是当前价+加价单位的整数倍
if (num<min || k != Math.ceil(k) ) errors+='- '+nm+' 必须是大于 '+min+' 并且加价必须为 '+max+'的整数倍.n';
} } } //*******结束改动部分********
else if (test.charAt(0) == 'R') errors += '- '+nm+' 要填完整.n'; }
} if (errors) alert('发现错误如下:n'+errors);
document.MM_returnValue = (errors == '');
}
//-->
</script>

下面的事就简单了,还要有什么呢?显示一下已结束竞标的商品吧。这个功能的实现与显示未结束的商品方法一样,我就不罗嗦了。唯一的区别在于一是SetCondition()条件的不同和在显示结束竞价的商品详细资料时,没有用户出价的表单。

另外,我再给出添加新商品的方法吧。

<?php
include "config.inc.php";
include "tview.class.php";

function AddRecord(){
global $view;
//以下变量都是从上一个页面的表单中得到的。
global $name,$price,$unit,$year,$month,$day,$photofile,$intro;

$t=time();
$c=nl2br($intro);
$et=mktime(24,0,0,$month,$day,$year);

//判断一下是否有图上传了。
$ph=( $photofile!="none" and !empty($photofile) )? '1':'0';

//调用成员函数add()参数就是sql语句中的values()中的字串
$view->Add("'$t','$name','$c','$price','$unit','$et','0','$price','$ph'");

//如果有图片,拷到指定目录下。
if($ph=='1')
copy($photofile,"photo/$t.jpg");

}

if( $Submit){
$view= new TViewPage($WARE_TABLE,20);
AddRecord();
header("Location:manager.htm");
}

?>

好了,罗罗嗦嗦写了两篇,不知道可不可以又加个几百分哦。:)

有什么问题真心地请大家提出来讨论,我可是把程序拿出来了,您见到什么不妥的不当的,可千万不要吝啬,记得告诉我一声。

我的email : ycshowtop@21cn.com

另外,如果你想要这个程序比较完整的代码,也来个email,我寄给您。

PHP 相关文章推荐
oracle资料库函式库
Oct 09 PHP
mysql5写入和读出乱码解决
Nov 25 PHP
追求程序速度,而不是编程的速度
Apr 23 PHP
Drupal7中常用的数据库操作实例
Mar 02 PHP
Win7 64位系统下PHP连接Oracle数据库
Aug 20 PHP
php实现给图片加灰色半透明效果的方法
Oct 20 PHP
yii实现图片上传及缩略图生成的方法
Dec 04 PHP
PHP删除指定目录中的所有目录及文件的方法
Feb 26 PHP
thinkphp框架下404页面设置 仅三步
May 14 PHP
PHP编程中的Session阻塞问题与解决方法分析
Aug 07 PHP
php删除一个路径下的所有文件夹和文件的方法
Feb 07 PHP
PHP代码重构方法漫谈
Apr 17 PHP
php中的时间处理
Oct 09 #PHP
用php写的serv-u的web申请账号的程序
Oct 09 #PHP
PHP系统流量分析的程序
Oct 09 #PHP
PHP的栏目导航程序
Oct 09 #PHP
php的计数器程序
Oct 09 #PHP
PHP的开合式多级菜单程序
Oct 09 #PHP
PHP如何透过ODBC来存取数据库
Oct 09 #PHP
You might like
深入PHP中的HashTable结构详解
2013/06/13 PHP
Zend Framework教程之Loader以及PluginLoader用法详解
2016/03/09 PHP
php版微信公众平台实现预约提交后发送email的方法
2016/09/26 PHP
PHP针对中英文混合字符串长度判断及截取方法示例
2017/03/31 PHP
thinkPHP框架实现的短信接口验证码功能示例
2018/06/20 PHP
PHP时间相关常用函数用法示例
2020/06/03 PHP
javascript学习基础笔记之DOM对象操作
2011/11/03 Javascript
jquery form表单序列化为对象的示例代码
2014/03/05 Javascript
生成二维码方法汇总
2014/12/26 Javascript
js实现简单的左右两边固定广告效果实例
2015/04/10 Javascript
JS组件中bootstrap multiselect两大组件较量
2016/01/26 Javascript
js不间断滚动的简单实现
2016/06/03 Javascript
bootstrap是什么_动力节点Java学院整理
2017/07/14 Javascript
Angular指令之restict匹配模式的详解
2017/07/27 Javascript
vue axios 给生产环境和发布环境配置不同的接口地址(推荐)
2018/05/08 Javascript
JavaScript创建对象方式总结【工厂模式、构造函数模式、原型模式等】
2018/12/19 Javascript
Mint UI实现A-Z字母排序的城市选择列表
2018/12/28 Javascript
vue框架制作购物车小球动画效果实例代码
2019/09/26 Javascript
Vue实现背景更换颜色操作
2020/07/17 Javascript
vue+element_ui上传文件,并传递额外参数操作
2020/12/05 Vue.js
[01:52]深扒TI7聊天轮盘语音出处7
2017/05/11 DOTA
[39:02]DOTA2亚洲邀请赛 3.31 小组赛 B组 Mineski vs VGJ.T
2018/04/01 DOTA
[00:10]神之谴戒
2019/03/06 DOTA
[33:33]完美世界DOTA2联赛PWL S2 FTD.C vs SZ 第二场 11.27
2020/11/30 DOTA
Python实现针对中文排序的方法
2017/05/09 Python
Python获取当前页面内所有链接的四种方法对比分析
2017/08/19 Python
django用户注册、登录、注销和用户扩展的示例
2018/03/19 Python
Python基于滑动平均思想实现缺失数据填充的方法
2019/02/21 Python
opencv3/python 鼠标响应操作详解
2019/12/11 Python
PyTorch之nn.ReLU与F.ReLU的区别介绍
2020/06/27 Python
python 实现Harris角点检测算法
2020/12/11 Python
做一个能自适应高度的textarea的示例代码
2019/09/06 HTML / CSS
美国LOGO设计公司:The Logo Company
2018/07/16 全球购物
2014年领导班子工作总结
2014/12/11 职场文书
python3实现Dijkstra算法最短路径的实现
2021/05/12 Python
Spring Boot mybatis-config 和 log4j 输出sql 日志的方式
2021/07/26 Java/Android