Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Bind object properties with string dynamically

I have a below class

public class SearchModel
{
    public string Locations { get; set; }
    public string City { get; set; }
    public string Address { get; set; } 
    public string MaxRecord { get; set; }
    public string PageSize { get; set; }
    ....
    ....
    Approx 80 properties
}

I have a query string like "my location_Locations/new york_City/city street_Address/200_MaxRecord/20_PageSize"

Above string contains the exact property names of the class SearchModel. Now I want to do something like below:-

SearchModel model = new SearchModel();
string[] Parameters = "my location_Locations/new york_City/city street_Address/200_MaxRecord/20_PageSize".Split('/');
foreach (string item in Parameters)
{
    string[] value=item.Split('_');
    model.value[1] = value[0];
}
like image 424
Jitendra Pancholi Avatar asked Oct 01 '22 07:10

Jitendra Pancholi


1 Answers

add following codes to your class

public class SearchModel
{
    public object this[string propertyName] 
    {
        get{
           Type myType = typeof(MyClass);                   
           PropertyInfo myPropInfo = myType.GetProperty(propertyName);
           return myPropInfo.GetValue(this, null);
        }
        set{
           Type myType = typeof(SearchModel);
            PropertyInfo myPropInfo = myType.GetProperty(propertyName);
            switch (myPropInfo.PropertyType.Name)
            {
                case "Int32":
                    myPropInfo.SetValue(this, Convert.ToInt32(value), null);
                    break;
                case "Int64":
                    myPropInfo.SetValue(this, Convert.ToInt64(value), null);
                    break;
                case "Boolean":
                    myPropInfo.SetValue(this, Convert.ToBoolean(value), null);
                    break;
                case "DateTime":
                    myPropInfo.SetValue(this, Convert.ToDateTime(value), null);
                    break;
                case "String":
                    myPropInfo.SetValue(this, value.ToString(), null);
                    break;
                default:
                    myPropInfo.SetValue(this, value, null);
                    break;
            } 
        }
    }
}

and your modified codes

SearchModel model = new SearchModel();
string[] Parameters = "my location_Locations/new york_City/city street_Address/200_MaxRecord/20_PageSize".Split('/');
foreach (string item in Parameters)
{
    string[] value= item.Split('_');
    // I changed this line
    model[value[1]] = value[0];
}

OR


SearchModel model = new SearchModel();
string[] Parameters = "my location_Locations/new york_City/city street_Address/200_MaxRecord/20_PageSize".Split('/');
foreach (string item in Parameters)
{
    string[] value= item.Split('_');

    PropertyInfo propertyInfo = model.GetType().GetProperty(value[1]);
    propertyInfo.SetValue(model, Convert.ChangeType(value[0], propertyInfo.PropertyType),
}

For case insensitive:

model.GetType().GetProperty(value[1], BindingFlags.IgnoreCase |  BindingFlags.Public | BindingFlags.Instance )
like image 88
AliRıza Adıyahşi Avatar answered Oct 20 '22 17:10

AliRıza Adıyahşi