php商品在最少购买,ECSHOP给商品设置最少购买数量的方法

ecshop后台默认没有给商品设置最小起订量或者最少购买量的功能。保哥在使用ecshop做一个商城时,要给商品设置包邮来吸引买家,但又不想买家购买一件产品也给包邮,这样很容易亏本。对于价值较高的商品有一定的利润空间设置包邮是合情合理的,但是有的商品价格都低于运费了,就不能再包邮了。有的朋友可能会说,可以发布商品属性价格,不同数量装的价格或者发布商品时,设置十个装的价格,但是这样的话,买家一眼看到商品上显示的价位太高,可能心理上就不愿意再看了。我们设置一件商品的价格,这样在心理上感觉便宜。具体的解决思路是可以给ecshop在下订单设置一个强制提示最小购买数量。具体的解决步骤如下:

编辑/themes/goods.dwt文件,找到以下代码:

替换为以下代码:

但是这种方法会使得全站所有的商品购买数量都设置为不低于十个,不太人性化。那么下面这种修改数据库的方法,可以在后台产品编辑时,设置每个商品的最小购买数量。具体方法如下:

第一步,给商品表创建一个新字段min_number用于储存每个商品的最小订购数量数据,打开goods表在最后字段添加一个min_number类型为tinyint默认值为0

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

{$lang.lab_shop_price}

{$lang.require_field}

后添加

{$lang.lab_min_number}

{$lang.notice_min_number}

第五步:修改语言languages/zh_cn/admin/goods.php

最后添加

$_LANG['lab_min_number'] = '最小购买数量:';

$_LANG['notice_min_number'] = '该商品最小购买数量,0表示按购买数量无限制.'

到现在位置 后台设置全部结束了,不知道大家能懂了没有

前台实现:

以default模板为例,修改themes/default/goods.dwt

改成

这样就是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}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/543111.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Crawler - 如何爬取列表后进行文章的爬取

2019独角兽企业重金招聘Python工程师标准>>> 已知BUG&#xff1a;(version:5) 1-爬取后生成的XML默认编码是Java环境决定导入数据库可能出问题 方法修改xml编码后导入 重点CL 和 CI命令 CL 是爬取List列表 会通过file生成文件 CI 中file是CL执行后生存的File文件 CL…

程序员出差是去干什么_让我来告诉你,35岁以上的人都在干什么!

欢迎关注专栏&#xff1a;里面定期分享Android和Flutter架构技术知识点及解析&#xff0c;还会不断更新的BATJ面试专题&#xff0c;欢迎大家前来探讨交流&#xff0c;如有好的文章也欢迎投稿。Android高级进阶​zhuanlan.zhihu.com让我来告诉你&#xff0c;35岁以上的人都在干什…

oracle v¥bh,【oracle笔记2】约束

约束*约束是添加在列上的&#xff0c;用来约束列的。1. 主键约束(唯一标识)***非空******唯一******被引用***(外键时引用主键)*当表的某一列被指定为主键后&#xff0c;该列就不能为空&#xff0c;不能有重复的出现。*创建表时指定主键的两种方式&#xff1a;>create table…

WAP端 touch事件触发顺序记录

