19

How can I tell my TabControl to set the focus to its first TabItem, something like this:

PSEUDO-CODE:

((TabItem)(MainTabControl.Children[0])).SetFocus();
Steffen Opel
  • 63,899
  • 11
  • 192
  • 211
Edward Tanguay
  • 189,012
  • 314
  • 712
  • 1,047

11 Answers11

33

How about this?

MainTabControl.SelectedIndex = 0;
Martin Liversage
  • 104,481
  • 22
  • 209
  • 256
12
this.tabControl1.SelectedTab = this.tabControl1.TabPages["tSummary"];

I've found it's usually a best practice to name your tabs and access it via the name so that if/when other people (or you) add to or subtact tabs as part of updating, you don't have to go through your code and find and fix all those "hard coded" indexes. hope this helps.

koopajah
  • 23,792
  • 9
  • 78
  • 104
Brian
  • 137
  • 1
  • 7
5

I realise this was answered a long time ago, however a better solution would be to bind your items to a collection in your model and expose a property that selected item is bound to.

XAML:

<!-- MyTemplateForItem represents your template -->
<TabControl ItemsSource="{Binding MyCollectionOfItems}"
            SelectedItem="{Binding SelectedItem}"
            ContentTemplate="{StaticResource MyTemplateForItem}">
</TabControl>

Code Behind:

public ObservableCollection<MyItem> MyCollectionOfItems {
    get;
    private set;
}

private MyItem selectedItem;
public MyItem SelectedItem{
    get { return selectedItem; }
    set {
        if (!Object.Equals(selectedItem, value)) {
            selectedItem = value;
            // Ensure you implement System.ComponentModel.INotifyPropertyChanged
            OnNotifyPropertyChanged("SelectedItem");
        }
    }
}

Now, all you have to do to set the item is:

MyItem = someItemToSelect;

You can use the same logic with the SelectedIndex property, further, you can use the two at the same time.

This approach allows you to separate your model correctly from the UI, which could allow you to replace the TabControl with something else down the line but not requiring you to change your underlying model.

Brett Ryan
  • 26,937
  • 30
  • 128
  • 163
3

Look at the properties for the tab control... Expand the TabPages properties "collection"... Make note of the names you gave the members.

ie. a tab control called tabMain with 2 tabs called tabHeader and tabDetail

Then to select either tab...You have to set it with the tabname

tabMain.SelectedTab = tabHeader;
Chris Catignani
  • 5,040
  • 16
  • 42
  • 49
2
tabControl1.SelectedTab = item;
item.Focus();
Chernikov
  • 847
  • 1
  • 11
  • 21
  • 3
    What is the benefit of using item.Focus() after setting the selected Item? – Hugo Estrada Jan 18 '11 at 13:24
  • 1
    @HugoEstrada Focus and selection are not the same thing. Create a couple triggers based off of each of these properties to see what I mean. Or see my related question: https://stackoverflow.com/q/58207987/2596334 – Scott Solmer Oct 03 '19 at 12:20
2

Basically all of the answers here deal with SELECTION, which does not answer the question.
Maybe that is what OP wanted, but the question very specifically asks for FOCUS.

TabItem item = (TabItem)MainTabControl.Items[0];
// OR
TabItem item = (TabItem)MainTabControl.SelectedItem;
// Then
item.Focus();
Scott Solmer
  • 3,871
  • 6
  • 44
  • 72
  • 1
    This appears to be the only sensible answer, BUT: my `Items[]` collection does not contain instances of `TabITem`, (that would make too much sense,) it contains viewmodels, because I am using `ItemsSource="{Binding...` and `SelectedItem="{Binding...` -- do you have a solution in this case? – Mike Nakis Mar 16 '21 at 23:00
  • @MikeNakis did you ever find a solution to your question? I asked what you were looking for here: https://stackoverflow.com/q/74385939/1306012 – Bruno Bieri Nov 10 '22 at 08:20
  • 1
    @BrunoBieri no, I did not. I looked at your question, but I still do not have an answer. – Mike Nakis Nov 10 '22 at 12:03
  • @MikeNakis Have you considered basing your "viewmodels" classes on UIElement or ContentElement? So long as one of those is in the base of the custom class you are using as a ViewModel, it should have the Focus method and events. – Scott Solmer Nov 10 '22 at 13:37
  • @ScottSolmer that sounds like a horrible, horrible, *horrible beyond words* idea. – Mike Nakis Nov 10 '22 at 15:31
  • @MikeNakis I don't disagree. However that is the result of choosing "ViewModel" as the type for TabControl Items. _That_ is a horrible idea. – Scott Solmer Nov 10 '22 at 16:14
1

it's better to use the following type of code to select the particular item in the particular tab...

.

 private void PutFocusOnControl(Control element)
        {
            if (element != null)
                Dispatcher.BeginInvoke(System.Windows.Threading.DispatcherPriority.Input,
                    (System.Threading.ThreadStart)delegate
                    {
                        element.Focus();
                    });
        }

And in calling time... tabcontrol.isselected=true; PutFocusOnControl(textbox1);

will works fine...

V G S Naidu
  • 357
  • 3
  • 10
  • 30
1

tabControl.SelectedItem = tabControl.Items[0];

Ray
  • 1,585
  • 9
  • 10
1

If you have a Tabcontroller named tabControl you could set the selectedIndex from different methods, i use following methods mostly.

codebehind:

tabControl.SelectedIndex = 0; // Sets the focus to first tabpanel

clientside:

First, put the following javascript in your aspx/ascx file:

<script type="text/javascript">
function SetActiveTab(tabControl, activeTabIndex) {
    var activeTab = tabControl.GetTab(activeTabIndex);
    if(activeTab != null)
        tabControl.SetActiveTab(activeTab);
}</script>

Then add following clientside event to prefered controller:

OnClientClick="function(s, e) { SetActiveTab(tabControl, 0);
Webking
  • 1,822
  • 2
  • 20
  • 28
0

Private Sub TabControl1_SelectedIndexChanged(sender As Object, e As EventArgs) Handles TabControl1.SelectedIndexChanged 'MsgBox(TabControl1.SelectedIndex)

    If TabControl1.SelectedIndex = 0 Then
        txt_apclntFrstName.Select()
    Else
        txtApplcnNo.Select()
    End If


End Sub
0

It worked for me to set focus to the last tab just after I open it:

//this is my assignment of the collection to the tab control
DictTabControl.DataContext = appTabs.DictTabs;  

//set the selected item to the last in the collection, i.e., the one I just added to the end.
DictTabControl.SelectedItem = DictTabControl.Items[(DictTabControl.Items.Count-1)];
Bruno Bieri
  • 9,724
  • 11
  • 63
  • 92
mly
  • 51
  • 5