Welcome to the Treehouse Community

Want to collaborate on code errors? Have bugs you need feedback on? Looking for an extra set of eyes on your latest project? Get support with fellow developers, designers, and programmers of all backgrounds and skill levels here with the Treehouse Community! While you're at it, check out some resources Treehouse students have shared here.

Looking to learn something new?

Treehouse offers a seven day free trial for new students. Get access to thousands of hours of content and join thousands of Treehouse students and alumni in the community today.

Start your free trial

PHP Enhancing a Simple PHP Application Refactoring the Codebase Separating Concerns: MVC

Refactoring the Codebase

<?php foreach ($flavors as $flavor) { echo "<li>" . $flavor["name"] . " " . "+" . $flavor["likes"] . "</li>"; } ?> Why are we putting an empty quotes after the $flavor["name"], but the question said followed by space?

Please may you help, thank you!

index.php
<?php

// INCLUDE MODEL FILE
require_once("flavors.php");



// CONTROLLER CODE
$flavors = get_flavors_by_likes(3);



// VIEW CODE
?><html>
<body>

    <h1>Ye Olde Ice Cream Shoppe</h1>

    <p>We sell amazing flavors of ice cream.</p>

    <h2>Most Popular Flavors</h2>

    <ul>
    <?php
        foreach ($flavors as $flavor) {
            echo "<li>" . $flavor["name"] . " " . "+" . $flavor["likes"] . "</li>";
        }
    ?>
    </ul>

</body>
</html>
flavors.php
<?php

// This function returns all the flavors
// ordered by the date they have been added.
function get_all_flavors() {

    $flavors = array(
        array("name" => "Vanilla", "likes" => 312),
        array("name" => "Cookie Dough", "likes" => 976),
        array("name" => "Peppermint", "likes" => 12),        
        array("name" => "Cake Batter", "likes" => 598),
        array("name" => "Avocado Chocolate", "likes" => 6),        
        array("name" => "Jalapeno So Spicy", "likes" => 3),        
    );

    return $flavors;

}

// This function receives a number as an argument.
// It returns the newest flavors, the most recent
// flavor first. (The number of flavors returned
// corresponds to the number in the argument.)
function get_recent_flavors($number) {

    $recent = array();
    $all = get_all_flavors();

    $total_flavors = count($all);
    $position = 0;

    foreach($all as $flavor) {
        $position = $position + 1;
        if ($total_flavors - $position < $number) {
            $recent[] = $flavor;
        }
    }

    return array_reverse($recent);

}

// This function receives a number as an argument.
// It returns the most popular flavors based on
// the number of likes, the most popular flavor
// first. (The number of flavors returned corresponds
// to the number in the argument.)
function get_flavors_by_likes($number) {

    $all = get_all_flavors();

    $total_flavors = count($all);
    $position = 0;

    $popular = $all;
    usort($popular, function($a, $b) {
        return $b['likes'] - $a['likes'];
    });

    return array_slice($popular, 0, $number);

}

?>

2 Answers

Hello,

In PHP, " " is actually counted as a space. "", would be counted as empty quotes. So:

 echo "<li>" . $flavor["name"] . " " . "+" . $flavor["likes"] . "</li>"

This would write <li>Vanilla +312</li> as opposed to <li>Vanilla+312</li>. (The space is gone).

thank you, its quite better now

Hugo Paz
Hugo Paz
15,622 Points

Hi Moyo,

What you are doing is concatenating the value of those variables with a string containing a space.

Here is an example:

<?php

$first_name = "John";
$last_name = "Doe";

/*if you echo the concatenation of these 2 variables like this:*/

echo $first_name . $last_name;

/*
you get JohnDoe
You want a space between the names so you do it like so:
*/

echo $first_name . ' ' . $last_name;

?>

Hope this helps clear thigs up.

Thank you very much hey, you have enlighten me on that!