该模块采用Springmvc+spring+mybatis实现:
首先点击商品首页链接,从后台加载商品信息至商品详情页。
从后台加载商品信息代码如下:
  @RequestMapping(value="/product/detail.shtml")
public String detail(Integer id,String name, ModelMap model){
Product product = productService.getProductByKey(id);//包含img
List<Sku> skus = skuService.getStock(id);
List<Color> c = new ArrayList<Color>(); //去掉重复颜色
for (Sku sku : skus) {//重写equals方法
if(!c.contains(sku.getColor())){ //判断集合是否包含此颜色
c.add(sku.getColor());
}
}
model.addAttribute("skus",skus);
model.addAttribute("product",product);
model.addAttribute("colors",c);
return "/product/productDetail";
} mybatis对应sql:
    <select id="getStock" parameterType="Integer" resultMap="sku">
select
id,product_id,color_id,size,delive_fee,sku_price,stock_inventory,sku_upper_limit,location,sku_img,sku_sort,sku_name,market_price,create_time,update_time,create_user_id,update_user_id,last_status,sku_type,sales
FROM bbs_sku
<where>
stock_inventory > 0 and product_id = #{productId}
</where>
</select>

 
商品详情页,颜色尺码联动及购买数量选择js代码:
<script type="text/javascript">
$(function(){
//初始化点击第一个颜色 jquery
$("#colors a:first").trigger("click"); //初始化点击第一个颜色
$("#sub").click(function(){
var num = $("#num").val();
num--;
if(num == 0){
return;
}
//赋值
$("#num").val(num);
});
$("#add").click(function(){
var num = $("#num").val();
num++;
if(num>buyLimit){
alert("此商品一次只能买"+buyLimit+"件");
return;
}
$("#num").val(num);
});
});
//全局变量
var colorId ;
var skuId;
var buyLimit;
function colorToRed(target,id){
colorId = id;
$("#colors a").each(function(){ //colors下的a标签 通过id修改
$(this).attr("class","changToWhite");
});
//先清理尺码 都变成不可点
$("#sizes a").each(function(){
$(this).attr("class","not-allow");
});
var flag = 0;
$(target).attr("class","changToRed");
<c:forEach items="${skus}" var="sku">
if('${sku.colorId}' == id){
if(flag == 0){ //默认第一个为选中
$("#"+'${sku.size}').attr("class","changToWhite");
$("#"+'${sku.size}').attr("class","changToRed");
flag = 1;
$("#price").html("¥"+'${sku.skuPrice}');
$("#mprice").html("¥"+'${sku.marketPrice}');
$("#fee").html("¥"+'${sku.deliveFee}');
$("#stockInventory").html("¥"+'${sku.stockInventory}');
skuId = '${sku.id}';
buyLimit = '${sku.skuUpperLimit}';
}else{
$("#"+'${sku.size}').attr("class","changToWhite");
}
}
</c:forEach>
}
function sizeToRed(target,id) {
var cc = $(target).attr("class");
if(cc=="not-allow"){
return;
}
//先清理尺码 都变成未选状态
$("#sizes a").each(function(){
var c = $(this).attr("class");
if(c!="not-allow"){
$(this).attr("class","changToWhite");
}
});
// 变红
$(target).attr("class","changToRed"); <c:forEach items="${skus}" var="sku">
if('${sku.colorId}' == colorId && id== '${sku.size}' ){
$("#price").html("¥"+'${sku.skuPrice}');
$("#mprice").html("¥"+'${sku.marketPrice}');
$("#fee").html("¥"+'${sku.deliveFee}');
$("#stockInventory").html("¥"+'${sku.stockInventory}');
skuId = '${sku.id}';
buyLimit = '${sku.skuUpperLimit}';
}
</c:forEach>
}
</script>

商品详情页代码:
<div class="r" style="width: 640px">
<ul class="uls form">
<li><h2>${product.name }</h2></li>
<li><label>巴 巴 价:</label><span class="word"><b class="f14 red mr" id="price">¥144</b>(市场价:<del id="mprice">¥150.00</del>)</span></li>
<li><label>商品评价:</label><span class="word"><span class="val_no val3d4" title="4分">4分</span><var class="blue">(已有888人评价)</var></span></li>
<li><label>运  费:</label><span class="word" id="fee">10元</span></li>
<li><label>库  存:</label><span class="word" id="stockInventory">100</span><span class="word" >件</span></li>
<li><label>选择颜色:</label>
<div id="colors" class="pre spec">
<c:forEach items="${colors}" var="color">
<a onclick="colorToRed(this,${color.id})" href="javascript:void(0)" title="${color.name }" class="changToWhite"><img width="25" height="25" data-img="1" src="/res/img/pic/ppp00.jpg" alt="${color.name } "><i>${color.name }</i></a>
</c:forEach>
</div>
</li>
<li id="sizes"><label>尺  码:</label>
<a href="javascript:void(0)" onclick="sizeToRed(this,'S')" class="not-allow" id="S">S</a>
<a href="javascript:void(0)" onclick="sizeToRed(this,'M')" class="not-allow" id="M">M</a>
<a href="javascript:void(0)" onclick="sizeToRed(this,'L')" class="not-allow" id="L">L</a>
<a href="javascript:void(0)" onclick="sizeToRed(this,'XL')" class="not-allow" id="XL">XL</a>
<a href="javascript:void(0)" onclick="sizeToRed(this,'XXL')"class="not-allow" id="XXL">XXL</a>
</li>
<li><label>我 要 买:</label>
<a id="sub" class="inb arr" style="border: 1px solid #919191;width: 10px;height: 10px;line-height: 10px;text-align: center;" title="减" href="javascript:void(0);" >-</a>
<input id="num" type="text" value="1" name="" size="1" readonly="readonly">
<a id="add" class="inb arr" style="border: 1px solid #919191;width: 10px;height: 10px;line-height: 10px;text-align: center;" title="加" href="javascript:void(0);">+</a></li>
<li class="submit"><input type="button" value="" class="hand btn138x40" onclick="buy(${product.id});"/><input type="button" value="" class="hand btn138x40b" onclick="addCart()"/></li>
</ul>
</div>
 

