Help coderanch get a
new server
by contributing to the fundraiser
  • Post Reply Bookmark Topic Watch Topic
  • New Topic
programming forums Java Mobile Certification Databases Caching Books Engineering Micro Controllers OS Languages Paradigms IDEs Build Tools Frameworks Application Servers Open Source This Site Careers Other Pie Elite all forums
this forum made possible by our volunteer staff, including ...
Marshals:
  • Campbell Ritchie
  • Ron McLeod
  • Paul Clapham
  • Devaka Cooray
  • Liutauras Vilda
Sheriffs:
  • Jeanne Boyarsky
  • paul wheaton
  • Henry Wong
Saloon Keepers:
  • Stephan van Hulst
  • Tim Holloway
  • Tim Moores
  • Carey Brown
  • Mikalai Zaikin
Bartenders:
  • Lou Hamers
  • Piet Souris
  • Frits Walraven

Data structure choice

 
Ranch Hand
Posts: 346
10
Eclipse IDE Chrome Linux
  • Mark post as helpful
  • send pies
    Number of slices to send:
    Optional 'thank-you' note:
  • Quote
  • Report post to moderator
I am building a simple jsp page where I have list of items that have a title, a description and an image. I am trying to make it easy for non-programmer to edit the list (and make it generally more readable). My thoughts are that I could write a JSON or YAML file that is then used by the jsp file to display the list.

Are either formats a good idea, or would there be something better? (Note: it is such a small application that I think a database might be too cumbersome).
 
best scout
Posts: 1294
Scala IntelliJ IDE Java
  • Mark post as helpful
  • send pies
    Number of slices to send:
    Optional 'thank-you' note:
  • Quote
  • Report post to moderator
Hi Adrien,

in my opinion it's a matter of taste and the tooling you have available. Obviously data formats like JSON or YAML are less verbose than XML and should be easier to understand and read by non-technical folks. Despite that fact I personally still often prefer XML over the others because with the right tooling (for example IntelliJ IDEA) it gives me excellent tool support like auto-completion and data validation (structure and content).

But if other people will have to read or edit the said files you probably should simply ask for their opinions ;-)


Marco
 
Adrien Lapointe
Ranch Hand
Posts: 346
10
Eclipse IDE Chrome Linux
  • Mark post as helpful
  • send pies
    Number of slices to send:
    Optional 'thank-you' note:
  • Quote
  • Report post to moderator

Marco Ehrentreich wrote:
But if other people will have to read or edit the said files you probably should simply ask for their opinions ;-)



hehe, it is not always going to be the same people over time. The main characteristic is: non-technical/might be afraid of code looking stuff (xml would fit in that category)

I like how YAML is really easy to figure out. So I think I'll go with it. Any recommendations for a good parser?
 
Sheriff
Posts: 67750
173
Mac Mac OS X IntelliJ IDE jQuery TypeScript Java iOS
  • Likes 2
  • Mark post as helpful
  • send pies
    Number of slices to send:
    Optional 'thank-you' note:
  • Quote
  • Report post to moderator
Why not just go with a simple properties file that Java already knows and loves?
 
Adrien Lapointe
Ranch Hand
Posts: 346
10
Eclipse IDE Chrome Linux
  • Likes 1
  • Mark post as helpful
  • send pies
    Number of slices to send:
    Optional 'thank-you' note:
  • Quote
  • Report post to moderator
simply because I did not know about them... (I know enough Java to get in trouble I think)

I like that I would not have to find a third party library.
 
Bear Bibeault
Sheriff
Posts: 67750
173
Mac Mac OS X IntelliJ IDE jQuery TypeScript Java iOS
  • Mark post as helpful
  • send pies
    Number of slices to send:
    Optional 'thank-you' note:
  • Quote
  • Report post to moderator
 
Adrien Lapointe
Ranch Hand
Posts: 346
10
Eclipse IDE Chrome Linux
  • Mark post as helpful
  • send pies
    Number of slices to send:
    Optional 'thank-you' note:
  • Quote
  • Report post to moderator
hmmm, looking at the properties files format, I cannot seem to find a way to express different instances of an item. For instance, in YAML I would write




Where the --- indicates a different item.
 
Author and all-around good cowpoke
Posts: 13078
6
  • Mark post as helpful
  • send pies
    Number of slices to send:
    Optional 'thank-you' note:
  • Quote
  • Report post to moderator

