• Jquery快速构建可拖曳的购物车DragDrop


    拖曳功能早已经成为各个网站吸引用户的一大亮点,那有没有想过如何把拖曳功能应用到电子商务网站的购物车功能模块中呢? 这样一来,购买者只需要把自己感兴趣的商品拖曳到自己的购物车中,也可以从购物车中删除商品 同时更新购物车的总体价格和数量。

    那咱们就开始实例吧,本实例并没有链接数据库读取数据来初始化Products,而是创建了一些虚拟的商品如下:

     

    1、  创建Product实体类

     

    public class Product

        {

            public string Code { get; set;  }

            public string Name { get; set; }

            public string Description { get; set; }

            public double Price { get; set; }

    }

     

    2、  构建商品List<Product>

     

    public class Product

        {

            public string Code { get; set;  }

            public string Name { get; set; }

            public string Description { get; set; }

            public double Price { get; set; }

    }

     

    3、创建DataList并绑定List<Product>

     

    <asp:DataList ID="dlProducts" RepeatColumns="3"

             RepeatDirection="Horizontal" runat="server">

     

        <ItemTemplate>

     

        <div class="productItemStyle" price='<%# Eval("Price") %>'

             code='<%# Eval("Code") %>'  id='item_<%# Container.ItemIndex + 1 %>'>

        <li>

        <%# Eval("Code") %>

        </li>

        <li>

        <%# Eval("Name") %>

        </li>

        <li>

        <%# Eval("Description") %>

        </li>

     

         <li>

        $<%# Eval("Price") %>

        </li>

        </div>

     

        </ItemTemplate>

     

        </asp:DataList>

     

    private void BindData()

    {

        var products = GetProducts();

     

        dlProducts.DataSource = products;

        dlProducts.DataBind();

    }

     

    productItemStyle 样式名称

    Container.ItemIndex动态生成连续的商品编号

     

    4、  生成Products Div Draggable

    下载最新的Jquery JS文件及其UI文件:

    <script language="javascript" type="text/javascript" src="jquery-1.2.6.min.js"></script>

    <script language="javascript" type="text/javascript"

    src="jquery-ui-personalized-1.6rc4.min.js"></script>

     

    页面初始化时生成Div Draggable

     

    $(document).ready(function() {

     

            $(".productItemStyle").draggable({ helper: "clone", opacity: "0.5" });

    )};

     

    5、创建一个DropZone

     

    DropZones 是购物车区域

     

    $(".dropZone").droppable(

            {

                accept: ".productItemStyle",

                hoverClass: "dropHover",

                drop: function(ev, ui) {

     

                    var droppedItem = ui.draggable.clone().addClass("droppedItemStyle");

     

                    var productCode = droppedItem[0].attributes["code"].nodeValue;

                    var productPrice =

                     getFormattedPrice(droppedItem[0].attributes["price"].nodeValue);

     

                    var removeLink = document.createElement("a");

                    removeLink.innerHTML = "Remove";

                    removeLink.className = "deleteLink";

                    removeLink.href = "#";

                    removeLink.onclick = function()

                    {

                        $(".dropZone").children().remove("#" + droppedItem[0].id);

                        updateTotal(productPrice * (-1));

                    }

     

                    droppedItem[0].appendChild(removeLink);

     

                    $(this).append(droppedItem);

     

                    updateTotal(productPrice);

                }

            }

            );

     

    Accept参数:展示Class= productItemStyleDiv

    hoverClass参数:当有Product放到DropZone时的样式

    drop函数:当Product拖放到DropZone时出发的函数,此函数主要做了一个Product ItemClone,价格的计算、添加Remove按钮以及到点击Remove按钮时所触发的事件。

     

    价格的计算updateTotal()函数

    // update the total!

        function updateTotal(price) {

     

            total += parseFloat(price);

            $("#total").html(total.toFixed(2));

            $(".shoppingCartTotal").effect("bounce");

     

    }

     

    最终效果如下图:

     

     

     

    英文原文地址:http://www.codeproject.com/KB/aspnet/JQueryShoppingCart.aspx

     

  • 相关阅读:
    从源码角度看MySQL memcached plugin——3. containers表的管理
    从源码角度看MySQL memcached plugin——2. 线程模型和连接的状态机
    从源码角度看MySQL memcached plugin——1. 系统结构和引擎初始化
    从源码角度看MySQL memcached plugin——0.大纲
    关注博客
    文摘
    MySQL—FTS实现原理介绍PPT
    GIT情况展示说明
    final发布48小时用户调查报告
    final版本发布评价II
  • 原文地址:https://www.cnblogs.com/ywqu/p/1613367.html
Copyright © 2020-2023  润新知