js实现商品颜色尺码联动以及购买数量的选择的更多相关文章

  1. 服装盘点机PDA在服装行业颜色尺码仓库条码高效管理应用

    服装行业的商品管理的特点是需要管理颜色和尺码 具体逻辑就是: 什么商品,什么颜色,什么尺码,入库多少个? 什么商品,什么颜色,什么尺码,出库多少个? 什么商品,什么颜色,什么尺码,还有库存多少个? 如 ...

  2. JS Select 月日日期联动

    Js对Select控件进行联动操作,一个select选择月份后另一个select生成对应月份的所有日期. <%@ Page Language="C#" AutoEventWi ...

  3. Codrops 实验:使用 Vibrant.js 提取图像颜色

    Codrops 分享了一个有趣的颜色提取实验.这个想法是创建图像的调色板,既有图像本身的潜移默化的影响,也有一些花哨的颜色延伸.通过使用 Vibrant.js 来提取图像中的颜色,并通过 CSS 过滤 ...

  4. 关于更改MYECLIPSE JS 代码背景颜色

    白色的背景,看花了眼,你想改一下编辑器的背景颜色,移步这里就可以了. 这时你高兴的打开编辑器,发现颜色确实变了,但是当你打开有JS的JSP时,你碉堡了,发现JS的背景颜色还是默认的, 看着让人纠结,好 ...

  5. JS年月日三级联动下拉框日期选择代码

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  6. js获取背景颜色

    //js获取背景颜色var Airport=$("#Airport").css('background-color'); js设置背景颜色 $("#intercity&q ...

  7. 纯js做的select二级联动

    分步阅读 select 联动用到的范围很广,下面介绍一下简单的二级联动 方法/步骤   做一个简单的html页面,用于显示select联动,如图所示:   设置js,点击一级选择项时,创建其下对应的二 ...

  8. JS实现随机颜色的3种方法与颜色格式的转化

    JS实现随机颜色的3种方法与颜色格式的转化   随机颜色和颜色格式是我们在开发中经常要用到的一个小功能,网上相关的资料也很多,想着有必要总结一下自己的经验.所以这篇文章主要介绍了JS实现随机颜色的3种 ...

  9. js点击某个图标或按钮弹出文件选择框

    <HTML> <head> <script type="text/javascript" src="script/jquery-1.6.2. ...

随机推荐

  1. vmware三种网络模式:桥接模式|仅主机|NAT模式

    VMware 网络模式 1. Bridged(桥接)桥接模式下,宿主机物理网卡(主机网卡)和虚拟网卡通过 VMnet0 虚拟交换机进行桥接,物理网卡和虚拟网卡在拓扑图上处于同等地位,物理网卡和虚拟网卡 ...

  2. uva-10720-贪心

    题意:对于一个简单图(不存在平行边和自旋边),输入所有的点的度,问,能不能变成一个简单图. 解题思路: 可图化定理.https://blog.csdn.net/shuangde800/article/ ...

  3. HPROF - Heap Profile

    基于动态链接库实现,可用于性能分析,锁内容.诊断memory leak问题等.获得堆开辟信息 java -agentlib:hprof=heap=sites ToBeProfiledClass 帮助文 ...

  4. 一些被提问频率最高的12个php面试题,以及对应的常规回答。

    一些被提问频率最高的12个php面试题,以及对应的常规回答.1.问题:请用最简单的语言告诉我php是什么?回答:php全称:hypertext preprocessor,是一种用来开发动态网站的服务器 ...

  5. jquery轮播图片(无插件简单版)

    轮播图(第三版)[2016-2-26] 工作中用的,改写了半透明蒙版,可以兼容ie7 <script type="text/javascript" src="htt ...

  6. 36. Oracle查询数据库中所有表的记录数

    select t.table_name,t.num_rows from user_tables t

  7. python Requests库网络爬取IP地址归属地的自动查询

    #IP地址查询全代码import requestsurl = "http://m.ip138.com/ip.asp?ip="try: r = requests.get(url + ...

  8. 图片 base64转byte[]

    /// <summary> /// 保存base64图片,返回阿里云地址 /// </summary> /// <param name="imgCode&quo ...

  9. 一个Tparams小测试

    var aParams: TParams; aPar: TParam; I:Integer; begin aParams := TParams.Create(nil); aPar := aParams ...

  10. Linux ftp软件安装、配置和启动

    ftp软件安装.配置和启动及相关问题的解决在测试环境使用过程中经常使用.本文以SuSE11sp1上vsftpd的安装过程进行介绍. 测试环境 SuSE11sp1 vsftp软件安装检查 1.rpm - ...