更改 Xamarin Forms XAML 按钮的 isVisible 属性
Changing isVisible property of Xamarin Forms XAML buttons
我正在尝试在 Xamarin Forms ContentPage 中动态 show/hide 按钮。
我的 XAML 代码中有两个按钮:
<StackLayout Orientation="Vertical">
<Button x:Name="start_btn" Clicked="startPanic">
<Button.Text>START</Button.Text>
</Button>
<Button x:Name="stop_btn" IsVisible="false">
<Button.Text>STOP</Button.Text>
</Button>
</StackLayout>
对应的C#代码:
public partial class PanicPage : ContentPage
{
private Button startBtn;
private Button stopBtn;
public PanicPage ()
{
InitializeComponent ();
startBtn = this.FindByName<Button> ("start_btn");
stopBtn = this.FindByName<Button> ("stop_btn");
}
private void startPanic(object sender, EventArgs args){
Device.BeginInvokeOnMainThread (() => {
startBtn.IsVisible = false;
stopBtn.IsVisible = true; // DOESN'T WORK, button still will be hidden
});
}
}
当我在 XAML 中设置 isVisible 属性 时,它不会对事件方法 (startPanic) 中的任何 属性 更改做出反应。我该如何解决?
它应该工作得很好。我复制了你的代码并稍微清理了一下,它显示了停止按钮,然后我
几点说明:
- 尽可能使用短 属性
<Button Text="X"/>
,它是
更容易阅读
- 当您添加一个 XAML 页面时,IDE 会在其旁边添加一个 .xaml.cs 文件并生成另一个您看不到的 .g.cs 文件。 .g.cs 文件
包含生成的代码,用于查找所有 x:Name'd 元素和
为它们定义占位符,无需自己通过名称找到它们
- 所有 UI 启动的事件都在 UI 线程上执行,无需显式执行
这是 XAML,与您的一样,只是收紧并添加了边距,以便按钮可见
<StackLayout Orientation="Vertical" Margin="20">
<Button x:Name="start_btn" Clicked="startPanic" Text="START" />
<Button x:Name="stop_btn" Text="STOP" IsVisible="false" />
</StackLayout>
以及后面的代码:
public partial class TestPage : ContentPage
{
public TestPage ()
{
InitializeComponent ();
}
private void startPanic(object sender, EventArgs args){
Device.BeginInvokeOnMainThread (() => {
start_btn.IsVisible = false;
stop_btn.IsVisible = true;
});
}
}
更改 xmal 文件中的代码并编写开始和停止按钮的属性
<Button x:Name="start_btn" Clicked="startPanic" IsVisible="{Binding IsStartVisible}">
<Button.Text>START</Button.Text>
</Button>
<Button x:Name="stop_btn" IsVisible="{Binding IsStopVisible}">
<Button.Text>STOP</Button.Text>
</Button>
在 ViewModel 中,为开始按钮编写以下 属性 和类似内容,并根据您的逻辑设置 IsStopVisible =true/false
private bool _isStopVisible;
public bool IsStopVisible{
get {
return _isStopVisible;
}
set {
_isStopVisible= value;
RaisePropertyChanged ("IsStopVisible");
}
}
使用视图的可见性 属性。
例如,如果你想让你的按钮不可见,你可以这样做
if(condition)
{
button.Visibility=ViewStates.Invisible;
}
else
{
button.Visibility=ViewStates.Visible;
}
也许我迟到了,但我也在搜索这个但没有成功。这可能对某人有用。
objectView.SetValue(IsVisibleProperty, false); // the view is GONE, not invisible
objectView.SetValue(IsVisibleProperty, true);
我正在尝试在 Xamarin Forms ContentPage 中动态 show/hide 按钮。 我的 XAML 代码中有两个按钮:
<StackLayout Orientation="Vertical">
<Button x:Name="start_btn" Clicked="startPanic">
<Button.Text>START</Button.Text>
</Button>
<Button x:Name="stop_btn" IsVisible="false">
<Button.Text>STOP</Button.Text>
</Button>
</StackLayout>
对应的C#代码:
public partial class PanicPage : ContentPage
{
private Button startBtn;
private Button stopBtn;
public PanicPage ()
{
InitializeComponent ();
startBtn = this.FindByName<Button> ("start_btn");
stopBtn = this.FindByName<Button> ("stop_btn");
}
private void startPanic(object sender, EventArgs args){
Device.BeginInvokeOnMainThread (() => {
startBtn.IsVisible = false;
stopBtn.IsVisible = true; // DOESN'T WORK, button still will be hidden
});
}
}
当我在 XAML 中设置 isVisible 属性 时,它不会对事件方法 (startPanic) 中的任何 属性 更改做出反应。我该如何解决?
它应该工作得很好。我复制了你的代码并稍微清理了一下,它显示了停止按钮,然后我
几点说明:
- 尽可能使用短 属性
<Button Text="X"/>
,它是 更容易阅读 - 当您添加一个 XAML 页面时,IDE 会在其旁边添加一个 .xaml.cs 文件并生成另一个您看不到的 .g.cs 文件。 .g.cs 文件 包含生成的代码,用于查找所有 x:Name'd 元素和 为它们定义占位符,无需自己通过名称找到它们
- 所有 UI 启动的事件都在 UI 线程上执行,无需显式执行
这是 XAML,与您的一样,只是收紧并添加了边距,以便按钮可见
<StackLayout Orientation="Vertical" Margin="20">
<Button x:Name="start_btn" Clicked="startPanic" Text="START" />
<Button x:Name="stop_btn" Text="STOP" IsVisible="false" />
</StackLayout>
以及后面的代码:
public partial class TestPage : ContentPage
{
public TestPage ()
{
InitializeComponent ();
}
private void startPanic(object sender, EventArgs args){
Device.BeginInvokeOnMainThread (() => {
start_btn.IsVisible = false;
stop_btn.IsVisible = true;
});
}
}
更改 xmal 文件中的代码并编写开始和停止按钮的属性
<Button x:Name="start_btn" Clicked="startPanic" IsVisible="{Binding IsStartVisible}">
<Button.Text>START</Button.Text>
</Button>
<Button x:Name="stop_btn" IsVisible="{Binding IsStopVisible}">
<Button.Text>STOP</Button.Text>
</Button>
在 ViewModel 中,为开始按钮编写以下 属性 和类似内容,并根据您的逻辑设置 IsStopVisible =true/false
private bool _isStopVisible;
public bool IsStopVisible{
get {
return _isStopVisible;
}
set {
_isStopVisible= value;
RaisePropertyChanged ("IsStopVisible");
}
}
使用视图的可见性 属性。
例如,如果你想让你的按钮不可见,你可以这样做
if(condition)
{
button.Visibility=ViewStates.Invisible;
}
else
{
button.Visibility=ViewStates.Visible;
}
也许我迟到了,但我也在搜索这个但没有成功。这可能对某人有用。
objectView.SetValue(IsVisibleProperty, false); // the view is GONE, not invisible
objectView.SetValue(IsVisibleProperty, true);