1. 程式人生 > >thinkphp——前臺(提交訂單)並插入相關資訊到資料庫

thinkphp——前臺(提交訂單)並插入相關資訊到資料庫

1.購物車列表頁:

2.訂單主頁顯示:

3.然後訂單主頁就是一些表單,如下:

<strong><span style="font-size:18px;"><!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta name="Generator" content="YONGDA v1.0" />
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
<meta name="Keywords" content="" />
<meta name="Description" content="" />
<title>購物流程_YONGDA商城 - Powered by YongDa</title>
<link href="{$smarty.const.CSS_URL}style.css" rel="stylesheet" type="text/css" />
<style type="text/css">
{
literal
}
table {
	border: 1px solid #dddddd;
	border-collapse: collapse;
	width: 99%;
	margin: auto;
}
td {
	border: 1px solid #dddddd;
}
#consignee_addr {
	width: 450px;
}
{
/literal
}
</style>
</head>
<body>
<div class="block clearfix" style="position: relative; height: 98px;"> <a href="#" name="top"><img class="logo" alt="" src="{$smarty.const.IMG_URL}logo.gif" /></a>
  <div id="topNav" class="clearfix">
    <div style="float: left;"> <font id="ECS_MEMBERZONE">
      <div id="append_parent"></div>
      歡迎光臨本店 
      {if $smarty.session.username}
      歡迎您:{$smarty.session.username} <a href="{$smarty.const.__MODULE__}/User/logout" style="color:red;" onclick="if (confirm('確定要退出登入嗎?')) return true; else return false;">退出登入</a> {else} <a href="{$smarty.const.__MODULE__}/User/login"> 登入</a> <a href="{$smarty.const.__MODULE__}/User/register">註冊</a> {/if} </font> </div>
    <div style="float: right;"> <a href="#">檢視購物車</a> | <a href="#">選購中心</a> | <a href="#">標籤雲</a> | <a href="#">報價單</a> </div>
  </div>
  <div id="mainNav" class="clearfix">
    <ul>
      <li> <a href="{$smarty.const.__MODULE__}/Index/index" class="cur">首頁<span></span></a></li>
      {foreach $pcinfo as $k=>$v}
      <li><a href="{$smarty.const.__MODULE__}/Goods/showlist/category_id/{$v.category_id}" class="cur">{$v.category_name}<span></span> </a> </li>
      {/foreach}
      <li> <a href="#" class="cur">留言板<span></span></a> </li>
    </ul>
  </div>
</div>
<div class="header_bg">
  <div style="float: left; font-size: 14px; color:white; padding-left: 15px;"> </div>
  <form id="searchForm" method="get" action="{$smarty.const.__MODULE__}/Goods/search">
    <input name="keywords" id="keyword" type="text" />
    <input name="imageField" value=" " class="go" style="cursor: pointer; background: url('{$smarty.const.IMG_URL}sousuo.gif') no-repeat scroll 0% 0% transparent; width: 39px; height: 20px; border: medium none; float: left; margin-right: 15px; vertical-align: middle;" type="submit" />
  </form>
</div>
<div class="blank5"></div>
<div class="header_bg_b">
{*購物車總數和總價格*}
  {foreach $cart_data as $k=>$v}
  {foreach $ginfo as $kk=>$vv}
    {if $vv.goods_id==$v.goods_id}
     {$num=$num+{$vv.goods_price*$v.goods_num}}
    {$number=$number+{$v.goods_num}}
      {/if}
    {/foreach}
    {/foreach}
  <div class="f_r" style="padding-right: 10px;"> <img style="vertical-align: middle;" src="{$smarty.const.IMG_URL}biao3.gif" /> <span class="cart" id="ECS_CARTINFO"> <a href="{$smarty.const.__MODULE__}/Cart/showlist" title="檢視購物車">您的購物車中有 {$number} 件商品,總計金額 ¥{$num}元。</a></span> <a href="{$smarty.const.__MODULE__}/Cart/showlist"><img style="vertical-align: middle;" src="{$smarty.const.IMG_URL}biao7.gif" /></a> </div>