hmmm, looking at the properties files format, I cannot seem to find a way to express different instances of an item.



In properties files that is usually handled with more elaborate names -easy to understand and fairly simple to parsel

Say:

book.1.title = ......
book.1.image = ........
book.1.link = ........
book.2.title = ........

etc

You can see some more examples of properties files with this kind of naming in typical Tomcat conf files

Don't let users edit properties files with MS Word due to the "smart" punctuation

Bill

 
Bear Bibeault
Sheriff
Posts: 67750
173
Mac Mac OS X IntelliJ IDE jQuery TypeScript Java iOS
  • Mark post as helpful
  • send pies
    Number of slices to send:
    Optional 'thank-you' note:
  • Quote
  • Report post to moderator
Yes, with properties files, it is a simple key-to-text equivalence. This is perfect for things like translations (or, ahem, properties). You can impose an artificial hierarchy with dots (e.g. name.bill=Bill, name.bear =Bear) but you'd have to do the parsing yourself.

[Edit: I see William beat me to the punch]

If you need complex objects with grouping, you might want to go with something more complex such as yaml or json.

If you just need text substitution, and want to handle it on the client, you might want to think about using JSON with jQuery Ajax and a JavaScript templating engine such as Handlebars.
 
Adrien Lapointe
Ranch Hand
Posts: 346
10
Eclipse IDE Chrome Linux
  • Mark post as helpful
  • send pies
    Number of slices to send:
    Optional 'thank-you' note:
  • Quote
  • Report post to moderator

Bear Bibeault wrote:
If you need complex objects with grouping, you might want to go with something more complex such as yaml or json.



it looks like either would be the way to go. It would be error prone to have the editors manually serialize each item.

Bear Bibeault wrote:
If you just need text substitution, and want to handle it on the client, you might want to think about using JSON with jQuery Ajax and a JavaScript templating engine such as Handlebars.



All I would do is generate an html unordered list from the items in the yaml/json. I am thinking it would be better on the server side, but I am not totally up to date with the current best practices.

 
Bear Bibeault
Sheriff
Posts: 67750
173
Mac Mac OS X IntelliJ IDE jQuery TypeScript Java iOS
  • Mark post as helpful
  • send pies
    Number of slices to send:
    Optional 'thank-you' note:
  • Quote
  • Report post to moderator
Could easily also be done on the server. There are JSON and yaml parsers available. You could digest the file into a data construct to send to a JSP to use as the template with JSTL and EL.
 
Adrien Lapointe
Ranch Hand
Posts: 346
10
Eclipse IDE Chrome Linux
  • Mark post as helpful
  • send pies
    Number of slices to send:
    Optional 'thank-you' note:
  • Quote
  • Report post to moderator
From a design point of view, would it be more appropriate on the server or client side?
 
William Brogden
Author and all-around good cowpoke
Posts: 13078
6
  • Mark post as helpful
  • send pies
    Number of slices to send:
    Optional 'thank-you' note:
  • Quote
  • Report post to moderator

Adrien Lapointe wrote:From a design point of view, would it be more appropriate on the server or client side?



I would certainly do all selection on the server for the following reasons:

1. minimum amount of text sent to client
2. flexibility if you need to grow the properties with more data types, for example cds or tapes
3. less dependence on client capabilities

Bill
 
Bear Bibeault
Sheriff
Posts: 67750
173
Mac Mac OS X IntelliJ IDE jQuery TypeScript Java iOS
  • Likes 1
  • Mark post as helpful
  • send pies
    Number of slices to send:
    Optional 'thank-you' note:
  • Quote
  • Report post to moderator
For simplicity, I'd probably go server-side unless there's a good reason not to. But I disagree with William's points (1) and (3). The difference in response size would be marginal at best, and anyone using a browser that can't handle basic JavaScript at this point doesn't deserve to be on the web.
 
Adrien Lapointe
Ranch Hand
Posts: 346
10
Eclipse IDE Chrome Linux
  • Likes 1
  • Mark post as helpful
  • send pies
    Number of slices to send:
    Optional 'thank-you' note:
  • Quote
  • Report post to moderator
Thanks everybody for your inputs!

Server side it is for this app then.
 
reply
    Bookmark Topic Watch Topic
  • New Topic