您现在的位置是:首页 > cms教程 > Ecshop商城教程Ecshop商城教程

ecshop商品购买批发起订量数量插件开发教程

香巧2023-11-30Ecshop商城教程已有人查阅

导读做过ECSHOP商城,或者说经营过商城的都会知道,有很多商品利润很小,而且还要包运费什么的,所以根本就是做 的生意,如果利润小

做过ECSHOP商城,或者说经营过商城的都会知道,有很多商品利润很小,而且还要包运费什么的,所以根本就是做 的生意,如果利润小,数量多的话这样就不会出现赔本的损失。所以 今天 个插件也是很实用的插件就是如果在后台设置商品很小起订量
步骤一,商品表必须有个字段  代表某个商品 很小订购数量->min_number
打开goods表在最后字段添加一个min_number  tinyint类型 默认值为0  代表没有很小起订量
sql:alter table `goods` add column `min_number` tinyint (3) UNSIGNED  DEFAULT '0' NOT NULL  after `warn_number`
步骤二,在后台添加商品的时候 必须有个text文本框  设置很小起订量
admin/goods.php
在'warn_number'=> 1 , 代码行后插入'min_number'=> 0, 
在$warn_number = isset($_POST['warn_number']) ? $_POST['warn_number'] : 0;
后添加代码$min_number = isset($_POST['min_number']) ? $_POST['min_number'] : 0;
步骤三,修改添加商品sql语句
修改代码
if ($is_insert){  
 if ($code == ''){
  $sql = "INSERT INTO " . $ecs->table('goods') . " (goods_name, goods_name_style, goods_sn, " .
  "cat_id, brand_id, shop_price, market_price, is_promote, promote_price, " .
 "promote_start_date, promote_end_date, goods_img, goods_thumb, original_img,keywords, goods_brief, " .
 "seller_note, goods_weight, goods_number, warn_number,min_number, integral,give_integral, is_best, is_new, is_hot, ".
 "is_on_sale, is_alone_sale, goods_desc, add_time, last_update, goods_type,rank_integral)" .
"VALUES ('$_POST[goods_name]', '$goods_name_style', '$goods_sn', '$catgory_id', " .
 "'$brand_id', '$shop_price', '$market_price', '$is_promote','$promote_price', ".
 "'$promote_start_date', '$promote_end_date', '$goods_img', '$goods_thumb', '$original_img', ".
 "'$_POST[keywords]', '$_POST[goods_brief]', '$_POST[seller_note]', '$goods_weight','$goods_number',".
 "'$warn_number','$min_number', '$_POST[integral]', '$give_integral', '$is_best', '$is_new', '$is_hot', '$is_on_sale', '$is_alone_sale', ".
 "'$_POST[goods_desc]', '" . gmtime() . "', '". gmtime() ."', '$goods_type','$rank_integral')";
 }else{
  $sql = "INSERT INTO " . $ecs->table('goods') . " (goods_name, goods_name_style, goods_sn, ".
 "cat_id, brand_id, shop_price, market_price, is_promote, promote_price, " .
  "promote_start_date, promote_end_date, goods_img, goods_thumb, original_img,keywords, goods_brief, " .
  "seller_note, goods_weight, goods_number, warn_number, min_number,integral,give_integral, is_best, is_new, is_hot, is_real, " .
  "is_on_sale, is_alone_sale, goods_desc, add_time, last_update, goods_type,extension_code, rank_integral)" .
  "VALUES ('$_POST[goods_name]', '$goods_name_style', '$goods_sn', '$catgory_id', " .
  "'$brand_id', '$shop_price', '$market_price', '$is_promote','$promote_price', ".
  "'$promote_start_date', '$promote_end_date', '$goods_img', '$goods_thumb','$original_img', ".
  "'$_POST[keywords]', '$_POST[goods_brief]', '$_POST[seller_note]', '$goods_weight','$goods_number',".
  " '$warn_number','$min_number', '$_POST[integral]', '$give_integral', '$is_best','$is_new', '$is_hot', 0, '$is_on_sale', '$is_alone_sale’' ".
  " '$_POST[goods_desc]', '" . gmtime() . "', '". gmtime() ."', '$goods_type', '$code', '$rank_integral')";
 }
}else{
 
  $sql = "SELECT goods_thumb, goods_img, original_img " .
 " FROM " . $ecs->table('goods') .
   " WHERE goods_id = '$_REQUEST[goods_id]'";
  $row = $db->getRow($sql);
  if ($proc_thumb && $goods_img && $row['goods_img'] &&
  !goods_parse_url($row['goods_img']))
  {
   @unlink(ROOT_PATH . $row['goods_img']);
   @unlink(ROOT_PATH . $row['original_img']);
  }
  if ($proc_thumb && $goods_thumb && $row['goods_thumb'] && !goods_parse_url($row['goods_thumb']))
  {
   @unlink(ROOT_PATH . $row['goods_thumb']);
  }
   $sql = "UPDATE " . $ecs->table('goods') . " SET " .
   "goods_name = '$_POST[goods_name]', " .
   "goods_name_style = '$goods_name_style', " .
   "goods_sn = '$goods_sn', " .
   "cat_id = '$catgory_id', " .
   "brand_id = '$brand_id', " .
   "shop_price = '$shop_price', " .
   "market_price = '$market_price', " .
   "is_promote = '$is_promote', " .
   "promote_price = '$promote_price', " .
   "promote_start_date = '$promote_start_date', " .
   "promote_end_date = '$promote_end_date', ";
   
   if ($goods_img)
   {
$sql .= "goods_img = '$goods_img', original_img = '$original_img', ";
   }
   if ($goods_thumb)
   {
$sql .= "goods_thumb = '$goods_thumb', ";
   }
   if ($code != '')
   {
$sql .= "is_real=0, extension_code='$code', ";
   }
   $sql .= "keywords = '$_POST[keywords]', " .
"goods_brief = '$_POST[goods_brief]', " .
"seller_note = '$_POST[seller_note]', " .
"goods_weight = '$goods_weight'," .
"goods_number = '$goods_number', " .
"warn_number = '$warn_number', " .
"min_number = '$min_number', " .
"integral = '$_POST[integral]', " .
"give_integral = '$give_integral', " .
"rank_integral = '$rank_integral', " .
"is_best = '$is_best', " .
"is_new = '$is_new', " .
"is_hot = '$is_hot', " .
"is_on_sale = '$is_on_sale', " .
"is_alone_sale = '$is_alone_sale', " .
"goods_desc = '$_POST[goods_desc]', " .
"last_update = '". gmtime() ."', ".
"goods_type = '$goods_type' " .
"WHERE goods_id = '$_REQUEST[goods_id]' LIMIT 1";
 }
