非根对象中的XAML事件处理程序

时间:2019-03-09 19:16:08

标签: xaml uwp-xaml

想象一下以下XAML:

<Page
    x:Class="MyProject.MainPage"
    xmlns:local="using:MyProject">

   <local:MyStackPanel>
       <Button Content="Go" Click="OnGo"/>
   </local:MyStackPanel>
</Page>

XAML假定OnGo是页面类中的方法。我能以某种方式声明性地告诉它OnGo驻留在MyStackPanel中吗?

我知道页面加载后就可以通过编程方式分配事件处理程序。我想知道仅通过XAML手段是否有可能。 “否”是可以接受的答案:)

1 个答案:

答案 0 :(得分:1)

根据您的要求,您可以将MyStackPanel DataContext与其自身绑定。然后在BtnClickCommand类中创建用于绑定按钮命令的MyStackPanel,如下所示。

public class MyStackPanel : StackPanel
{
    public MyStackPanel()
    {

    }

    public ICommand BtnClickCommand
    {
        get
        {
            return new RelayCommand(() =>
            {


            });
        }
    }

}
public class RelayCommand : ICommand
{
    private readonly Action _execute;
    private readonly Func<bool> _canExecute;
    /// <summary>
    /// Raised when RaiseCanExecuteChanged is called.
    /// </summary>
    public event EventHandler CanExecuteChanged;
    /// <summary>
    /// Creates a new command that can always execute.
    /// </summary>
    /// <param name="execute">The execution logic.</param>
    public RelayCommand(Action execute)
        : this(execute, null)
    {
    }
    /// <summary>
    /// Creates a new command.
    /// </summary>
    /// <param name="execute">The execution logic.</param>
    /// <param name="canExecute">The execution status logic.</param>
    public RelayCommand(Action execute, Func<bool> canExecute)
    {
        if (execute == null)
            throw new ArgumentNullException("execute");
        _execute = execute;
        _canExecute = canExecute;
    }
    /// <summary>
    /// Determines whether this RelayCommand can execute in its current state.
    /// </summary>
    /// <param name="parameter">
    /// Data used by the command. If the command does not require data to be passed,
    /// this object can be set to null.
    /// </param>
    /// <returns>true if this command can be executed; otherwise, false.</returns>
    public bool CanExecute(object parameter)
    {
        return _canExecute == null ? true : _canExecute();
    }
    /// <summary>
    /// Executes the RelayCommand on the current command target.
    /// </summary>
    /// <param name="parameter">
    /// Data used by the command. If the command does not require data to be passed,
    /// this object can be set to null.
    /// </param>
    public void Execute(object parameter)
    {
        _execute();
    }
    /// <summary>
    /// Method used to raise the CanExecuteChanged event
    /// to indicate that the return value of the CanExecute
    /// method has changed.
    /// </summary>
    public void RaiseCanExecuteChanged()
    {
        var handler = CanExecuteChanged;
        if (handler != null)
        {
            handler(this, EventArgs.Empty);
        }
    }
}

用法

<local:MyStackPanel DataContext="{Binding RelativeSource={RelativeSource Mode=Self}}">
    <Button Command="{Binding BtnClickCommand}" Content="ClickMe" />
</local:MyStackPanel>