菜鸟问题,请高手解答。

lifeiwen 2009-08-18 11:24:44
我用gridview绑定数据库,并写了页面部分,数据库中“ID”值我设为空的(因为不知道gridview的checkbox怎么用)
<Columns>
<asp:BoundField DataField="项目商品编号" HeaderText="项目商品编号" ReadOnly="true" />
<asp:BoundField DataField="项目商品名称" HeaderText="项目商品名称" ReadOnly="true" />
<asp:BoundField DataField="项目产品编号" HeaderText="项目产品编号" ReadOnly="true" />
<asp:BoundField DataField="中心产品编号" HeaderText="中心产品编号" ReadOnly="true" />
<asp:BoundField DataField="产品名称" HeaderText="产品名称" ReadOnly="true" />
<asp:BoundField DataField="生产厂家" HeaderText="生产厂家" ReadOnly="true" />
<asp:BoundField DataField="供应商" HeaderText="供应商" ReadOnly="true" />
<asp:BoundField DataField="配送商" HeaderText="配送商" ReadOnly="true" />
<asp:BoundField DataField="资料编号" HeaderText="资料编号" ReadOnly="true" />
<asp:CheckBoxField HeaderText="选择" DataField="ID" />
</Columns>
问题1出在checkbox在页面显示是灰色的,点击不了,请问是添加什么属性才能点击呢?
问题2,如何获取checkbox的值,知道选的是那一行,请高手提供几个函数。
问题3,如果在程序中使用数据库select操作,查找的数据为空,使用什么函数可以获取?
...全文
127 25 打赏 收藏 转发到动态 举报
写回复
用AI写文章
25 条回复
切换为时间正序
请发表友善的回复…
发表回复
threenewbee 2009-08-19
  • 打赏
  • 举报
回复
ReadOnly="true" 修改成 ReadOnly="false"
Checked属性
不清楚你问什么。""就是空。
liaoyukun111 2009-08-19
  • 打赏
  • 举报
回复
using System;
using System.Data;
using System.Configuration;
using System.Collections;
using System.Web;
using System.Web.Security;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.WebControls.WebParts;
using System.Web.UI.HtmlControls;
using System.Data.SqlClient;