步骤四,修改后台模板文件(在市场价会员价  后边添加设置很小起订量)
admin/templates/goods_info.htm
<tr>
<td class="label">{$lang.lab_shop_price}</td>
<td><input type="text" name="market_price" value="{$goods.shop_price}" size="20" />
<input type="button" value="{$lang.integral_market_price}" onclick="integral_market_price()" />{$lang.require_field}</td>
</tr>
添加
<!-- 新增 批发数量限制 begin --> 
<tr> 
<td class="label">{$lang.lab_min_number}</td> 
<td><input type="text" name="min_number" value="{$goods.min_number}" size="20" />
<span class="notice-span" {if $help_open}style="display:block" {else} style="display:none" mce_style="display: none;" {/if} id="minNumber">{$lang.notice_min_number}</span>
</td>
</td>
</tr>
<!-- 批发数量限制 end -->
步骤五,修改语言languages/zh_cn/admin/goods.php
最后添加
$_LANG['lab_min_number']= '很小购买数量:';
$_LANG['notice_min_number']= '该商品很小购买数量,0表示按购买数量制.'
到现在位置 后台设置全部结束了,不知道大家能懂了没有
下面我门说说前台如何来实现
我以default模板为例子给大家讲解
想做起订量限制,这个必然是在商品购买页面  购买数量框来做限制 最简单的办法就是用JS当然还有别的办法
首先给那些如果给了起订量的商品  购买页面直接显示默认最少购买数量
如果在后台设置的AA商品最少5个那么进入AA商品页面购买数量默认值就是5
我这样来实现
修改themes/default/goods.dwt
<input name="number" type="text" id="number" value="1" size="4" onBlur="changePrice()" style="border:1px solid #ccc; " mce_style="border: 1px solid #ccc;"/>
改成
<input name="number" type="text" id="number" value="{$goods.min_number|default:"1"}" size="4" onblur="changePrice()" style=”border:1px solid #ccc; " mce_style="border: 1px solid #ccc;"/><br />
这样就是value  也就是默认值了 
最后添加JS判断就好了
themes/default/goods.dwt
var qty = document.forms['ECS_FORMBUY'].elements['number'].value;
后添加
{if $goods.min_number}
if(qty < {$goods.min_number})
{
alert('您输入的数字小于此商品很小购买数量:{$goods.min_number}');
qty = {$goods.min_number};
}
{/if}

本文标签:

很赞哦! ()

相关源码

  • (响应式)wordpress模板VieuV4.5主题资讯自媒体博客源码Vieu主题专注于个人博客与企业展示场景,采用响应式设计确保在手机、电脑、平板等多设备上的展示。主题集成会员中心、投稿系统、内容保护等实用功能,满足现代博客网站的建设需求。查看源码
  • 帝国cms7.5大型游戏资讯门户网站源码免费下载本模板基于帝国CMS7.5内核开发,为大型游戏资讯门户网站设计。模板自带响应式手机版,适配多种终端设备。内容架构针对游戏行业特点优化,支持游戏资讯、评测、攻略等内容类型的发布与管理。查看源码
  • (自适应响应式)html5蓝色智能水表营销型网站pbootcms模板下载PbootCMS内核开发,为智能水表企业打造的营销型网站解决方案,本模板基于PbootCMS内核开发,为智能水表及相关行业企业设计,采用HTML5+CSS3技术构建,具有响应式布局。查看源码
  • (PC+WAP)绿色资源回收新能源环保设备pbootcms源码下载基于PbootCMS系统深度开发的环保行业模板,特别适配资源回收设备、新能源技术、环境治理装备等企业的线上展示需求。集成产品库、解决方案、环保案例等专业模块,助力企业高效传递绿色价值。查看源码
  • (自适应响应式)家电维修清晰服务网站pbootcms模板免费下载本模板基于PbootCMS内核开发,为维修服务类企业打造,特别适合家电维修、设备维护等行业使用。通过简洁直观的界面设计,帮助企业快速搭建专业级服务平台,实现线上业务高效管理。查看源码
  • (自适应)html5宽屏电线电缆材料加工制造类企业网站源码下载本模板基于PbootCMS系统开发,特别适合电线电缆、电缆材料及相关加工制造类企业使用。采用HTML5宽屏设计,能够展示各类电缆产品的技术参数和规格详情,帮助客户全面了解产品特性。查看源码
分享笔记 (共有 篇笔记)
验证码:

本栏推荐