Solved

returning an element from JSON

Posted on 2013-05-20
2
320 Views
Last Modified: 2013-06-03
Im trying to get just 1 element from a JSON request:-
switch (json_decode($rowNewInput['json'])['type']) { 

Open in new window


The contents of "$rowNewInput['json']" are:-

{
"type" : "combo",
"attribute" : "SQL",
"values" : "Select distinct `First Name` from `staff`;"
}

And all I want is the 'combo' value.

Although I could decode the JSON into a variable and then pull the variable out of the created array, I was hoping to do it all on one line.

However I get an error to saying:-
Parse error: syntax error, unexpected '['

Any suggestions what Im doing wrong?

Thanks in advance.
0
Comment
Question by:tonelm54
2 Comments
 
LVL 108

Accepted Solution

by:
Ray Paseur earned 500 total points
Comment Utility
JSON uses object-oriented notation, not array notation.  Try the -> instead of the brackets and quotes.

Also, trying to "do it all on one line" is a fools errand.  That kind of code makes it harder to debug and understand the data structures.  Use as many statements as needed, no less, no more!
http://www.laprbass.com/RAY_temp_tonelm54.php

<?php // RAY_temp_tonelm54.php
error_reporting(E_ALL);

$jso = <<<EOD
{
"type" : "combo",
"attribute" : "SQL",
"values" : "Select distinct `First Name` from `staff`;"
}
EOD;

// DECODE THE STRING INTO AN OBJECT
$obj = json_decode($jso);

// ACTIVATE THIS TO SEE WHAT IS IN THE OBJECT
// var_dump($obj);

// WHAT IS IN THE type PROPERTY
var_dump($obj->type);

Open in new window

Best regards, ~Ray
0
 
LVL 33

Expert Comment

by:Slick812
Comment Utility
greetings  tonelm54, , not sure about how you "think" about the methods you use in your code, as you have a PHP ['type']  array access for what you have as a javascript object in the javascript object notation string. I have to work in PHP and javascript at the same time to build pages, and often get mixed up in the code syntax for each,
In javascript you are allowed to access OBJECT properties with array methods like - jsobj['type'] - , but in PHP this is not allowed, , I often forget which Object access to use, and put -> in javascript and put a "." in PHP, which causes fatal errors in either one.
If you are used to javascript, you will need to watch your code when changing to PHP code writing, as many things like ['type'] for object access will get you  -
Parse error: syntax error, unexpected '['

and -
switch (json_decode($rowNewInput['json'])->type) {
just might work

but if I forget and use -
switch (json_decode($rowNewInput['json']).type) {
it does Not work.

for your own development error trace, I have found that compound abstraction code like -
switch (json_decode($rowNewInput['json'])->type) {
is harder to debug.

I like this better for debugging -
    $newIn = json_decode($rowNewInput['json']);
    switch ($newIn->type) {
because you can more clearly see what line and method causes the error
0

Featured Post

How to run any project with ease

Manage projects of all sizes how you want. Great for personal to-do lists, project milestones, team priorities and launch plans.
- Combine task lists, docs, spreadsheets, and chat in one
- View and edit from mobile/offline
- Cut down on emails

Join & Write a Comment

Nothing in an HTTP request can be trusted, including HTTP headers and form data.  A form token is a tool that can be used to guard against request forgeries (CSRF).  This article shows an improved approach to form tokens, making it more difficult to…
This article discusses how to create an extensible mechanism for linked drop downs.
The viewer will learn how to dynamically set the form action using jQuery.
The viewer will learn how to create a basic form using some HTML5 and PHP for later processing. Set up your basic HTML file. Open your form tag and set the method and action attributes.: (CODE) Set up your first few inputs one for the name and …

771 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question

Need Help in Real-Time?

Connect with top rated Experts

8 Experts available now in Live!

Get 1:1 Help Now