public partial class gridview_fenpage : System.Web.UI.Page
{
protected void Page_Load(object sender, EventArgs e)
{
Button2.Attributes["onclick"] = "return slcNo_click();";
GridViewBind("");
}

private void GridViewBind(string Sqlsort)
{
string connStr = ConfigurationManager.ConnectionStrings["ConnString1"].ConnectionString;
string SqlStr = "SELECT * FROM test01 where id<1000" + Sqlsort;
DataSet ds = new DataSet();

try
{
SqlConnection conn = new SqlConnection(connStr);
if (conn.State.ToString() == "Closed") conn.Open();

SqlDataAdapter da = new SqlDataAdapter(SqlStr, conn);
da.Fill(ds, "test01");
if (conn.State.ToString() == "Open") conn.Close();

GridView1.DataSource = ds.Tables[0].DefaultView;
GridView1.DataBind();

LblCurrentIndex.Text = "第 " + (GridView1.PageIndex + 1).ToString() + " 页";
LblPageCount.Text = "共 " + GridView1 .PageCount.ToString()+ " 页";
LblRecordCount.Text = "总共 "+ds.Tables[0].Rows.Count.ToString()+" 条";
if (ds.Tables[0].Rows.Count == 0)
{
btnFirst.Visible = false;
btnPrev.Visible = false;
btnNext.Visible = false;
btnLast.Visible = false;

LblCurrentIndex.Visible = false;
LblPageCount.Visible = false;
LblRecordCount.Visible = false;
}
else if (GridView1.PageCount == 1)
{
btnFirst.Visible = false;
btnPrev.Visible = false;
btnNext.Visible = false;
btnLast.Visible = false;
}

// 计算生成分页页码,分别为:"首 页" "上一页" "下一页" "尾 页"
btnFirst.CommandName = "1";
btnPrev.CommandName = (GridView1.PageIndex == 0 ? "1" : GridView1.PageIndex.ToString());

btnNext.CommandName = (GridView1.PageCount == 1 ? GridView1.PageCount.ToString() : (GridView1.PageIndex + 2).ToString());
btnLast.CommandName = GridView1.PageCount.ToString();
//
}
catch(Exception ex)
{
Response.Write("数据库错误,错误原因:"+ex.Message);
Response.End();
}
}
protected void PagerButtonClick(object sender, EventArgs e)
{
GridView1.PageIndex = Convert.ToInt32(((LinkButton)sender).CommandName)-1;
GridViewBind("");
}

protected void GridView1_RowDataBound(object sender, GridViewRowEventArgs e)
{
e.Row.Attributes["onmouseover"] = "ItemOver(this)";
}

protected void Button2_Click(object sender, EventArgs e)
{
string str="";
string []ckb=null;

str=Request.Form.Get("checkboxname");
ckb=str.Split(new char[]{','});

Response.Write("直接在页面中得到的值为:"+str+"<br>");

Response.Write("处理后存放在数组中,如下:<br>");
for(int i=0;i<ckb.Length;i++)
{
Response.Write("ckb["+i+"]的值为:"+ckb[i]+"<br>");
}
}
protected void Button1_Click(object sender, EventArgs e)
{
Response.Write(Request.Form.Get("RadioName"));
}
protected void GridView1_Sorting(object sender, GridViewSortEventArgs e)
{
string sql = "";

if (ViewState["SortDirection"] == null || ViewState["SortDirection"].ToString().CompareTo("") == 0)
{
ViewState["SortDirection"] = " desc";
}
else
ViewState["SortDirection"] = "";

sql = " order by " + e.SortExpression + ViewState["SortDirection"];

GridViewBind(sql);
}
}
CREATE TABLE [dbo].[test01] (
[id] [decimal](18, 0) IDENTITY (1, 1) NOT NULL ,
[name] [varchar] (50) COLLATE Chinese_PRC_CI_AS NULL ,
[card] [varchar] (50) COLLATE Chinese_PRC_CI_AS NULL ,
[createdate] [datetime] NULL
) ON [PRIMARY]
GO

ALTER TABLE [dbo].[test01] ADD
CONSTRAINT [DF_test01_createdate] DEFAULT (getdate()) FOR [createdate],
CONSTRAINT [PK_test01] PRIMARY KEY CLUSTERED
(
[id]
) ON [PRIMARY]
GO
liaoyukun111 2009-08-19
  • 打赏
  • 举报
回复
<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
<title></title>

<script language="javascript" type="text/javascript">
// 判断多选是否与选中项(没有选中的返回false)
function slcNo_click()
{
if (document.form1.checkboxname.length)
{
for (var i=0;i<document.form1.checkboxname.length;i++)
{
if(document.form1.checkboxname[i].checked)
{
return true;
}
}
}
else
{
if(document.form1.checkboxname.checked)
{
return true;
}
}
alert("请选择后再操作!");
return false;
}

// 鼠标经过改变行的颜色
if (!objbeforeItem)
{
var objbeforeItem=null;
var objbeforeItembackgroundColor=null;
}
function ItemOver(obj)
{
if(objbeforeItem)
{
objbeforeItem.style.backgroundColor = objbeforeItembackgroundColor;
}
objbeforeItembackgroundColor = obj.style.backgroundColor;
objbeforeItem = obj;
obj.style.backgroundColor = "#B9D1F3";
}
//

// 多选的全选与取消
function checkJs(boolvalue)
{
if(document.all.checkboxname.length>1)
{
for(var i=0;i<document.all.checkboxname.length;i++)
{
document.all.checkboxname[i].checked = boolvalue;
}
}
else
document.all.checkboxname.checked = boolvalue;
}
//

