0

我有一个 TextBox,随着它的内容增长,我希望它增长,随着它的内容缩小,我希望它的高度和宽度都缩小。这可以通过挂钩到 TextBox 中的 TextChanged 事件来轻松实现,这意味着代码隐藏,这是我们在 MVVM 中应该避免的事情。所以问题是我们如何在 MVVM 中做到这一点?我们显然必须使用命令(实现 ICommand 接口的类),同时我们不能将命令挂钩到事件。

一种选择是使用 System.Windows.Interactivity。我以前用过它,它非常简洁,但实际上有些人可能反对它,因为它更多地使用 Silverlight 库。

还有其他选择吗?

一个更简单的 XAML。请注意,我希望窗口改变它的大小,因为 TextBox 占据了整个窗口:

<Window x:Class="WpfApplication1.MainWindow"
        xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
        xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
        Title="MainWindow" Height="350" Width="525">
    <Grid HorizontalAlignment="Stretch">
        <TextBox Width="Auto">            
        </TextBox>
    </Grid>
</Window>

这是我的 XAML:

<Window x:Class="SleekNoteUI.Views.SleekNoteView"
        xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
        xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
    <Window.Template>
        <ControlTemplate>
            <Border...>
                <Grid>
                    <Grid Grid.Row="1" x:Name="noteGrid">
                        <TextBox Grid.Row="0"
                                 Text="{Binding SomeText...}"
                                 Background="{Binding...}">
            </TextBox>
        </Grid>
        </Grid>
    </Border>
    </ControlTemplate>
</Window.Template>
</Window>
4

3 回答 3

6

文本框随着文本的变化缩小/增长:

<TextBox HorizontalAlignment="Left" Width="Auto" MinWidth="10"/>
  • 仅限 XAML 的解决方案。
  • 后面没有代码,
  • 没有System.Windows.Interactivity
  • 并且不要将与大小相关的东西放在它们不属于的 ViewModel 中。

然后再次:

  • MVVM 并不是要避免代码落后。这是关于将 UI 从业务/应用程序逻辑和数据中分离出来。
  • System.Windows.Interactivity 与 Silverlight 一样多的 WPF,所以我不知道“某些人”在说什么,但它的使用是完全有效的
于 2013-04-01T01:30:18.270 回答
1

通过简单地将 Width 属性设置为“Auto”,您就可以实现这一点。

<TextBox Width="Auto" />

谢谢,拉梅什

于 2013-04-01T09:35:24.943 回答
0

using System.Windows.Interactivity create a Behavior. This is the best way of encapsulating code that otherwise would endup in a code-behind

于 2014-01-17T22:05:19.230 回答