</div>
<div class="block box">
  <div class="blank"></div>
  <div id="ur_here"> 當前位置: <a href="#">首頁</a> <code>></code> 購物流程 </div>
</div>
<div class="blank"></div>
<div class="blank"></div>
<div class="block">
  <form action="{$smarty.const.__CONTROLLER__}/cartToOrder" method="post" name="theForm" id="theForm" >
    <div class="flowBox">
      <h6><span>商品列表</span><a href="#" class="f6">修改</a></h6>
      <table cellpadding="5" cellspacing="1" width="99%">
        <tbody>
          <tr>
            <th>商品名稱</th>
            <th>本店價</th>
            <th>購買數量</th>
            <th>小計</th>
          </tr>
          {foreach $cart_data as $k=>$v}
          <tr>
          {foreach $ginfo as $kk=>$vv}
          {if $vv.goods_id==$v.goods_id}
            <td><a href="#" target="_blank" class="f6">
            <input type="hidden" name="sub_goods_id[]" value="{$vv.goods_id}" />
            {$vv.goods_name}</a></td>
            <td align="right">
            ¥{$vv.goods_price}元</td>
            <td align="right">
            <input type="hidden" name="sub_goods_buy_number[]" value="{$v.goods_num}" />{$v.goods_num}</td>
            <td align="right">
           ¥{$vv.goods_price*$v.goods_num}元</td>
           {/if}
          {/foreach}
          </tr>
          {/foreach}
          <tr>
            <td colspan="7"> 購物金額小計 ¥{$num}元</td>
          </tr>
        </tbody>
      </table>
    </div>
    <div class="blank"></div>
    <div class="flowBox">
      <h6><span>收貨人資訊</span><a href="#" class="f6">修改</a></h6>
      <table cellpadding="5" cellspacing="1" width="99%">
        <tbody>
          <tr>
            <td>收貨人姓名:</td>
            <td><input type="text" name="consignee_name" /></td>
            <td>電子郵件地址:</td>
            <td><input type="text" name="consignee_email" /></td>
          </tr>
          <tr>
            <td>省份:</td>
            <td><input type="text" name="consignee_province" /></td>
            <td>城市:</td>
            <td><input type="text" name="consignee_city" /></td>
            <td>地區:</td>
            <td><input type="text" name="consignee_district" /></td>
          </tr>
          <tr>
            <td>詳細地址:</td>
            <td colspan="2"><textarea name="consignee_address" rows="1" cols="30"></textarea></td>
            <td>郵政編碼:</td>
            <td><input type="text" name="consignee_zipcode" /></td>
          </tr>
          <tr>
            <td>電話:</td>
            <td><input type="text" name="consignee_tel" /></td>
            <td>手機:</td>
            <td><input type="text" name="consignee_mobile" /></td>
          </tr>
          <tr>
            <td>最佳送貨時間:</td>
            <td><input type="text" name="consignee_best_time" /></td>
          </tr>
        </tbody>
      </table>
    </div>
    <div class="blank"></div>
    <div class="flowBox">
      <h6><span>配送方式</span></h6>
      <script>
     /* window.onload=function(){
			var radio=document.getElementsByName("shipping");
			for(var i=0;i<radio.length;i++){
				if(radio[i].checked==true){
				value=radio[i].value;
				document.write(value);
				}
			}
		}*/
      </script>
      <table id="shippingTable" cellpadding="5" cellspacing="1" width="99%">
        <tbody>
          <tr>
            <th width="5%"> </th>
            <th width="25%">名稱</th>
            <th width="15%">費用</th>
          </tr>
          <tr>
            <td valign="top"><input name="order_ship_name" value="5"  type="radio" checked="checked" /></td>
            <td valign="top"><strong>申通快遞</strong></td>
            <td align="right" valign="top">¥15.00元</td>
          </tr>
          <tr>
            <td valign="top"><input name="order_ship_name" value="3"  type="radio" /></td>
            <td valign="top"><strong>城際快遞</strong></td>
            <td align="right" valign="top">¥10.00元</td>
          </tr>
          <tr>
            <td valign="top"><input name="order_ship_name" value="6"   type="radio" /></td>
            <td valign="top"><strong>郵局平郵</strong></td>
            <td align="right" valign="top">¥3.50元</td>
          </tr>
        </tbody>
      </table>
    </div>
    <div class="blank"></div>
    <div class="flowBox">
      <h6><span>支付方式</span></h6>
      <table id="paymentTable" cellpadding="5" cellspacing="1" width="99%">
        <tbody>
          <tr>
            <th width="5%"> </th>
            <th width="20%">名稱</th>
            <th width="15%">手續費</th>
          </tr>
          <tr>
            <td valign="top"><input name="order_pay_name" value="1" iscod="0" type="radio" /></td>
            <td valign="top"><strong>支付寶支付</strong></td>
            <td align="right" valign="top">¥0.00元</td>
          </tr>
          <tr>
            <td valign="top"><input name="order_pay_name" value="2" iscod="0" type="radio" checked="checked"/></td>
            <td valign="top"><strong>銀行匯款/轉帳</strong></td>
            <td align="right" valign="top">¥0.00元</td>
          </tr>
          <tr>
            <td valign="top"><input name="order_pay_name" value="3" iscod="1" disabled="true" type="radio" /></td>
            <td valign="top"><strong>貨到付款</strong></td>
            <td align="right" valign="top"><span id="ECS_CODFEE">¥0.00元</span></td>
          </tr>
        </tbody>
      </table>
    </div>
    <div class="blank"></div>
    <div class="blank"></div>
    <div class="flowBox">
      <h6><span>費用總計</span></h6>
      <div id="ECS_ORDERTOTAL">
        <table cellpadding="5" cellspacing="1" width="99%">
          <tbody>
            <tr>
              <td align="right"> 商品總價: <font class="f4_b">¥{$num}元</font></td>
            </tr>
            <tr>
              <td align="right"> 應付款金額: <font class="f4_b">¥{$num}元
              <input type="hidden" name="order_amount" value="{$num}" />
              {*訂單建立時間*}<input type="hidden" name="order_create_time" value="{$smarty.now|date_format:'%Y-%m-%d %H:%M:%S'}" />
              </font></td>
            </tr>
          </tbody>
        </table>
      </div>
      <div style="margin: 8px auto;">
        <input type="submit" value='提交訂單' type="image" />
        <input name="step" value="done" type="hidden" />
      </div>
    </div>
  </form>