// 只有全部选中时“全选”选中
function SingleCheckJs()
{
var flag1=false;
var flag2=false;

if (document.form1.checkboxname.length)
{
for (var i=0;i<document.form1.checkboxname.length;i++)
{
if(document.form1.checkboxname[i].checked)
flag1 = true;
else
flag2 = true;
}
}
else
{
if(document.form1.checkboxname.checked)
flag1 = true;
else
flag2 = true;
}

if(flag1==true&&flag2==false)
document.getElementById("chk").checked = true;
else
document.getElementById("chk").checked = false;
}
//
</script>
</head>
<body>
<form id="form1" runat="server">
<div>
<table cellpadding="0" cellspacing="0" border="0" width="80%" style="font-size: 11px">
<tr>
<td align="center">
<asp:GridView ID="GridView1" runat="server" Width="100%" CellPadding="4" ForeColor="#333333"
AutoGenerateColumns="False" AllowPaging="True" PageSize="12" BorderColor="Silver"
BorderStyle="Solid" BorderWidth="1px" OnRowDataBound="GridView1_RowDataBound"
ShowFooter="True" EmptyDataText="没有数据记录!!" AllowSorting="True" OnSorting="GridView1_Sorting">
<Columns>
<asp:BoundField HeaderText="编号" DataField="id" Visible="False" />
<asp:TemplateField HeaderText="<input type='checkbox' id='chk' name='chk' onclick='checkJs(this.checked);' />全选" FooterText="全选">
<ItemTemplate>
<input type="checkbox" id="checkboxname" name="checkboxname" value='<%# DataBinder.Eval(Container.DataItem, "id")%>' onclick='SingleCheckJs();' />
</ItemTemplate>
</asp:TemplateField>
<asp:TemplateField HeaderText="单选" FooterText="单选">
<ItemTemplate>
<input type="radio" id="RadioName" name="RadioName" value='<%# Eval("id")%>' />
</ItemTemplate>
</asp:TemplateField>
<asp:TemplateField HeaderText="自增列" FooterText="自增列">
<ItemTemplate>
<%# (Container.DataItemIndex+1).ToString()%>
</ItemTemplate>
</asp:TemplateField>
<asp:BoundField HeaderText="姓名" FooterText="姓名" DataField="name" SortExpression="name" />
<asp:BoundField HeaderText="身份证号" FooterText="身份证号" DataField="card" SortExpression="card" />
<asp:BoundField HeaderText="价格" FooterText="价格" DataField="price" DataFormatString="{0:¥#,##0.00}"
HtmlEncode="False" SortExpression="price" />
<asp:BoundField HeaderText="数字" FooterText="数字" DataField="price" DataFormatString="{0:0.00}"
HtmlEncode="False" SortExpression="price" />
<asp:BoundField HeaderText="建立时间" FooterText="建立时间" DataField="createdate" DataFormatString="{0:yyyy年MM月dd日 hh时mm分ss秒}"
HtmlEncode="False" SortExpression="createdate" />
</Columns>
<RowStyle BackColor="#F7F6F3" ForeColor="#333333" />
<EditRowStyle BackColor="#999999" />
<SelectedRowStyle BackColor="#E2DED6" Font-Bold="True" ForeColor="#333333" />
<PagerStyle BackColor="#284775" ForeColor="White" HorizontalAlign="Center" />
<AlternatingRowStyle BackColor="White" ForeColor="#284775" />
<PagerSettings Visible="False" />
<FooterStyle Font-Bold="True" />
<HeaderStyle Font-Bold="False" Font-Italic="False" />
</asp:GridView>
</td>
</tr>
<tr>
<td align="center" style="height: 25px">
<asp:LinkButton ID="btnFirst" CommandArgument="first" OnClick="PagerButtonClick"
runat="server">首 页</asp:LinkButton>
<asp:LinkButton ID="btnPrev" CommandArgument="prev" OnClick="PagerButtonClick" runat="server">上一页</asp:LinkButton>
<asp:LinkButton ID="btnNext" CommandArgument="next" OnClick="PagerButtonClick" runat="server">下一页</asp:LinkButton>
<asp:LinkButton ID="btnLast" CommandArgument="last" OnClick="PagerButtonClick" runat="server">尾 页</asp:LinkButton>
<asp:Label ID="LblCurrentIndex" runat="server"></asp:Label>
<asp:Label ID="LblPageCount" runat="server"></asp:Label>
<asp:Label ID="LblRecordCount" runat="server"></asp:Label></td>
</tr>
<tr>
<td>
<asp:Button ID="Button2" runat="server" Text="checkbox得到选择的行" OnClick="Button2_Click">
</asp:Button>
<asp:Button ID="Button1" runat="server" Text="radio得到选择的行" OnClick="Button1_Click"></asp:Button>
</td>
</tr>
</table>
</div>
</form>
</body>
</html>
Jinglecat 2009-08-19
  • 打赏
  • 举报
