0

I want to create json data at code behind which is like treeview components example at below;

I can parse like first one but I don't know how to generate others (for ex.; tree_data['for-sale']['additionalParameters'])

Sample Data

    var tree_data = {
        'for-sale': { name: 'For Sale', type: 'folder' },
        'vehicles': { name: 'Vehicles', type: 'folder' },
        'rentals': { name: 'Rentals', type: 'folder' },
        'real-estate': { name: 'Real Estate', type: 'folder' },
        'pets': { name: 'Pets', type: 'folder' },
        'tickets': { name: 'Tickets', type: 'item' },
        'services': { name: 'Services', type: 'item' },
        'personals': { name: 'Personals', type: 'item' }
    }

    tree_data['for-sale']['additionalParameters'] = {
        'children': {
            'appliances': { name: 'Appliances', type: 'item' },
            'arts-crafts': { name: 'Arts & Crafts', type: 'item' },
            'clothing': { name: 'Clothing', type: 'item' },
            'computers': { name: 'Computers', type: 'item' },
            'jewelry': { name: 'Jewelry', type: 'item' },
            'office-business': { name: 'Office & Business', type: 'item' },
            'sports-fitness': { name: 'Sports & Fitness', type: 'item' }
        }
    }

    tree_data['vehicles']['additionalParameters'] = {
        'children': {
            'cars': { name: 'Cars', type: 'folder' },
            'motorcycles': { name: 'Motorcycles', type: 'item' },
            'boats': { name: 'Boats', type: 'item' }
        }
    }

    tree_data['vehicles']['additionalParameters']['children']['cars']['additionalParameters'] = {
        'children': {
            'classics': { name: 'Classics', type: 'item' },
            'convertibles': { name: 'Convertibles', type: 'item' },
            'coupes': { name: 'Coupes', type: 'item' },
            'hatchbacks': { name: 'Hatchbacks', type: 'item' },
            'hybrids': { name: 'Hybrids', type: 'item' },
            'suvs': { name: 'SUVs', type: 'item' },
            'sedans': { name: 'Sedans', type: 'item' },
            'trucks': { name: 'Trucks', type: 'item' }
        }
    }

    tree_data['rentals']['additionalParameters'] = {
        'children': {
            'apartments-rentals': { name: 'Apartments', type: 'item' },
            'office-space-rentals': { name: 'Office Space', type: 'item' },
            'vacation-rentals': { name: 'Vacation Rentals', type: 'item' }
        }
    }

    tree_data['real-estate']['additionalParameters'] = {
        'children': {
            'apartments': { name: 'Apartments', type: 'item' },
            'villas': { name: 'Villas', type: 'item' },
            'plots': { name: 'Plots', type: 'item' }
        }
    }

    tree_data['pets']['additionalParameters'] = {
        'children': {
            'cats': { name: 'Cats', type: 'item' },
            'dogs': { name: 'Dogs', type: 'item' },
            'horses': { name: 'Horses', type: 'item' },
            'reptiles': { name: 'Reptiles', type: 'item' }
        }
    }
1
  • I suggest you take a look at the JObject class in Json.Net. It will allow you to easily add properties and objects. Commented Aug 12, 2014 at 7:27

1 Answer 1

1

The JSON string must have all its key and value pair enclosed with '"' (double quotes). For assigning the variables with JSON string, you have to do :

var tree_data = {
    "for-sale": { "name": "For Sale", "type": "folder" },
    "vehicles": { "name": "Vehicles", "type": "folder" },
    "rentals": { "name": "Rentals", "type": "folder" },
    "real-estate": { "name": "Real Estate", "type": "folder" },
    "pets": { "name": "Pets", "type": "folder" },
    "tickets": { "name": "Tickets", "type": "item" },
    "services": { "name": "Services", "type": "item" },
    "personals": { "name": "Personals", "type": "item" }
}

tree_data["for-sale"]["additionalParameters"] = {
    "children": {
        "appliances": { "name": "Appliances", "type": "item" },
        "arts-crafts": { "name": "Arts & Crafts", "type": "item" },
        "clothing": { "name": "Clothing", "type": "item" },
        "computers": { "name": "Computers", "type": "item" },
        "jewelry": { "name": "Jewelry", "type": "item" },
        "office-business": { "name": "Office & Business", "type": "item" },
        "sports-fitness": { "name": "Sports & Fitness", "type": "item" }
    }
}

The required JSON as per your requirement is shown below as an example.

[{
    "for-sale": {
        "name": "ForSale",
        "type": "folder",
        "additionalParameters": {
            "children": {
                "appliances": {
                    "name": "Appliances",
                    "type": "item"
                },
                "arts-crafts": {
                    "name": "Arts&Crafts",
                    "type": "item"
                },
                "clothing": {
                    "name": "Clothing",
                    "type": "item"
                },
                "computers": {
                    "name": "Computers",
                    "type": "item"
                },
                "jewelry": {
                    "name": "Jewelry",
                    "type": "item"
                },
                "office-business": {
                    "name": "Office&Business",
                    "type": "item"
                },
                "sports-fitness": {
                    "name": "Sports&Fitness",
                    "type": "item"
                }
            }
        }
    },
    "vehicles": {
        "name": "Vehicles",
        "type": "folder"
    },
    "rentals": {
        "name": "Rentals",
        "type": "folder"
    },
    "real-estate": {
        "name": "RealEstate",
        "type": "folder"
    },
    "pets": {
        "name": "Pets",
        "type": "folder"
    },
    "tickets": {
        "name": "Tickets",
        "type": "item"
    },
    "services": {
        "name": "Services",
        "type": "item"
    },
    "personals": {
        "name": "Personals",
        "type": "item"
    }
}]
Sign up to request clarification or add additional context in comments.

2 Comments

I made like this but didn't worked. var tree_data =[{ "for-sale": { ... "personals": { "name": "Personals", "type": "item"}}]
Yes, "[" and "]" is used whenever we use an array. It cannot be used at the most outer level. So, removing it will work fine.

Your Answer

By clicking “Post Your Answer”, you agree to our terms of service and acknowledge you have read our privacy policy.

Start asking to get answers

Find the answer to your question by asking.

Ask question

Explore related questions

See similar questions with these tags.