IOS7.0 safari 滚动滚动条的时候, 最后手指放开 (scroll 总是在 touchend后面&#xff0c;所以要用 setTimeout)   touchstart touchmove&#xff08;多个&#xff09; touchend scroll&#xff08;一个&#xff09;IOS8.4 safari 滚动滚动条的时候   touchstart touchmove…

opencv入门_【OpenCV入门之十八】通过形态学操作提取水平与垂直线

小白导读学习计算机视觉最重要的能力应该就是编程了&#xff0c;为了帮助小伙伴尽快入门计算机视觉&#xff0c;小白准备了【OpenCV入门】系列。新的一年文章的内容进行了很大的完善&#xff0c;主要是借鉴了更多大神的文章&#xff0c;希望让小伙伴更加容易理解。如果小伙伴觉…

php strstr 从尾部,PHP strstr() 和 strrchr() 详解

strstr() 和 strrchr()有一定的相似性&#xff0c;所以放在一起。strstrstrstr ( string $haystack , mixed $needle [, bool $before_needle FALSE ] ) : stringneedle 可以为单个字符&#xff0c;也可以是个字符串。返回 needle 在 haystack 在第一次出现的位置到结束&#…

python计算结果传给spark_Spark入门:流计算简介(Python版)

数据总体上可以分为静态数据和流数据。对静态数据和流数据的处理&#xff0c;对应着两种截然不同的计算模式&#xff1a;批量计算和实时计算。批量计算以“静态数据”为对象&#xff0c;可以在很充裕的时间内对海量数据进行批量处理&#xff0c;计算得到有价值的信息。Hadoop就…

【译】NoClassDefFoundError和ClassNotFoundException的不同

本文翻译自&#xff1a;Difference between NoClassDefFoundError vs ClassNotFoundExcepiton in Java 如果JVM或者ClassLoader在加载类时找不到对应的类&#xff0c;就会引发NoClassDefFoundError和ClassNotFoundException&#xff0c;这两种错误都非常严重。由于不同的ClassL…

oracle怎么设置出蓝色边,Oracle 数据库入门之———————-,多行函数-蓝色留心...

2&#xff0c;多行函数SQL> –工资总额SQL> select sum(sal) from emp;SUM(SAL)29025SQL> –人数SQL> select count(*) from emp;COUNT(*)14SQL> –平均工资SQL> select sum(sal)/count(*) 一,avg(sal) 二 from emp;一 二2073.21429 2073.21429SQL> –平均…

python绘制剖面图_用python绘制剖面图

我自己为这个功能做了一个模块。在import pandas as pdfrom pandas import Series, DataFrameimport numpy as npimport matplotlib.pyplot as pltdef Profile(x,y,nbins,xmin,xmax,ax):df DataFrame({x : x , y : y})binedges xmin ((xmax-xmin)/nbins) * np.arange(nbins1…

Ubuntu上安装Robomongo及添加到启动器

到目前为止&#xff0c;Robomongo仍是MongoDB最好的客户端管理工具&#xff0c;如需在Ubuntu上安装Robomongo&#xff0c;可直接从官网下载.tar.gz压缩包进行解压&#xff0c;然后直接运行bin目录下的robomongo文件即可启动界面。例如我将下载下来的.tar.gz压缩包解压到/usr/lo…

python打开手机网页_Python3 Windows服务器简单实现 手机访问

设备1. PC with Win102. Python 3.5.1步骤打开CMD&#xff0c;cd 到e盘&#xff0c;mkdir pythonWebserver 建立文件夹//在E盘建立文件夹&#xff0c;作为服务器的根目录。如:e:\pythonWebserver直接输入命令&#xff1a;python -m http.server 8000//以默认的地址——本地ip&a…

oracle开归档服务器,ORACLE RAC 启用归档

ORACLE RAC 启用归档1、关闭所有节点数据库实例c:\>srvctl stop database -d apts2、修改服务器配置参数sql>startup mountsql>alter system set cluster_databasefalse scopespfile;sql>shutdown immediate3、调整归档日志路径sql>startup mountsql>alter s…

pagefile.sys and heberfil.sys

dub 删除heberfil.sys大文件的方法 方法1:Windows/system32中的cmd.exe 输入 powercfg -h off&#xff0c;即可关闭休眠功能&#xff0c;同时 Hiberfil.sys 文件也会自动删除。 方法2:运行命令gpedit.msc打开策略组 依次打开Computer Configuration——Administrative Template…

加密生成指定长度_3分钟短文 | PHP伪随机Token生成器,实地测试,效果感人!

引言我们经常可能会用到邀请码&#xff0c;邮件验证码&#xff0c;或者需要使用unique 字符串标记用户属性的情况。今天我们且不说高深的“全局唯一ID”的生成方案&#xff0c;我们说一个简单的&#xff0c;如何生成一个唯一的&#xff0c;随机的&#xff0c;数组字母组成的字符…

《Java高级程序设计》期末作业【2】-进度安排

计算器项目计划进度安排&#xff1a; 项目成员&#xff1a;潘世林 何青 柴晓光 张峰转载于:https://www.cnblogs.com/panshilin/p/5578496.html

python find不区分大小写_牛鹭学院:Python基础了解

本文来自牛鹭学院学员&#xff1a;田雨python初印象Python 是一种解释型语言&#xff1a; 这意味着开发过程中没有了编译这个环节。类似于PHP和Perl语言。Python 是交互式语言&#xff1a; 在一个 Python 提示符 >>> 后直接执行代码。Python 是面向对象语言: 这意味着…

linux内核升级写入不了,解决linux内核升级后不能重启系统的故障

1.闲来无事&#xff0c;想升级下centos的内核。升级方法就不多讲了。2.升级完后&#xff0c;重启系统&#xff0c;发现系统无法启动&#xff0c;具体原因是系统无法挂载文件系统。3.在网上找了下资料&#xff0c;原因出在了initrd是旧版本mkinitrd生成的。所以导致文件系统无法…

Spring+Quartz(一)

2019独角兽企业重金招聘Python工程师标准>>> Quartz是一个非常优秀的任务调度引擎&#xff0c;详情请见官网:http://www.quartz-scheduler.org/ 而Spring很好地集成了Quartz&#xff0c;为企业级的任务调度提供了方便。 下面先看一个实现了Job接口的任务HelloWorldJ…

python struct pack解析_Python struct 详解

最近在学习python网络编程这一块&#xff0c;在写简单的socket通信代码时&#xff0c;遇到了struct这个模块的使用&#xff0c;当时不太清楚这到底有和作用&#xff0c;后来查阅了相关资料大概了解了&#xff0c;在这里做一下简单的总结。了解c语言的人&#xff0c;一定会知道s…