麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > CMS > Ecshop > 正文

ECSHOP添加最新交易滾動顯示功能

2024-07-09 22:56:30
字體:
來源:轉載
供稿:網友

ecshop添加新功能我感覺無外乎就是兩個地方的修改,顯示的要修改模板,為了方便下次升級,最好都做成lbi,下次升級了直接把lbi拷進去, 然后稍微修改一下dwt的模板就行了。而對于程序部分的修改,我建議做一個自己的目錄,比如dev,然后把自己加的每個功能做成一個php文件放到 dev目錄里面,在需要的時候在原來的ecshop的php里面include或者require進來就行了。這樣下次系統升級目錄一拷,然后在該 include的地方include 一下就ok了,省時省心。當然,我個人建議你維護一個表,用來保存你都在哪些地方做過哪些修改,以方便下次升級的使用。下面我從模板和程序兩個 方面說一下需要修改什么地方。

一、程序層面修改 
我們想要顯示的無非就是什么人在什么時間購買了什么東西,這樣分析下來我們需要去從數據庫讀取出來這來信息。從網上找到ecshop的數據字典,看了看 和咱們相關的表有三個ecs_order_info,ecs_order_goods,ecs_users,分別存儲了訂單信息,訂單對應的商品信息和購買商品的用戶信息。這三個表同 user_id,order_id和goods_id三個key來聯系,下面我們要寫出sql語句從中取出我們需要的那些信息,sql語句如下:

 SELECT ecs_users.user_name, ecs_order_goods.goods_id,
            ecs_order_goods.goods_name, order_info.add_time
            FROM ecs_users, 
            (
                SELECT order_id, user_id, add_time
                FROM ecs_order_info
                ORDER BY ecs_order_info.add_time DESC 
                LIMIT 0 , 20
            ) AS order_info, 
            ecs_order_goods
            WHERE order_info.order_id = ecs_order_goods.order_id
            AND order_info.user_id = ecs_users.user_id;


 


上面語句的意思從ecs_order_info里面提取前20個交易,然后根據order_id,goods_id和user_id的關聯來獲取用戶名、商品名、商品id和訂單時間。搞定了sql語句, 下面我們就要按照ecshop的模式來寫個函數,這個函數從通過數據庫獲取sql語句的內容,然后把這個sql的record封裝到一個array里面,傳給smarty模板來使用。 下面給出代碼,大家參考一下:

 
>
        /**
         * 調用獲取最新購買者和物品檠?         *
         * @access  private
         * @return  array
         */
        function index_get_recent_buy_query()
        {
            $sql = 'SELECT ecs_users.user_name, ecs_order_goods.goods_id,
                     ecs_order_goods.goods_name, order_info.add_time
                    FROM ecs_users, 
                    (
                        SELECT order_id, user_id, add_time
                        FROM ecs_order_info
                        ORDER BY ecs_order_info.add_time DESC 
                        LIMIT 0 , 20
                    ) AS order_info, 
                    ecs_order_goods
                    WHERE order_info.order_id = ecs_order_goods.order_id
                    AND order_info.user_id = ecs_users.user_id;';
 
            $all = $GLOBALS['db']->getAll($sql);
 
            $arr = array();
 
            foreach ($all AS $idx => $row)
            {
                $arr[$idx]['username']  = $row['user_name'];
                $arr[$idx]['goodName']  = $row['goods_name'];
                $arr[$idx]['goodID']    = $row['goods_id'];
                $arr[$idx]['add_time']  = local_date(
                  $GLOBALS['_CFG']['date_format'], $row['add_time']);
            }
 
            return $arr;
        }

 


