Solved

Setting textbox size in a gridview

Posted on 2016-11-02
12
44 Views
Last Modified: 2016-11-08
Hi,
I have a gridview with 3 columns.
The first column has a textbox, the 2nd a checkbox and the 3rd an image button.
I have set the size of :
- The Gridview to be 99% of form,
- The 1st column to be 70% of the gridview
- The textbox to be 100% of the column

However, I cannot manage to set the size of the textbox to use 100% of the 1st column.
No matter what I try, % of px, the maximum size does not change.


Could you please help.

I have also added an image on how it looks with the code below

Anne Rowe

This is the code:

    <asp:GridView ID="GV" runat="server" AutoGenerateColumns="false" 
        ShowFooter="False" DataKeyNames="QID, FQID" SelectedIndex="0" Width="99%" OnRowDataBound="GV_RowDataBound">
        <Columns>
            <asp:TemplateField Visible="true" HeaderText="Description" ItemStyle-VerticalAlign="Top" HeaderStyle-Width="70%" ItemStyle-Width="70%" HeaderStyle-HorizontalAlign="Center">
                <ItemTemplate>
                    <asp:TextBox ID="txtQuestionDesc" Text='<%# Eval("QuestionDesc") %>' runat="Server" Style="Width:100%; Height:20px"  />
                </ItemTemplate>
            </asp:TemplateField>
            <asp:TemplateField Visible="true" HeaderText="Correct answer" HeaderStyle-Width="20%" HeaderStyle-HorizontalAlign="Center" ItemStyle-HorizontalAlign="Center">
                <ItemTemplate>
                     <asp:CheckBox ID="ckIsAnswer" runat="server" CssClass="exclusive" data-linked="group3" Checked='<%# Bind("IsAnswer") %>'/>
                    <asp:Label ID="lblIsAnswer" Text='<%# Eval("IsAnswer") %>' runat="Server" Visible="False" />
                </ItemTemplate>
            </asp:TemplateField>
            <asp:TemplateField Visible="true" HeaderText="Remove" HeaderStyle-Width="10%" ItemStyle-HorizontalAlign="Center">
                <ItemTemplate>
                    <asp:ImageButton ID="btnDelete" runat="server" AlternateText="Delete" TabIndex="-1"
                        ImageUrl="~/App_Themes/Default/Images/Buttons/Remove.png" ImageAlign="middle" CssClass="imagebutton"
                        CommandName="DeleteSubQuestion" CommandArgument='<%# Eval("QID") %>' OnCommand="Delete_RowCommand"
                        Visible='<%# Boolean.Parse(Eval("IsDelete").ToString()) %>' Enabled='<%# Boolean.Parse(Eval("IsEnabled").ToString()) %>' />
                </ItemTemplate>
            </asp:TemplateField>
        </Columns>
    </asp:GridView>

Open in new window

Texbox-in-a-Gridview.PNG
0
Comment
Question by:AnneSKS
[X]
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
  • 6
  • 3
  • 3
12 Comments
 
LVL 28

Expert Comment

by:Pawan Kumar
ID: 41871496
Try..I think you need to firs the Set the width of the column.

<asp:TemplateField HeaderText="Pawan" ItemStyle-Width="100px">                    
                    <EditItemTemplate>
                        <asp:TextBox ID="txtid" runat="server" Text='<%#Eval("Pawan") %>' Width="100%"></asp:TextBox>
                    </EditItemTemplate>
                    <ItemStyle Width="100px" />
</asp:TemplateField>
0
 
LVL 40

Expert Comment

by:Kyle Abrahams
ID: 41871505
Remove the itemstyle width . . . just use the header style.
0
 

Author Comment

by:AnneSKS
ID: 41871520
Kyle & Pawan,
I've tried both solutions, none of them made resized the width of the textbox.
0
Space-Age Communications Transitions to DevOps

ViaSat, a global provider of satellite and wireless communications, securely connects businesses, governments, and organizations to the Internet. Learn how ViaSat’s Network Solutions Engineer, drove the transition from a traditional network support to a DevOps-centric model.

 
LVL 28

Expert Comment

