在线竞拍系统的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 相关文章推荐
基于PHP+MySQL的聊天室设计
Oct 09 PHP
php性能优化分析工具XDebug 大型网站调试工具
May 22 PHP
PHP容易被忽略而出错陷阱 数字与字符串比较
Nov 10 PHP
php addslashes及其他清除空格的方法是不安全的
Jan 25 PHP
php获取网页请求状态程序示例
Jun 17 PHP
php表单提交实例讲解
Nov 12 PHP
PHP中Enum(枚举)用法实例详解
Dec 07 PHP
提交表单后 PHP获取提交内容的实现方法
May 25 PHP
全面解析PHP操作Memcache基本函数
Jul 14 PHP
php 7新特性之类型申明详解
Jun 06 PHP
深入理解PHP的远程多会话调试
Sep 21 PHP
对laravel in 查询的使用方法详解
Oct 09 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
深入phpMyAdmin的安装与配置的详细步骤
2013/05/07 PHP
浅析php fwrite写入txt文件的时候用 \r\n不能换行的问题
2013/08/06 PHP
destoon安全设置中需要设置可写权限的目录及文件
2014/06/21 PHP
Yii2中YiiBase自动加载类、引用文件方法分析(autoload)
2016/07/25 PHP
PHP折半(二分)查找算法实例分析
2018/05/12 PHP
PHP利用Mysql锁解决高并发的方法
2018/09/04 PHP
Javascript常用运算符(Operators)-javascript基础教程
2007/12/14 Javascript
Div Select挡住的解决办法
2008/08/07 Javascript
js+数组实现网页上显示时间/星期几的实用方法
2013/01/18 Javascript
JS 如何获取radio选中后的值及不选择取radio的值
2013/10/28 Javascript
Jquery中$.get(),$.post(),$.ajax(),$.getJSON()的用法总结
2013/11/14 Javascript
详解vue.js组件化开发实践
2016/12/14 Javascript
详解通过JSON数据使用VUE.JS
2017/05/26 Javascript
vue jsx 使用指南及vue.js 使用jsx语法的方法
2017/11/11 Javascript
Vue v2.4中新增的$attrs及$listeners属性使用教程
2018/01/08 Javascript
基于vue.js实现分页查询功能
2018/12/29 Javascript
js实现QQ邮箱邮件拖拽删除功能
2020/08/27 Javascript
NodeJS和浏览器中this关键字的不同之处
2021/03/03 NodeJs
[08:40]Navi Vs Newbee
2018/06/07 DOTA
Python如何快速上手? 快速掌握一门新语言的方法
2017/11/14 Python
PyCharm设置每行最大长度限制的方法
2019/01/16 Python
CSS3 calc()会计算属性详解
2018/02/27 HTML / CSS
利用css3径向渐变做一张优惠券的示例
2018/03/22 HTML / CSS
HTML5移动端开发遇见的东西
2019/10/11 HTML / CSS
标准的毕业生自荐信
2014/04/20 职场文书
校长师德师风自我剖析材料
2014/09/29 职场文书
2015建军节87周年演讲稿
2015/03/19 职场文书
求职导师推荐信范文
2015/03/27 职场文书
春晚观后感
2015/06/11 职场文书
2016新年致辞
2015/08/01 职场文书
2016年七夕爱情寄语
2015/12/04 职场文书
《灰雀》教学反思
2016/02/19 职场文书
MySQL 使用自定义变量进行查询优化
2021/05/14 MySQL
教你利用python实现企业微信发送消息
2021/05/23 Python
Go 语言结构实例分析
2021/07/04 Golang
使用pipenv管理python虚拟环境的全过程
2021/09/25 Python