上面代碼使用了$GLOBALS['db']->getAll($sql);來獲取數據庫里面記錄,這個db是在init.php里面系統初始化加載好的全局變量,他負責和數據庫交互,獲取 數據等功能。有時間我寫幾篇ecshop代碼分析的文章,詳細講解一下ecshop的初始化過程,大家就可以了解ecshop高質量的代碼了。下面的那個 foreach做的而 工作其實就是把數據封裝到array,smarty在模板處理時數組友好的。上面只是獲取了array,下面的語句是賦值array到smarty模板”

 
//獲取最新的購買者信息
$smarty->assign('recent_buys',     index_get_recent_buy_query());

 


把這句話加到index.php的類似的地方就可以,基本上在80多行,ecshop集中模板賦值的地方。在面我們來看看賦過去的值smarty模板是怎么用的。

二、模板層面的修改 
我們建立一個BusinessActivities.lbi來放我們的smarty模板內容。下面是代碼,看完代碼我來分析:

 <meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<!--{if $invoice_list}-->
<style type="text/css">
.boxCenterList form{display:inline;}
.boxCenterList form a{color:#404040; text-decoration:underline;}
</style>
<div class="box">
 <div class="box_1">
  <h3><span>{$lang.sale_activities}</span></h3>
  <div class="boxCenterList">
  <MARQUEE onmouseover=this.stop() onmouseout=this.start() 
scrollAmount=1 direction=up height=155px>
    <!-- 發貨單查詢{foreach from=$recent_buys item=buy_info} -->
    <image src='images/speaker.gif'> {$buy_info.username} 在 {$buy_info.add_time} 買了
    <a href='goods.php?id={$buy_info.goodID}'> {$buy_info.goodName}</a><br>
 
   <div class="blank"></div>
   <!-- 結束發貨單查詢{/foreach}-->
      </MARQUEE>
  </div>
 </div>
</div>
<div class="blank5"></div>
<!-- {/if} --> 
 

大家注意看上面的是來說明你的模板內容基本信息的,我這里是utf8,如果你是gbk,要改成gbk哦。 是和我們上面php程序里面的$smarty->assign(’recent_buys’, index_get_recent_buy_query())對應的,若果你給recent_buys賦值, 并且這個值不為空或者0的話才顯示咱們的模板內容。我們重點看,foreach是smarty模板內置函數,其 主要作用是遍歷傳入的數組,然后生成內容,類似于其他語言里面的foreach。這句話就是遍歷recent_buys,然后把每次遍歷的項做 buy_info,其實這個buy_info 就是咱們數據的2維數組的第二維了。你可以直接用{$buy_info.goodName}這種形式來調用你數組傳入的內容。用smarty模板絕對的數據和現實分離,很爽的。 
下面你在你需要顯示的地方加入 就可以顯示了。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 日美av在线| 日本爽快片100色毛片视频 | 202z中文字幕第一页 | 免费观看一区二区三区视频 | 日韩大片在线永久观看视频网站免费 | 欧美激情精品久久久久久久久久 | 黄色电影免费网址 | 电影av在线| 韩国三级日本三级香港三级黄 | 久久91亚洲人成电影网站 | 久久久久二区 | 日韩毛片在线看 | 久久婷婷一区二区三区 | 国产精品18久久久久久久久 | 国产在线精品一区二区 | 广州毛片| 中国美女一级黄色大片 | 性少妇freeseⅹbbwhd | 日韩视频一二区 | 失禁高潮抽搐喷水h | 免费看性xxx高清视频自由 | 九九视屏 | 玩偶姐姐在线观看免费 | 久久久久久久久国产 | 免费观看9x视频网站在线观看 | 免费一级在线视频 | 午夜生活理论片 | 午夜精品福利在线观看 | 1级黄色毛片| 久久艹一区| 欧美日韩大片在线观看 | 国产91小视频在线观看 | 欧美日韩中文字幕在线 | 黄色免费电影网址 | 欧美a视频在线观看 | 国产精品色综合 | 久久精品视频亚洲 | 999久久久国产999久久久 | h视频在线免费看 | 又黄又爽免费无遮挡在线观看 | 亚洲国产高清一区 |