- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试使用 TreeView 呈现一个未知的 JSON。我还需要编辑这些 JSON 对象中的字符串并将它们写回,因此我需要某种形式的字典,但键可以从层次结构的一侧重复到另一侧(JSON 示例中的“响应”)。我已经研究了又研究,但我无法找到有用的东西。大多数问题也是针对 winforms 或不使用 MVVM 提出的,我无法将其翻译成我所追求的。
JSON 示例:
{
"universal": {
"regionalSettings": {
"culture": {
"en-GB": "United Kingdom (en-GB)",
"mk-MK": "Македонија (mk-MK)",
"sq-MK": "Shqipëria (sq-MK)",
},
"language": {
"en-GB": "English (United Kingdom)",
"mk": "Македонски",
"sq": "Shqipe",
},
"timeZone": {
"Europe/Amsterdam": "Europe/Amsterdam",
"Europe/Andorra": "Europe/Andorra",
"Europe/Astrakhan": "Europe/Astrakhan",
"Europe/Athens": "Europe/Athens",
"Europe/Belgrade": "Europe/Belgrade",
"Europe/Berlin": "Europe/Berlin",
"Europe/Bratislava": "Europe/Bratislava",
"Europe/Brussels": "Europe/Brussels",
}
}
}
}
查看片段:
<ScrollViewer>
<TreeView>
<HierarchicalDataTemplate ItemsSource="{Binding Tree}" />
</TreeView>
</ScrollViewer>
ViewModel 片段:
public class SomeViewModel
{
public JToken Tree { get; set; }
private void PopulateTreeView()
{
var jsonReader = new JsonReader();
var jsonText = jsonReader.Read("C:\\imaginary_path\\example.json");
var token = JToken.Parse(jsonText);
// where magic should happen
Tree = token;
}
}
“奇迹应该发生的地方”标记了我缺少代码的地方。在那里我需要以某种方式分层表示 json 并制作成一种我可以传递给 TreeView 的格式,同时还包括字符串(在对象中,而不是在 TreeView 本身中,因为我需要在特定项目时显示这些字符串在树中被选中),目前我正在传递 JObject,它使 TreeView 显示显示“System.Windows.HierarchicalDataTemplate”的根。
我衷心感谢所有提前提供帮助的人。
最佳答案
正如我们在评论中得出的结论,某些 Json 编辑器 可能适合实现目标。
我已经实现了一个示例,如何使用 .NET Core System.Text.Json
( documentation ) 读取/写入 json 并使用 TreeView
.
我没有使用 Calibrum.Micro,也不熟悉它,但没有使用任何外部库。我在解决方案中添加了两个辅助类。
public class NotifyPropertyChanged : INotifyPropertyChanged
{
public event PropertyChangedEventHandler PropertyChanged;
protected virtual void OnPropertyChanged([CallerMemberName] string propertyName = null)
=> PropertyChanged?.Invoke(this, new PropertyChangedEventArgs(propertyName));
}
public class RelayCommand : ICommand
{
private readonly Action<object> _execute;
private readonly Predicate<object> _canExecute;
public event EventHandler CanExecuteChanged
{
add => CommandManager.RequerySuggested += value;
remove => CommandManager.RequerySuggested -= value;
}
public RelayCommand(Action<object> execute, Predicate<object> canExecute = null)
=> (_execute, _canExecute) = (execute, canExecute);
public bool CanExecute(object parameter)
=> _canExecute == null || _canExecute(parameter);
public void Execute(object parameter)
=> _execute(parameter);
}
数据模型实现
public class TreeNode : NotifyPropertyChanged
{
public static MainViewModel MainVM { get; set; }
private bool _isSelected;
private string _name;
public bool IsSelected
{
get => _isSelected;
set
{
_isSelected = value;
if (_isSelected) MainVM.SelectedItem = this;
}
}
public string Name
{
get => _name;
set
{
_name = value;
OnPropertyChanged();
}
}
}
public class TreeObject : TreeNode
{
private ObservableCollection<TreeNode> _children;
public ObservableCollection<TreeNode> Children
{
get => _children;
set
{
_children = value;
OnPropertyChanged();
}
}
}
public class TreeValue : TreeNode
{
private string _value;
public string Value
{
get => _value;
set
{
_value = value;
OnPropertyChanged();
}
}
}
MainWindow
的 View 模型
public class MainViewModel : NotifyPropertyChanged
{
private ObservableCollection<TreeNode> _treeItems;
private TreeNode _selectedItem;
private ICommand _loadCommand;
private ICommand _saveCommand;
public ObservableCollection<TreeNode> TreeItems
{
get => _treeItems;
set
{
_treeItems = value;
OnPropertyChanged();
}
}
public TreeNode SelectedItem
{
get => _selectedItem;
set
{
_selectedItem = value;
OnPropertyChanged();
}
}
public ICommand LoadCommand => _loadCommand ??= new RelayCommand(parameter =>
{
TreeItems = new ObservableCollection<TreeNode>();
JsonReaderOptions options = new JsonReaderOptions
{
AllowTrailingCommas = true,
CommentHandling = JsonCommentHandling.Skip
};
Utf8JsonReader reader = new Utf8JsonReader(File.ReadAllBytes("example.json"), options);
reader.Read();
ReadJson(ref reader, TreeItems);
});
public ICommand SaveCommand => _saveCommand ??= new RelayCommand(parameter =>
{
JsonWriterOptions options = new JsonWriterOptions
{
Indented = true,
Encoder = JavaScriptEncoder.UnsafeRelaxedJsonEscaping
};
using Stream stream = File.Create("out.json");
using Utf8JsonWriter writer = new Utf8JsonWriter(stream, options);
writer.WriteStartObject();
WriteJson(writer, TreeItems);
});
private void WriteJson(Utf8JsonWriter writer, ObservableCollection<TreeNode> items)
{
foreach (TreeNode node in items)
{
switch (node)
{
case TreeValue valueNode:
writer.WriteString(valueNode.Name, valueNode.Value);
break;
case TreeObject objectNode:
writer.WriteStartObject(objectNode.Name);
WriteJson(writer, objectNode.Children);
break;
}
}
writer.WriteEndObject();
}
private void ReadJson(ref Utf8JsonReader reader, ObservableCollection<TreeNode> items)
{
bool complete = false;
string propertyName = "";
while (!complete && reader.Read())
{
switch (reader.TokenType)
{
case JsonTokenType.PropertyName:
propertyName = reader.GetString();
break;
case JsonTokenType.String:
items.Add(new TreeValue { Name = propertyName, Value = reader.GetString() });
break;
case JsonTokenType.StartObject:
ObservableCollection<TreeNode> children = new ObservableCollection<TreeNode>();
items.Add(new TreeObject { Name = propertyName, Children = children });
ReadJson(ref reader, children);
break;
case JsonTokenType.EndObject:
complete = true;
break;
}
}
}
public MainViewModel()
{
TreeItems = new ObservableCollection<TreeNode>();
TreeNode.MainVM = this;
}
}
查看(整个标记)
<Window x:Class="WpfApp1.MainWindow"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
xmlns:local="clr-namespace:WpfApp1"
mc:Ignorable="d"
Title="MainWindow" Height="450" Width="800">
<Window.DataContext>
<local:MainViewModel/>
</Window.DataContext>
<Grid>
<Grid.ColumnDefinitions>
<ColumnDefinition/>
<ColumnDefinition/>
</Grid.ColumnDefinitions>
<TreeView Margin="5" ItemsSource="{Binding TreeItems}">
<TreeView.Resources>
<HierarchicalDataTemplate DataType="{x:Type local:TreeObject}" ItemsSource="{Binding Children}">
<TextBlock Text="{Binding Name}"/>
</HierarchicalDataTemplate>
<DataTemplate DataType="{x:Type local:TreeValue}">
<TextBlock Text="{Binding Name}"/>
</DataTemplate>
<Style TargetType="TreeViewItem">
<Setter Property="IsSelected" Value="{Binding IsSelected}" />
<Setter Property="IsExpanded" Value="True"/>
</Style>
</TreeView.Resources>
</TreeView>
<StackPanel Margin="5" Grid.Column="1">
<StackPanel Orientation="Horizontal">
<Button Content="Load" Padding="5,0" Command="{Binding LoadCommand}"/>
<Button Content="Save" Padding="5,0" Margin="5,0,0,0" Command="{Binding SaveCommand}"/>
</StackPanel>
<TextBlock Text="Name"/>
<TextBox Text="{Binding SelectedItem.Name, UpdateSourceTrigger=PropertyChanged}"/>
<ContentControl Content="{Binding SelectedItem}" Margin="0,5">
<ContentControl.Resources>
<DataTemplate DataType="{x:Type local:TreeObject}">
<WrapPanel>
<TextBlock Text="{Binding Children.Count, StringFormat=Children count: {0}}"/>
</WrapPanel>
</DataTemplate>
<DataTemplate DataType="{x:Type local:TreeValue}">
<StackPanel Orientation="Vertical">
<TextBlock Text="Value"/>
<TextBox Text="{Binding Value, UpdateSourceTrigger=PropertyChanged}"/>
</StackPanel>
</DataTemplate>
</ContentControl.Resources>
</ContentControl>
</StackPanel>
</Grid>
</Window>
关于c# - 使用 WPF 从自定义 JSON 显示 TreeView,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/63656768/
#include using namespace std; class C{ private: int value; public: C(){ value = 0;
这个问题已经有答案了: What is the difference between char a[] = ?string?; and char *p = ?string?;? (8 个回答) 已关闭
关闭。此题需要details or clarity 。目前不接受答案。 想要改进这个问题吗?通过 editing this post 添加详细信息并澄清问题. 已关闭 7 年前。 此帖子已于 8 个月
除了调试之外,是否有任何针对 c、c++ 或 c# 的测试工具,其工作原理类似于将独立函数复制粘贴到某个文本框,然后在其他文本框中输入参数? 最佳答案 也许您会考虑单元测试。我推荐你谷歌测试和谷歌模拟
我想在第二台显示器中移动一个窗口 (HWND)。问题是我尝试了很多方法,例如将分辨率加倍或输入负值,但它永远无法将窗口放在我的第二台显示器上。 关于如何在 C/C++/c# 中执行此操作的任何线索 最
我正在寻找 C/C++/C## 中不同类型 DES 的现有实现。我的运行平台是Windows XP/Vista/7。 我正在尝试编写一个 C# 程序,它将使用 DES 算法进行加密和解密。我需要一些实
很难说出这里要问什么。这个问题模棱两可、含糊不清、不完整、过于宽泛或夸夸其谈,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开,visit the help center . 关闭 1
有没有办法强制将另一个 窗口置于顶部? 不是应用程序的窗口,而是另一个已经在系统上运行的窗口。 (Windows, C/C++/C#) 最佳答案 SetWindowPos(that_window_ha
假设您可以在 C/C++ 或 Csharp 之间做出选择,并且您打算在 Windows 和 Linux 服务器上运行同一服务器的多个实例,那么构建套接字服务器应用程序的最明智选择是什么? 最佳答案 如
你们能告诉我它们之间的区别吗? 顺便问一下,有什么叫C++库或C库的吗? 最佳答案 C++ 标准库 和 C 标准库 是 C++ 和 C 标准定义的库,提供给 C++ 和 C 程序使用。那是那些词的共同
下面的测试代码,我将输出信息放在注释中。我使用的是 gcc 4.8.5 和 Centos 7.2。 #include #include class C { public:
很难说出这里问的是什么。这个问题是含糊的、模糊的、不完整的、过于宽泛的或修辞性的,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开它,visit the help center 。 已关
我的客户将使用名为 annoucement 的结构/类与客户通信。我想我会用 C++ 编写服务器。会有很多不同的类继承annoucement。我的问题是通过网络将这些类发送给客户端 我想也许我应该使用
我在 C# 中有以下函数: public Matrix ConcatDescriptors(IList> descriptors) { int cols = descriptors[0].Co
我有一个项目要编写一个函数来对某些数据执行某些操作。我可以用 C/C++ 编写代码,但我不想与雇主共享该函数的代码。相反,我只想让他有权在他自己的代码中调用该函数。是否可以?我想到了这两种方法 - 在
我使用的是编写糟糕的第 3 方 (C/C++) Api。我从托管代码(C++/CLI)中使用它。有时会出现“访问冲突错误”。这使整个应用程序崩溃。我知道我无法处理这些错误[如果指针访问非法内存位置等,
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 我们不允许提问寻求书籍、工具、软件库等的推荐。您可以编辑问题,以便用事实和引用来回答。 关闭 7 年前。
已关闭。此问题不符合Stack Overflow guidelines 。目前不接受答案。 要求我们推荐或查找工具、库或最喜欢的场外资源的问题对于 Stack Overflow 来说是偏离主题的,因为
我有一些 C 代码,将使用 P/Invoke 从 C# 调用。我正在尝试为这个 C 函数定义一个 C# 等效项。 SomeData* DoSomething(); struct SomeData {
这个问题已经有答案了: Why are these constructs using pre and post-increment undefined behavior? (14 个回答) 已关闭 6
我是一名优秀的程序员,十分优秀!