Asp classic 在经典asp中显示多个产品。使用数据库

Asp classic 在经典asp中显示多个产品。使用数据库,asp-classic,Asp Classic,我有一个这样的访问表:有100个产品 Product Id, Product Name, Image Path, Price 我可以使用asp代码轻松地在我的网页上显示这些产品 我想在每个产品下添加一个按钮,允许用户将产品添加到购物车 我的页面一次显示30个项目。这是我的网页的HTML。当我点击任何按钮时,我调用下面提到的JavaSCTIPT函数来提交表单 <table class="retail"> <tr> <td

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

Product Id, 
Product Name, 
Image Path, 
Price
我可以使用asp代码轻松地在我的网页上显示这些产品

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

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

<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();
}

“width=“125”height=“125”/>
0.00美元
函数调用(对象、详细信息、产品id、价格){
var prodnm=document.getElementById(“productid”);
prodnm.value=prod_id;
var itemprice=document.getElementById(“价格”);
itemprice.value=价格;
var trollyform=document.getElementById(“trollyform”);
document.forms[“trollyform”].submit();
}

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

<%

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

对此,我得到的答复是:

我的页面显示了30个项目,如果我单击任何“添加到购物车”按钮,它会给我这个值。因此,我单击的按钮,它会给我这个值,但它也会给我逗号分隔的其他值

产品代码值:RNG-2、、、和, 价格值:10、、、、、、、、

基本上,第一个值是我为该页面上的其他产品单击的按钮的值,它给了我逗号
<a href="cart.asp?mode=add&itemID=<%=rs("Product Id")%>">Add to Cart</a>

类似于这样的情况,rs是您循环使用的记录集,“cart.asp”“是一个专为管理购物车而设计的页面。

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

<a href="<%=Request.ServerVariables("SCRIPT_NAME")%>?mode=add&itemID=<%=rs("Product Id")%>">Add to Cart</a>

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

您使用产品Id。它肯定是主键,将唯一标识每个产品,对吗?如果
产品id
不是主键,则创建一个通常为随机id的id,或者您可以使用autocrement值,这将要求您在表中创建一个新字段。只是一个旁注:您是否考虑过在每篇文章旁边加一个复选框和一个“全局”添加到购物车按钮?问题是用多个值填充表单输入“productid”。你发布的代码是整页代码吗?如果不是全部发布。我只有一个ASP,我在那里做所有的事情。原因是,我想在左边显示购物车项目。所以,这都是一页导航的东西。我简单地这样做:-创建DB连接-根据用户单击的链接读取表,这样我在页面中就有条件进入该选择的代码块:我列出了一个选择的代码,我的页面目前显示了30个项目。@user1122575首先,不要喊。可以使用编辑器中的“代码格式”图标发布代码。第二,你可以在一个页面上完成这一切。我很快会发布我自己的答案。谢谢大家,请在我的原始邮件中查看代码。。请回复和帮助。
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