首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在经典asp中展示多个产品。使用数据库

在经典asp中展示多个产品。使用数据库
EN

Stack Overflow用户
提问于 2011-12-30 15:44:57
回答 2查看 947关注 0票数 0

我有一个这样的访问表:有100个产品

代码语言:javascript
复制
Product Id, 
Product Name, 
Image Path, 
Price

我可以很容易地使用asp代码在我的网页上显示这些产品。

我想在每个产品下添加一个按钮,这将允许用户将产品添加到购物车。

我的页面一次显示30个项目。这是我的页面的HTML。当我点击任何按钮时,我会调用下面提到的java sctipt函数来提交表单。

代码语言:javascript
复制
<table class="retail">
        <tr>
            <td>
                <img src="images/<%=rs.fields("image")%>" width="125" height="125"/>
            <td>
        </tr>
        <tr><td>&nbsp;</td></tr>
        <tr>
            <td style="font-weight: bold;color: #151B8D;text-align: center;font-size: 10px; padding: 5px 5px 5px 5px;">
                <%=rs.fields("details")%>
            <td>
        </tr>
        <tr><td>&nbsp;</td></tr>
        <tr>
            <td style="font-weight: bold;color: red;text-align: center;font-size: 14px; padding: 0px 1px 1px 1px;">
                <%=rs.fields("productid")%>
            <td>
        </tr>
        <tr><td>&nbsp;</td></tr>
        <tr>
            <td style="font-weight: bold;color: red;text-align: center;font-size: 16px; padding: 0px 1px 1px 1px;">
                USD $<%=rs.fields("price")%>.00
            </td>
            <input type="hidden" id="details" name="details"/>
            <input type="hidden" id="productid" name="productid"/>
            <input type="hidden" id="price" name="price"/>
        </tr>
        <tr>
        <td>
         <input type="button" value="Add to Trolly" id="cmdAdd" name="cmdAdd" onClick="javascript:callMe(this,'<%=rs.fields("details")%>','<%=rs.fields("productid")%>','<%=rs.fields("price")%>')"/>
        </td>
        </tr>
    </table>




<SCRIPT LANGUAGE="JavaScript">
function callMe(obj,details,prod_id,price) {
    var prodnm = document.getElementById("productid");
    prodnm.value = prod_id;

    var itemprice = document.getElementById("price");
    itemprice.value = price;

    var trollyform = document.getElementById("trollyform");

    document.forms["trollyform"].submit();
}

THis是我用来检查表单提交值的代码:

代码语言:javascript
复制
<%

Response.Write "<br>Product Code value : " & request.Form("productid")
Response.Write "<br>Price value : " & request.Form("price")

%>

作为回应,我得到了这个:

我的页面显示30个项目,如果我点击任何添加到购物车按钮,它会给我这个。因此,我点击的按钮,它为我提供了值,但它也为我提供了逗号分隔的rest值

产品代码值: RNG-2,,,

基本上,第一个值是我为该页面上的其他产品单击的按钮的值,它会给我提供逗号

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2012-01-01 16:13:38

如果这是您关心的问题,您可以在一个页面中完成所有这些操作。代码posted by cavillac是一个很好的开始,而不是指向不同的页面,只指向相同的页面,但仍然有查询字符串值来指示要添加的产品:

代码语言:javascript
复制
<a href="<%=Request.ServerVariables("SCRIPT_NAME")%>?mode=add&itemID=<%=rs("Product Id")%>">Add to Cart</a>

现在在你的页面中,有这样的代码块:

代码语言:javascript
复制
If Request.QueryString("mode")="add" Then
    productID = Request.QueryString("itemID")

    If IsNumeric(productID) Then
        arrCurrentCart = Session("UserCart")
        If IsArray(arrCurrentCart) Then
            ReDim Preserve arrCurrentCart(UBound(arrCurrentCart) + 1)
        Else
            ReDim arrCurrentCart(0)
        End If
        arrCurrentCart(UBound(arrCurrentCart)) = productID
        Session("UserCart") = arrCurrentCart

        Response.Write("item added to cart")
        Response.END
    End If
End If

这是一个非常基本的示例,使用普通数组作为会话变量来存储添加的项-希望用意是明确的。

票数 1
EN

Stack Overflow用户

发布于 2011-12-31 03:08:52

代码语言:javascript
复制
<a href="cart.asp?mode=add&itemID=<%=rs("Product Id")%>">Add to Cart</a>

类似这样,其中rs是您正在遍历的记录集,而"cart.asp“是一个用来管理购物车的页面。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/8677310

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档