</div>
<div class="blank"></div>
<div class="block"> <a href="#" target="_blank" title="YONGDA商城"><img alt="YONGDA商城" src="{$smarty.const.IMG_URL}di.jpg" /></a>
  <div class="blank"></div>
</div>
<div class="blank"></div>
<div id="bottomNav" class="box block">
  <div class="box_1">
    <div class="links clearfix"> <a href="#" target="_blank" title="YONGDA商城">Powered by <strong><span style="color: rgb(51, 102, 255);">YongDa</span></strong></a> [<a href="#" target="_blank" title="">yongda商城</a>] </div>
  </div>
</div>
<div class="blank"></div>
<div id="bottomNav" class="box block">
  <div class="bNavList clearfix"> <a href="#">免責條款</a> | <a href="#">隱私保護</a> | <a href="#">諮詢熱點</a> | <a href="#">聯絡我們</a> | <a href="#">公司簡介</a> | <a href="#">批發方案</a> | <a href="#">配送方式</a> </div>
</div>
<div id="footer">
  <div class="text"> © 2005-2012 YONGDA 版權所有,並保留所有權利。<br />
  </div>
</div>
</body>
</html></span></strong>

4.訂單提交後:控制器裡如下:
<strong><span style="font-size:18px;">//購物車結算(提交訂單)
	function cartToOrder(){
		//接收index傳過來的值
		$sub_goods_buy_number=I('sub_goods_buy_number',0);//商品數量
		
		$consignee_name=I('consignee_name',0);//收貨人姓名
		$consignee_email=I('consignee_email',0);//電子郵件地址
		$consignee_province=I('consignee_province',0);//省份
		$consignee_city=I('consignee_city',0);//城市
		$consignee_district=I('consignee_district',0);//地區
		$consignee_address=I('consignee_address',0);//詳細地址
		$consignee_zipcode=I('consignee_zipcode',0);//郵政編碼
		$consignee_tel=I('consignee_tel',0);//電話
		$consignee_mobile=I('consignee_mobile',0);//手機
		$consignee_best_time=I('consignee_best_time',0);//最佳送貨時間
		
		$order_ship_name=I('order_ship_name',0);//配送方式名稱
		$order_pay_name=I('order_pay_name',0);//支付方式
		$order_amount=I('order_amount',0);//訂單總金額
		$order_create_time=I('order_create_time',0);//訂單建立時間
		
				
		$uid=session("user_id");
		if(!$uid){
		echo "<script>alert('請先登入');location.href='../User/login'</script>";
		//$this->ajaxReturn(array("status"=>0,"info"=>"請先登入"));
		}
		$cart=unserialize(D('Cart')->where("cart_uid='{$uid}'")->getField("cart_info"));
		
		$id_arr=array();
		foreach($cart as $k=>$v){
			$id_arr[]=$v['goods_id'];
		}
		$ids=implode(',',$id_arr);//把商品id由陣列變為逗號隔開
		$goods=D('Goods')->where("goods_id in ($ids)")->select();
		$order_data=array();
		foreach($goods as $k=>$v){
			$order_data['order_sn']=date("Ymdhis").'_'.$v['goods_id'];
			$order_data['order_uid']=$uid;
			$order_data['order_uname']=$consignee_email;
			$order_data['order_status']=1;
			$order_data['order_ship_name']=$order_ship_name;
			$order_data['order_pay_name']=$order_pay_name;
			$order_data['order_amount']=$order_amount;
			$order_data['order_create_time']=$order_create_time;
		}
		$oinfo=D('Order')->add($order_data);
		$order=D('Order')->field('order_sn')->find($oinfo); 
		$order_sn=$order['order_sn'];
		if($oinfo){
			foreach($goods as $k=>$v){
				$order_goods_data=array();
				$order_goods_data['sub_pid']=$oinfo;
				$order_goods_data['sub_order_sn']=$order_sn;
				$order_goods_data['sub_goods_id']=$v['goods_id'];
				$order_goods_data['sub_goods_name']=$v['goods_name'];
				$order_goods_data['sub_goods_price']=$v['goods_price'];
				$order_goods_data['sub_goods_buy_number']=$sub_goods_buy_number[$k];
				$order_goods_data['sub_goods_buy_sum']=$sub_goods_buy_number[$k]*$v['goods_price'];
				$sinfo=D('Order_sub')->add($order_goods_data);				
			}			
			if($sinfo){
				foreach($goods as $k=>$v){
					$user_consignee_data=array();
					$user_consignee_data['consignee_u_id']=$uid;
					$user_consignee_data['consignee_name']=$consignee_name;
					$user_consignee_data['consignee_email']=$consignee_email;
					$user_consignee_data['consignee_province']=$consignee_province;
					$user_consignee_data['consignee_city']=$consignee_city;
					$user_consignee_data['consignee_district']=$consignee_district;
					$user_consignee_data['consignee_address']=$consignee_address;
					$user_consignee_data['consignee_zipcode']=$consignee_zipcode;
					$user_consignee_data['consignee_tel']=$consignee_tel;
					$user_consignee_data['consignee_mobile']=$consignee_mobile;
					$user_consignee_data['consignee_best_time']=$consignee_best_time;
				}
				$is_ok=D('User_consignee')->add($user_consignee_data);
				if($is_ok){
					$rst=D('Cart')->where("cart_uid='{$uid}'")->delete();//訂單提交後刪除使用者購物車
					if($rst)
					echo "<script>alert('訂單提交成功');location.href='../Cart/showlist'</script>";
				}
			}
		}
		//show_bug($ginfo);
	}</span></strong>

      


初學者如需購買thinkphp程式(包括前後臺),加個人微信LBXZFR2013

微信掃描關注“公眾號” 有驚喜

公眾號ID“lbxzsan7378”