ktsu.ToStringJsonConverter
1.2.4
Prefix Reserved
dotnet add package ktsu.ToStringJsonConverter --version 1.2.4
NuGet\Install-Package ktsu.ToStringJsonConverter -Version 1.2.4
<PackageReference Include="ktsu.ToStringJsonConverter" Version="1.2.4" />
<PackageVersion Include="ktsu.ToStringJsonConverter" Version="1.2.4" />
<PackageReference Include="ktsu.ToStringJsonConverter" />
paket add ktsu.ToStringJsonConverter --version 1.2.4
#r "nuget: ktsu.ToStringJsonConverter, 1.2.4"
#:package ktsu.ToStringJsonConverter@1.2.4
#addin nuget:?package=ktsu.ToStringJsonConverter&version=1.2.4
#tool nuget:?package=ktsu.ToStringJsonConverter&version=1.2.4
ktsu.ToStringJsonConverter
A JSON converter factory that serializes objects using their ToString and FromString methods.
Introduction
ToStringJsonConverter
is a JSON converter factory for System.Text.Json that simplifies serialization and deserialization of custom types by leveraging their ToString
and FromString
methods. This approach is particularly useful for value types, strong types, and any other types where a string representation makes logical sense.
Features
- Automatic Type Detection: Automatically identifies types with compatible
FromString
methods. - String-Based Serialization: Converts objects to and from JSON using their string representation.
- Property Name Support: Works with both JSON values and property names.
- Reflection Optimization: Uses cached reflection for improved performance.
- Generic Method Support: Handles both generic and non-generic
FromString
methods.
Installation
Package Manager Console
Install-Package ktsu.ToStringJsonConverter
.NET CLI
dotnet add package ktsu.ToStringJsonConverter
Package Reference
<PackageReference Include="ktsu.ToStringJsonConverter" Version="x.y.z" />
Usage Examples
Basic Example
using System.Text.Json;
using ktsu.ToStringJsonConverter;
// Configure the converter in your JsonSerializerOptions
var options = new JsonSerializerOptions();
options.Converters.Add(new ToStringJsonConverterFactory());
// Example custom type with ToString and FromString
public class CustomId
{
public string Value { get; set; }
public static CustomId FromString(string value) => new() { Value = value };
public override string ToString() => Value;
}
// Serialization
var id = new CustomId { Value = "12345" };
string json = JsonSerializer.Serialize(id, options);
// json is now: "12345"
// Deserialization
CustomId deserialized = JsonSerializer.Deserialize<CustomId>(json, options);
// deserialized.Value is now: "12345"
Integration with Other Converters
using System.Text.Json;
using System.Text.Json.Serialization;
using ktsu.ToStringJsonConverter;
var options = new JsonSerializerOptions
{
WriteIndented = true,
PropertyNamingPolicy = JsonNamingPolicy.CamelCase,
Converters =
{
new ToStringJsonConverterFactory(),
new JsonStringEnumConverter()
}
};
// Now both enum values and custom types with FromString will be handled appropriately
Advanced Usage
Working with Collections of Custom Types
using System.Text.Json;
using ktsu.ToStringJsonConverter;
// Setup serializer options with the converter
var options = new JsonSerializerOptions();
options.Converters.Add(new ToStringJsonConverterFactory());
// A collection of custom types
List<CustomId> ids = new()
{
new CustomId { Value = "A001" },
new CustomId { Value = "B002" },
new CustomId { Value = "C003" }
};
// Serialize the collection
string json = JsonSerializer.Serialize(ids, options);
// json is now: ["A001","B002","C003"]
// Deserialize back to a collection
List<CustomId> deserializedIds = JsonSerializer.Deserialize<List<CustomId>>(json, options);
Using with Dictionaries as Keys
// Custom type can be used as dictionary keys
var dictionary = new Dictionary<CustomId, string>
{
{ new CustomId { Value = "key1" }, "value1" },
{ new CustomId { Value = "key2" }, "value2" }
};
string json = JsonSerializer.Serialize(dictionary, options);
// Serializes as a dictionary with string keys
var deserialized = JsonSerializer.Deserialize<Dictionary<CustomId, string>>(json, options);
// Keys are properly deserialized back to CustomId objects
API Reference
ToStringJsonConverterFactory
The primary class for integrating with System.Text.Json serialization.
Methods
Name | Return Type | Description |
---|---|---|
CanConvert(Type typeToConvert) |
bool |
Determines if a type can be converted by checking for a static FromString method |
CreateConverter(Type typeToConvert, JsonSerializerOptions options) |
JsonConverter |
Creates a type-specific converter instance |
Compatibility Requirements
For a type to work with ToStringJsonConverter, it must meet these requirements:
- Have a public static
FromString(string)
method that returns an instance of the type - Override
ToString()
to provide a string representation that can be reversed byFromString
Contributing
Contributions are welcome! Here's how you can help:
- Fork the repository
- Create your feature branch (
git checkout -b feature/amazing-feature
) - Commit your changes (
git commit -m 'Add some amazing feature'
) - Push to the branch (
git push origin feature/amazing-feature
) - Open a Pull Request
Please make sure to update tests as appropriate.
License
This project is licensed under the MIT License - see the LICENSE.md file for details.
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net8.0 is compatible. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. net9.0 is compatible. net9.0-android was computed. net9.0-browser was computed. net9.0-ios was computed. net9.0-maccatalyst was computed. net9.0-macos was computed. net9.0-tvos was computed. net9.0-windows was computed. net10.0 was computed. net10.0-android was computed. net10.0-browser was computed. net10.0-ios was computed. net10.0-maccatalyst was computed. net10.0-macos was computed. net10.0-tvos was computed. net10.0-windows was computed. |
-
net8.0
- ktsu.Extensions (>= 1.5.5)
-
net9.0
- ktsu.Extensions (>= 1.5.5)
NuGet packages (3)
Showing the top 3 NuGet packages that depend on ktsu.ToStringJsonConverter:
Package | Downloads |
---|---|
ktsu.AppDataStorage
Application data management library using JSON serialization to save and load data in the user's app data folder. |
|
ktsu.Schema
Schema |
|
ktsu.PkmnDB
PkmnDB |
GitHub repositories
This package is not used by any popular GitHub repositories.
Version | Downloads | Last Updated |
---|---|---|
1.2.4 | 261 | 5/21/2025 |
1.2.4-pre.17 | 111 | 5/20/2025 |
1.2.4-pre.15 | 73 | 5/17/2025 |
1.2.4-pre.14 | 133 | 5/16/2025 |
1.2.4-pre.13 | 200 | 5/15/2025 |
1.2.4-pre.12 | 207 | 5/14/2025 |
1.2.4-pre.11 | 200 | 5/13/2025 |
1.2.4-pre.10 | 236 | 5/12/2025 |
1.2.4-pre.9 | 164 | 5/11/2025 |
1.2.4-pre.8 | 107 | 5/10/2025 |
1.2.4-pre.7 | 48 | 5/9/2025 |
1.2.4-pre.6 | 125 | 5/8/2025 |
1.2.4-pre.5 | 121 | 5/7/2025 |
1.2.4-pre.4 | 122 | 5/6/2025 |
1.2.4-pre.3 | 114 | 5/5/2025 |
1.2.4-pre.2 | 125 | 5/4/2025 |
1.2.4-pre.1 | 118 | 5/4/2025 |
1.2.3 | 2,796 | 5/4/2025 |
1.2.3-pre.1 | 51 | 4/26/2025 |
1.2.2 | 585 | 4/25/2025 |
1.2.2-pre.1 | 124 | 4/4/2025 |
1.2.1 | 698 | 3/30/2025 |
1.2.0 | 382 | 3/30/2025 |
1.1.1-pre.3 | 80 | 3/29/2025 |
1.1.1-pre.2 | 461 | 3/25/2025 |
1.1.1-pre.1 | 77 | 2/18/2025 |
1.1.0 | 954 | 2/17/2025 |
1.0.49-pre.3 | 86 | 2/6/2025 |
1.0.49-pre.2 | 68 | 2/5/2025 |
1.0.49-pre.1 | 69 | 2/5/2025 |
1.0.48 | 2,484 | 12/27/2024 |
1.0.48-pre.30 | 71 | 2/4/2025 |
1.0.48-pre.29 | 68 | 2/3/2025 |
1.0.48-pre.28 | 77 | 2/1/2025 |
1.0.48-pre.27 | 68 | 1/30/2025 |
1.0.48-pre.26 | 66 | 1/28/2025 |
1.0.48-pre.25 | 64 | 1/26/2025 |
1.0.48-pre.24 | 67 | 1/24/2025 |
1.0.48-pre.23 | 70 | 1/22/2025 |
1.0.48-pre.22 | 64 | 1/20/2025 |
1.0.48-pre.21 | 61 | 1/18/2025 |
1.0.48-pre.20 | 58 | 1/16/2025 |
1.0.48-pre.19 | 51 | 1/14/2025 |
1.0.48-pre.18 | 58 | 1/13/2025 |
1.0.48-pre.17 | 66 | 1/11/2025 |
1.0.48-pre.16 | 61 | 1/10/2025 |
1.0.48-pre.15 | 63 | 1/10/2025 |
1.0.48-pre.14 | 54 | 1/8/2025 |
1.0.48-pre.13 | 72 | 1/7/2025 |
1.0.48-pre.12 | 74 | 1/5/2025 |
1.0.48-pre.11 | 93 | 1/3/2025 |
1.0.48-pre.10 | 69 | 1/3/2025 |
1.0.48-pre.9 | 73 | 1/3/2025 |
1.0.48-pre.8 | 75 | 1/3/2025 |
1.0.48-pre.7 | 68 | 1/2/2025 |
1.0.48-pre.6 | 94 | 12/31/2024 |
1.0.48-pre.5 | 72 | 12/30/2024 |
1.0.48-pre.4 | 75 | 12/29/2024 |
1.0.48-pre.3 | 63 | 12/28/2024 |
1.0.48-pre.2 | 65 | 12/27/2024 |
1.0.48-pre.1 | 68 | 12/27/2024 |
1.0.47-pre.1 | 72 | 12/27/2024 |
1.0.46 | 290 | 12/26/2024 |
1.0.45 | 105 | 12/26/2024 |
1.0.44 | 99 | 12/26/2024 |
1.0.43 | 96 | 12/26/2024 |
1.0.42 | 106 | 12/26/2024 |
1.0.41 | 120 | 12/26/2024 |
1.0.40 | 98 | 12/26/2024 |
1.0.39 | 105 | 12/25/2024 |
1.0.38 | 255 | 12/23/2024 |
1.0.37 | 262 | 12/23/2024 |
1.0.36 | 96 | 12/23/2024 |
1.0.35 | 128 | 12/23/2024 |
1.0.34 | 326 | 12/19/2024 |
1.0.33 | 246 | 12/16/2024 |
1.0.32 | 336 | 12/6/2024 |
1.0.31 | 276 | 12/5/2024 |
1.0.30 | 153 | 12/4/2024 |
1.0.29 | 254 | 12/2/2024 |
1.0.28 | 119 | 12/2/2024 |
1.0.27 | 140 | 12/2/2024 |
1.0.26 | 185 | 12/1/2024 |
1.0.25 | 184 | 12/1/2024 |
1.0.24 | 155 | 11/30/2024 |
1.0.23 | 119 | 11/29/2024 |
1.0.22 | 205 | 11/27/2024 |
1.0.21 | 179 | 11/26/2024 |
1.0.20 | 198 | 11/20/2024 |
1.0.19 | 314 | 11/15/2024 |
1.0.18 | 187 | 11/14/2024 |
1.0.17 | 175 | 11/13/2024 |
1.0.16 | 423 | 11/4/2024 |
1.0.15 | 180 | 11/1/2024 |
1.0.14 | 594 | 10/17/2024 |
1.0.13 | 400 | 10/7/2024 |
1.0.12 | 158 | 10/4/2024 |
1.0.11 | 321 | 9/23/2024 |
1.0.10 | 142 | 9/20/2024 |
1.0.10-pre.1 | 57 | 12/27/2024 |
1.0.9 | 163 | 9/19/2024 |
1.0.8 | 167 | 9/19/2024 |
1.0.7 | 114 | 9/19/2024 |
1.0.6 | 142 | 9/19/2024 |
1.0.5 | 123 | 9/18/2024 |
1.0.4 | 117 | 9/18/2024 |
1.0.3 | 229 | 9/18/2024 |
1.0.2 | 156 | 9/18/2024 |
1.0.1 | 224 | 9/14/2024 |
1.0.0 | 125 | 9/14/2024 |
## v1.2.4
Initial release or repository with no prior history.