回复
问题3,如果在程序中使用数据库select操作,查找的数据为空,使用什么函数可以获取?

=========

如果 DataReader

if(myDataReader.HasRows) {

}

如果 DataTable 就直接 DataTable.Rows.Count > 0
Jinglecat 2009-08-19
  • 打赏
  • 举报
回复
CheckBoxField 只有在 Edit 状态才能点

不要用 CheckBoxField 了,
添加一个模板列,并放入 CheckBox 控件,注意这个 CheckBox 也没有 value 可直接绑定的
你应该把 ID 直接指定给 DataKeyNames

<asp:GridView DataKeyNames="ID" runat=server .....
<Columns>
<asp:BoundField DataField="项目商品编号" HeaderText="项目商品编号" ReadOnly="true" />
<asp:BoundField DataField="项目商品名称" HeaderText="项目商品名称" ReadOnly="true" />
<asp:BoundField DataField="项目产品编号" HeaderText="项目产品编号" ReadOnly="true" />
<asp:BoundField DataField="中心产品编号" HeaderText="中心产品编号" ReadOnly="true" />
<asp:BoundField DataField="产品名称" HeaderText="产品名称" ReadOnly="true" />
<asp:BoundField DataField="生产厂家" HeaderText="生产厂家" ReadOnly="true" />
<asp:BoundField DataField="供应商" HeaderText="供应商" ReadOnly="true" />
<asp:BoundField DataField="配送商" HeaderText="配送商" ReadOnly="true" />
<asp:BoundField DataField="资料编号" HeaderText="资料编号" ReadOnly="true" />

<asp:templatefield>
<itemtemplate><asp:checkbox id=chkPro runat=server ></itemtemplate>
</asp:templatefield>
</Columns>


