ASPxNavBar.AutoPostBack Property
Gets or sets a value that specifies whether server-side processing is required for specific predefined user actions.
Namespace: DevExpress.Web
Assembly: DevExpress.Web.v24.1.dll
NuGet Package: DevExpress.Web
Declaration
Property Value
Type | Default | Description |
---|---|---|
Boolean | false |
|
Remarks
Use the AutoPostBack property to control whether a predefined user action (such as a group’s expansion state change, for instance) can be completely processed on the client side by handling an appropriate client-side event (such as the ASPxClientNavBar.ExpandedChanging in this instance) or a round trip to the server is required so that the action is finally processed on the server side with the help of the corresponding server-side event (such as the ASPxNavBar.ExpandedChanging event).
Note that the available client-side events whose handlers are assigned in a navbar control are always fired regardless of the AutoPostBack property’s setting. The AutoPostBack property’s value only affects the default value of the processOnServer property which is passed to the navbar’s specific client-side events. If the AutoPostBack property is set to true
the end-user action is first of all processed via the corresponding client-side event and only after that the server-side processing is performed if it has not been canceled via the setting of the client-side event’s processOnServer property. If the value of the AutoPostBack property is false
, a specific user action which has a corresponding server-side event can all the same be processed on the server side by setting the processOnServer property to true
in the client event’s handler.
In such a way, note that server-side events which correspond to specific performed user actions may not be generated in the following two cases:
- The AutoPostBack property is set to
true
, but the corresponding client-side event is handled so that the processOnServer property is set tofalse
. The AutoPostBack property is set to
false
and the corresponding client-side event is not handled, or handled so that the processOnServer property is not changed (is not set totrue
).Note
Assigning a handler for a server event that relates to processing a click operation within a control (such as ASPxNavBar.ItemClick, for instance) changes the default value of the processOnServer property to
true
. So, invoking such events on the server does not depend on the AutoPostBack property setting and depends only on a developer not explicitly setting the processOnServer property tofalse
in the corresponding client event’s handler.
Example
using DevExpress.Web.ASPxNavBar;
...
protected void Page_Load(object sender, EventArgs e) {
ASPxNavBar ASPxNavBar1 = new ASPxNavBar();
ASPxNavBar1.AutoPostBack = true;
ASPxNavBar1.ShowExpandButtons = false;
ASPxNavBar1.GroupHeaderStyle.HorizontalAlign = HorizontalAlign.Left;
ASPxNavBar1.ItemStyle.HorizontalAlign = HorizontalAlign.Center;
NavBarGroup group1 = new NavBarGroup("Group1");
NavBarGroup group2 = new NavBarGroup("Group2");
NavBarItem item1 = new NavBarItem("Item1");
NavBarItem item2 = new NavBarItem("Item2");
NavBarItem item3 = new NavBarItem("Item3");
ASPxNavBar1.Groups.Add(group1);
ASPxNavBar1.Groups.Add(group2);
group1.Items.Add(item1);
group2.Items.Add(item2);
group2.Items.Add(item3);
group1.HeaderStyle.BackColor = System.Drawing.Color.White;
group2.HeaderStyle.BackColor = System.Drawing.Color.Red;
Page.Form.Controls.Add(ASPxNavBar1);
}