by:Pawan Kumar
ID: 41871530
Try this

<asp:TemplateField HeaderText="Pawan" ItemStyle-Width="100px">                    
                    <EditItemTemplate>
                        <asp:TextBox ID="txtid" runat="server" Text='<%#Eval("Pawan") %>' Width="100%"></asp:TextBox>
                    </EditItemTemplate>
                    <Itemstyle Width="100px" />
                    <ControlStyle Width="100%" />

</asp:TemplateField>
0
 

Author Comment

by:AnneSKS
ID: 41871535
Hi Pawan,
Below is what I have tried, however it did not make any difference.


            <asp:TemplateField Visible="true" HeaderText="Description" ItemStyle-VerticalAlign="Top" HeaderStyle-Width="70%" HeaderStyle-HorizontalAlign="Center">
                <ItemTemplate>
                    <asp:TextBox ID="txtQuestionDesc" Text='<%# Eval("QuestionDesc") %>' runat="Server" Style="Width:100%; Height:20px"  CssClass="Label_100_Blue_QB" />
                    <asp:Label ID="lblQuestionDesc" Text='<%# Eval("QuestionDesc") %>' runat="Server" Visible="False" />
                </ItemTemplate>
                 <ControlStyle Width="100%" />
            </asp:TemplateField>

Open in new window

0
 
LVL 40

Expert Comment

by:Kyle Abrahams
ID: 41871537
Can you inspect it and post the raw html from your browseR?

What's in the css class Label_100_Blue_QB
0
 
LVL 28

Expert Comment

by:Pawan Kumar
ID: 41871558
Remove this class Label_100_Blue_QB .

Also try with both ..

 <Itemstyle Width="100px" />
<ControlStyle Width="100%" />
0
 

Author Comment

by:AnneSKS
ID: 41871644
Pawan,
I have removed the class Label_100_Blue_QB
And added both
 <Itemstyle Width="100px" />
<ControlStyle Width="100%" />
 
And it did not change anything
0
 

Author Comment

by:AnneSKS
ID: 41871646
Kyle,
Attached is the raw html for the full page. SO a lot more information than what I posted above.
I have removed in the sample above what was not relevant for this exercise.
Texbox-in-a-Gridview.txt
0
 
LVL 40

Expert Comment

by:Kyle Abrahams
ID: 41873197
Where is it getting the height:15px from?  Setting the width to 70% there will do the trick in terms of the column with (or in the TH section).

<td style="height:15px;">

also Label_100_Blue_QB appears to be in a separate style sheet . . . can you post the CSS definition for that?

Can you also post your full gridview or radgrid (EG: I see your hidden column in the data but not in your code).

Thanks.
0
 

Accepted Solution

by:
AnneSKS earned 0 total points
ID: 41873393
I found the solution:
It looks like setting up the width of a textbox using Width property and a % is not working, and not only in a gridview.
The way to do it is to use the min-width:

 <asp:TextBox ID="txtQuestionDesc" Text='<%# Eval("QuestionDesc") %>' runat="Server" Style="min-width:98%; height:20px" />

Open in new window


Thank you for your help.

Anne
0
 

Author Closing Comment

by:AnneSKS
ID: 41878489
The other solutions provided by the experts did not solve the problem and did not lead me to finding the solution
0

Featured Post

SharePoint Admin?

Enable Your Employees To Focus On The Core With Intuitive Onscreen Guidance That is With You At The Moment of Need.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Real-time is more about the business, not the technology. In day-to-day life, to make real-time decisions like buying or investing, business needs the latest information(e.g. Gold Rate/Stock Rate). Unlike traditional days, you need not wait for a fe…
Not sure what the best email signature size is? Are you worried about email signature image size? Follow this best practice guide.
In this tutorial viewers will learn how to style elements, such a divs, with a "drop shadow" effect using the CSS box-shadow property Start with a normal styled element, such as a div.: In the element's style, type the box shadow property: "box-shad…
The viewer will learn the basics of jQuery including how to code hide show and toggles. Reference your jQuery libraries: (CODE) Include your new external js/jQuery file: (CODE) Write your first lines of code to setup your site for jQuery…

752 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question