protected void Button1_Click(...
{
foreach(GridViewRow row in GridView1.Rows) {
CheckBox chkPro = (CheckBox)row.FindControl("chkPro");
if(chkPro != null chkPro.Checked) {
object objID = GridView1.DataKeys[row.RowIndex].Value;
// .....
}
}
}
Jinglecat 2009-08-19
  • 打赏
  • 举报
回复
问题1出在checkbox在页面显示是灰色的,点击不了,请问是添加什么属性才能点击呢?

这个 checkboxfield 只能绑 true/false

问题2,如何获取checkbox的值,知道选的是那一行,请高手提供几个函数。

这个 checkboxfield 没用 vlaue 之类这种属性,只有 checked 属性
SK_Aqi 2009-08-19
  • 打赏
  • 举报
回复
恩问题三,返回对象,或DataSet,DataTable为null的话显示一个提示信息就行了
xiaowen_ly 2009-08-19
  • 打赏
  • 举报
回复
问题一:
设置模板列
问题二:
遍历
问题三:
没明白
lovexilove 2009-08-19
  • 打赏
  • 举报
回复
顶一个
Lovely_baby 2009-08-19
  • 打赏
  • 举报
回复
问题1出在checkbox在页面显示是灰色的,点击不了,请问是添加什么属性才能点击呢?
你的readonly设为true了 不能点击 删掉
问题2,如何获取checkbox的值,知道选的是那一行,请高手提供几个函数。
for (int i = 0; i < count ;i++)
{
Response.Write(((CheckBox)this.GridView1.Rows[i].FindControl("CheckBox")).Checked.ToString() + "<br>");
}
问题3,如果在程序中使用数据库select操作,查找的数据为空,使用什么函数可以获取?
你先在数据库中执行看看有结果吗
有的话就是你程序的问题 你断点跟踪看看
lifeiwen 2009-08-19
  • 打赏
  • 举报
回复
[Quote=引用 14 楼 sk_aqi 的回复:]
引用 6 楼 lifeiwen 的回复:
引用 4 楼 winscar 的回复:
对于第三个问题,真的是不明白楼主的意思了。
数据库的问题,也可以在SQL SERVER板块问大侠们。

我的意思是,比如用 select * from 总表 where 产品编号=‘123456’ 查询不到任何信息,用什么函数可以得到这个结果。


查不到就是查不到啊!还有什么函数?
[/Quote]
我在网页上有一个操作,数据库中查不到网页上可以有相应的提示,所以我想通过一个函数来获得数据库的这个信息。我刚查了下,adapterRead好像可以实现这个功能
  • 打赏
  • 举报
回复
//问题一:
<asp:TemplateField>
<ItemTemplate>
<asp:CheckBox ID="chkSelect" runat="server" />
</ItemTemplate>
</asp:TemplateField>
//问题二:
for (int i = 0; i < grdVMI.Rows.Count; i++)
{
if (((CheckBox)grdVMI.Rows[i].Cells[0].FindControl("chkSelect")).Checked) //如果有选中
{
array.Add(grdVMI.Rows[i].Cells[8].Text.ToString() + "|" + ((ImageButton)grdVMI.Rows[i].Cells[8].FindControl("imgbtn_Check")).ToolTip + "|" + ((LinkButton)grdVMI.Rows[i].Cells[1].FindControl("lkbVMINo")).Text.ToString()); //填加币种以及是否结算标记
}
}
//问题三:
//判断SqlDataReader、DataTable、DataSet是否为空即可。
SK_Aqi 2009-08-19
  • 打赏
  • 举报
回复
[Quote=引用 6 楼 lifeiwen 的回复:]
引用 4 楼 winscar 的回复:
对于第三个问题,真的是不明白楼主的意思了。
数据库的问题,也可以在SQL SERVER板块问大侠们。

我的意思是,比如用 select * from 总表 where 产品编号=‘123456’ 查询不到任何信息,用什么函数可以得到这个结果。
[/Quote]

查不到就是查不到啊!还有什么函数?
SK_Aqi 2009-08-19
  • 打赏
  • 举报
回复
ding xian
sxmonsy 2009-08-19
  • 打赏
  • 举报
回复
路过帮顶。
王向飞 2009-08-19
  • 打赏
  • 举报
回复
第三个问题还是没看明白。。。。。
查询不到信息就是没有符合条件的记录啊。。。还需要什么?
wiki14 2009-08-19
  • 打赏
  • 举报
回复
检查sql语句是否有错,检查数据库里是否有数据。

断点跟踪一下看看有没有打开SQL连接。
flyerwing 2009-08-19
  • 打赏
  • 举报
回复
我是菜鸟。过来看下。
fanxiaolin84 2009-08-19
  • 打赏
  • 举报
回复
第三个问题能否再叙述的清楚点?
rememberhai 2009-08-19
  • 打赏
  • 举报
回复
学习
加载更多回复(4)

62,046

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术交流专区
javascript云原生 企业社区
社区管理员
  • ASP.NET
  • .Net开发者社区
  • R小R
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

.NET 社区是一个围绕开源 .NET 的开放、热情、创新、包容的技术社区。社区致力于为广大 .NET 爱好者提供一个良好的知识共享、协同互助的 .NET 技术交流环境。我们尊重不同意见,支持健康理性的辩论和互动,反对歧视和攻击。

希望和大家一起共同营造一个活跃、友好的社区氛围。

试试用AI创作助手写篇文章吧