<ruby id="bdb3f"></ruby>

    <p id="bdb3f"><cite id="bdb3f"></cite></p>

      <p id="bdb3f"><cite id="bdb3f"><th id="bdb3f"></th></cite></p><p id="bdb3f"></p>
        <p id="bdb3f"><cite id="bdb3f"></cite></p>

          <pre id="bdb3f"></pre>
          <pre id="bdb3f"><del id="bdb3f"><thead id="bdb3f"></thead></del></pre>

          <ruby id="bdb3f"><mark id="bdb3f"></mark></ruby><ruby id="bdb3f"></ruby>
          <pre id="bdb3f"><pre id="bdb3f"><mark id="bdb3f"></mark></pre></pre><output id="bdb3f"></output><p id="bdb3f"></p><p id="bdb3f"></p>

          <pre id="bdb3f"><del id="bdb3f"><progress id="bdb3f"></progress></del></pre>

                <ruby id="bdb3f"></ruby>

                ??碼云GVP開源項目 12k star Uniapp+ElementUI 功能強大 支持多語言、二開方便! 廣告
                ### 根據傳入的商品ID查詢最優限時折扣活動價格或者折扣信息(返回結果帶有html標簽) **位置:** Common\Common\function.php **參數:** * @param int $no_id 商品ID * @param int $type 商品ID類型, 1是唯一碼,2是SKU,3是SKC * @param $back int 返回結果類型 1返回的是帶鏈接的活動價,2返回的是限時折扣,3返回的是活動價 * @param $shop_id int 當前門店ID,可以選填 **調用:** 列表展示用,詳情頁展示限時折扣活動價請調用Event組件庫中的同名方法 getTimeEventPrice **View模版中調用:** {$vo.no_id|get_time_event_price = 1,1} // 返回活動價(帶連接) {$vo.no_id|get_time_event_price = 1,2,70} // 返回指定門店的限時折扣 {$vo.no_id|get_time_event_price = 1,3} // 返回活動價 **PHP 調用中調用:** get_time_event_price($v['item_id'], 1, 1) // 返回活動價(帶連接) get_time_event_price($v['item_id'], 1, 2) // 返回限時折扣 get_time_event_price($v['item_id'], 1, 3,70) // 返回指定門店的活動價 **返回:** 如果是會員優先活動,非會員參與時間未到,根據函數第三個參數返回 會員限時折扣價 return "<a href=".$href.">".$min["ac_price"]."(會員)</a>"; 或者會員限時折扣 return $min['ac_discount']."(會員)"; 如果是會員優先活動,非會員參與時間已到,根據函數第三個參數返回 限時折扣價 return "<a href=".$href.">".$min["ac_price"]."</a>"; 或者限時折扣 return $min['ac_discount']; 如果是非會員優先活動,根據函數第三個參數直接返回最低限時折扣價 return "<a href=".$href.">".$min["ac_price"]."</a>"; 或者限時折扣 return $min['ac_discount']; **完整代碼:** ~~~ /** * 查詢最優限時折扣活動價格信息 * QJM 2018-07-11 * qjm 2023-02-21 update * 為了兼容小程序無法從本文件獲取SESSION信息,新添加了當前門店ID參數,如果不傳,默認從SESSION取門店 * @param $no_id int 商品ID * @param $type int 商品ID類型 1是唯一碼,2是SKU,3是SKC * @param $back int 返回結果類型 1返回的是帶鏈接的活動價,2返回的是限時折扣,3返回的是活動價 * @param $shop_id int 當前門店ID,可以選填 * @return $min array 最優限時折扣信息 */ function get_time_event_price ($no_id, $type, $back, $shop_id) { // 1、查詢所有正在進行的限時折扣活動 $time = time(); $map['start_time'] = array('elt', $time); // 活動開始時間 $map['end_time'] = array('egt', $time); // 活動結束時間 $map['types'] = array('eq', 1); // 活動類型 1為限時折扣,2為滿減,3為滿折 $map['status'] = 1; // 審批狀態(0為未審批;1為審批通過;2為終止或審批不通過) $event_result = M('event_basic')->where($map)->select(); // 2、根據傳入的商品ID獲取商品的SPUID和SKUID及商品品類信息 if ($type == 1) { $spu_id = M('goods_item')->where('id=' . $no_id)->getField('spu_id'); // 獲取spu_id $sku_id = M('goods_item')->where('id=' . $no_id)->getField('sku_id'); // 獲取sku_id $skc_id = M('goods_item')->where('id=' . $no_id)->getField('skc_id'); // 獲取skc_id $item_id = $no_id; // 獲取唯一碼id } elseif ($type == 2) { $spu_id = M('goods_sku')->where('id=' . $no_id)->getField('spu_id'); // 獲取spu_id $sku_id = $no_id; // 獲取sku_id $skc_id = M('goods_sku')->where('id=' . $no_id)->getField('skc_id'); // 獲取skc_id } elseif ($type == 3) { $spu_id = M('goods_skc')->where('id=' . $no_id)->getField('spu_id'); // 獲取spu_id $sku_ids = M('goods_sku')->where('skc_id=' . $no_id)->getField('id', true); // 獲取sku_id $skc_id = $no_id; // 獲取skc_id } if (empty($spu_id)) { return '異常:傳入商品ID的SPUID不存在'; } if (empty($sku_id) && empty($sku_ids)) { return '異常:傳入商品ID的SKUID不存在'; } if (empty($skc_id)) { return '異常:傳入商品ID的SKCID不存在'; } $goods['price'] = M('goods_sku')->where('skc_id=' . $skc_id)->getField('original_price'); // 獲取商品市場價 $goods['brand'] = M('goods_spu')->where('id=' . $spu_id)->getField('brand_id'); // 獲取品牌ID $goods['sex'] = M('goods_spu_category')->where('level=1 and spu_id=' . $spu_id)->getField('cat_id'); // 獲取性別ID $goods['big_class'] = M('goods_spu_category')->where('level=2 and spu_id=' . $spu_id)->getField('cat_id'); // 獲取大類ID // 3、判斷商品符合的活動 foreach ($event_result as $key => $value) { // 活動范圍 1為品類,2為SPU,3為SKU, 4為SKC,5為唯一碼 if ($value['time_discount'] == 1) { $where_a['event_id'] = array('eq', $value['id']); $where_a['is_delete'] = array('eq', 0); $event_class = M('event_time_goods_class')->where($where_a)->select(); foreach ($event_class as $k => $v) { // 判斷品牌ID是否相等 if (!empty($v['brand_id'])) { if ($v['brand_id'] != $goods['brand'] && $v['cat_big_id'] != 1) { unset($event_class[$k]); continue; } } // 判斷性別ID是否相等 if (!empty($v['cat_sex_id'])) { if ($v['cat_sex_id'] != $goods['sex'] && $v['cat_big_id'] != 1) { unset($event_class[$k]); continue; } } // 判斷大類ID是否相等 if (!empty($v['cat_big_id'])) { if ($v['cat_big_id'] != $goods['big_class'] && $v['cat_big_id'] != 1) { unset($event_class[$k]); continue; } } } if (empty($event_class)) { unset($event_result[$key]); } else { foreach ($event_class as $kk => $vv) { $id = $vv['event_id']; $discount = $vv['event_discount']; $price = $vv['event_discount'] * $goods['price']; $active[] = array('id' => $id, 'ac_price' => $price, 'ac_discount' => $discount); } } } elseif ($value['time_discount'] == 2) { $where_b['event_id'] = array('eq', $value['id']); $where_b['mark'] = array('eq', 1); // 1是款號;2是SKU $where_b['is_delete'] = array('eq', 0); $where_b['menu_id'] = array('eq', $spu_id); $event_no = M('event_time_goods_no')->where($where_b)->select(); if (!empty($event_no)) { $id = array_column($event_no, 'event_id')[0]; $discount = round(array_column($event_no, 'discount_price')[0] / $goods['price'], 2); // 折扣價/原價保留兩位小數 $price = array_column($event_no, 'discount_price')[0]; $active[] = array('id' => $id, 'ac_price' => $price, 'ac_discount' => $discount); } } elseif ($value['time_discount'] == 3) { $where_c['event_id'] = array('eq', $value['id']); $where_c['mark'] = array('eq', 2); // 1是款號;2是SKU $where_c['is_delete'] = array('eq', 0); // $type表示傳入的ID類型, 1表示傳入的是唯一碼,2表示傳入的是SKU, 3表示傳入的SKC if ($type == 1 || $type == 2) { // 在限時折扣款號表中查詢該SKU $where_c['menu_id'] = array('eq', $sku_id); $event_no = M('event_time_goods_no')->where($where_c)->select(); } elseif ($type == 3) { // 在限時折扣款號表中查詢該SKU $where_c['menu_id'] = array('in', $sku_ids); $event_no = M('event_time_goods_no')->where($where_c)->select(); } if (!empty($event_no)) { $id = array_column($event_no, 'event_id')[0]; $discount = round(array_column($event_no, 'discount_price')[0] / $goods['price'], 2); // 折扣價/原價保留兩位小數 $price = array_column($event_no, 'discount_price')[0]; // 將活動ID,活動折扣,活動折扣價存入活動數組 $active[] = array('id' => $id, 'ac_price' => $price, 'ac_discount' => $discount); } } elseif ($value['time_discount'] == 4) { $where_d['event_id'] = array('eq', $value['id']); $where_d['mark'] = array('eq', 3); // 1是款號;2是SKU;3是SKC;4是唯一碼 $where_d['is_delete'] = array('eq', 0); $where_d['menu_id'] = array('eq', $skc_id); $event_no = M('event_time_goods_no')->where($where_d)->select(); if (!empty($event_no)) { $id = array_column($event_no, 'event_id')[0]; $discount = round(array_column($event_no, 'discount_price')[0] / $goods['price'], 2); // 折扣價/原價保留兩位小數 $price = array_column($event_no, 'discount_price')[0]; // 將活動ID,活動折扣,活動折扣價存入活動數組 $active[] = array('id' => $id, 'ac_price' => $price, 'ac_discount' => $discount); } } elseif ($value['time_discount'] == 5) { // $type表示傳入的ID類型, 1表示傳入的是唯一碼,2表示傳入的是SKU, 3表示傳入的SKC if ($type == 1) { // 在限時折扣款號表中查詢該唯一碼 $where_e['event_id'] = array('eq', $value['id']); $where_e['mark'] = array('eq', 4); // 1是款號;2是SKU;3是SKC;4是唯一碼 $where_e['is_delete'] = array('eq', 0); $where_e['menu_id'] = array('eq', $item_id); $event_no = M('event_time_goods_no')->where($where_e)->select(); } if (!empty($event_no)) { $id = array_column($event_no, 'event_id')[0]; $discount = round(array_column($event_no, 'discount_price')[0] / $goods['price'], 2); // 折扣價/原價保留兩位小數 $price = array_column($event_no, 'discount_price')[0]; // 將活動ID,活動折扣,活動折扣價存入活動數組 $active[] = array('id' => $id, 'ac_price' => $price, 'ac_discount' => $discount); } } } // 4、如果過濾后的活動信息為空,直接返回 if (empty($active)) { return; } // 5、排除掉當前門店沒有參與的活動 2023-10-12 jig add $shop_active = ''; $push = 0; $event_shop = ''; if (session('userInfo.is_hq') != 1 || !empty($shop_id)) { // 沒有門店身份展示最優惠 if (empty($shop_id)) { $login_shop = session('userInfo.shop_max_id'); } else { $login_shop = $shop_id; } if ($login_shop > 0) { foreach ($active as $key => $value) { $arr_shop['event_id'] = $value['id']; $arr_shop['shops_id'] = array(array('eq', $login_shop), array('eq', 1), 'or'); $event_shop = M('event_shop')->where($arr_shop)->select(); if (!empty($event_shop)) { $shop_active[$push] = $active[$key]; $push++; } } if (empty($shop_active)) { return ''; // 未查到門店返回空 } } } else { $shop_active = $active; } // 6、判斷價格最低的活動 $min = null; foreach ($shop_active as $key => $value) { if ($key == 0) { $min = $shop_active[$key]; continue; } if ($shop_active[$key]['ac_price'] < $min['ac_price']) { $min = $shop_active[$key]; } } // 7、查詢最優活動基本信息 $event_basic = M('event_basic')->where('id=' . $min['id'])->find(); $min['prior'] = $event_basic['prior']; // 會員優先參與活動 // 拼接限時折扣活動價鏈接 $href = '/index.php/Wpos/Member/Event/index/id/'.$event_basic['id'].'.html'; // 8、判斷會員優先活動 if ($min['prior'] == 1) { // 判斷非會員是否已經可以參與最優活動價 $time = time(); if ($time < $event_basic['start_time'] + $event_basic['prior_days'] * 86400) { if ($back == 1) { return "<a href=".$href.">".$min["ac_price"]."(會員)</a>"; } elseif ($back == 2) { return $min['ac_discount']."(會員)"; } elseif ($back == 3) { return $min["ac_price"]; } } else { if ($back == 1) { return "<a href=".$href.">".$min["ac_price"]."</a>"; } elseif ($back == 2) { return $min['ac_discount']; } elseif ($back == 3) { return $min["ac_price"]; } } } // 9、非會員優先活動直接返回最低限時折扣價或折扣 if ($back == 1) { return "<a href=".$href.">".$min["ac_price"]."</a>"; } elseif ($back == 2) { return $min['ac_discount']; } elseif ($back == 3) { return $min["ac_price"]; } } ~~~
                  <ruby id="bdb3f"></ruby>

                  <p id="bdb3f"><cite id="bdb3f"></cite></p>

                    <p id="bdb3f"><cite id="bdb3f"><th id="bdb3f"></th></cite></p><p id="bdb3f"></p>
                      <p id="bdb3f"><cite id="bdb3f"></cite></p>

                        <pre id="bdb3f"></pre>
                        <pre id="bdb3f"><del id="bdb3f"><thead id="bdb3f"></thead></del></pre>

                        <ruby id="bdb3f"><mark id="bdb3f"></mark></ruby><ruby id="bdb3f"></ruby>
                        <pre id="bdb3f"><pre id="bdb3f"><mark id="bdb3f"></mark></pre></pre><output id="bdb3f"></output><p id="bdb3f"></p><p id="bdb3f"></p>

                        <pre id="bdb3f"><del id="bdb3f"><progress id="bdb3f"></progress></del></pre>

                              <ruby id="bdb3f"></ruby>

                              哎呀哎呀视频在线观看