在HTML页面中编写PHP代码的优选方法? [关闭]

I'm wondering if there is a standard rule or method when trying to construct a dynamic html page that consist of both html and php.

For example most of the time I code whatever pops up on my head and my php will end up looking like this:

<div class="front-title-blocks">
      <div class="table">
        <div class="table-row">

            <?php while ($wp_query->have_posts()) : $wp_query->the_post(); 
                if( have_rows('table_row') ):
                   while ( have_rows('table_row') ) : the_row(); ?>
                            <div class="table-cell">
                                <?php the_sub_field('single_cell'); ?>
                            </div> 
                    <?php endwhile; else :
                        // no row found
                endif; ?>
            <?php endwhile;  ?>

        </div>
      </div>
</div>

Then I noticed the same code that carried out the exact same function can be re-written like this.

<?php

while ($wp_query->have_posts()) : $wp_query->the_post();
    function repeaterField(){
            $output='';
            if( have_rows('table-b-table') ):
                while ( have_rows('table_row') ) : the_row();
                        $output .= "<div class='table-cell'>".get_sub_field('single_cell')."</div>";
                 endwhile; else : // no row found
            endif;
            return $output;
    }

    $output = "<div class='front-title-blocks'>
                  <div class='table'>
                       <div class='table-row'>".repeaterField()."</div>
                   </div>
                </div>";
endwhile; 

echo $output;

?>

The difference that I noticed:

• First example has multiple opening and closing php tag that switch between html and php continuously.

• Second example tend use php all the way and can be echo out easily using a variable.

• Second example took longer time to construct and rearrange.

• For arrangement sake I feel like second one is more organize but I do notice that the first example is easier to read though.

Any advise would be appreciated.

The first option it's 'better' (or I prefered this) for various reasons: because it's more readable, with code editors you could have syntaxis help and autocomplete and the page loads faster.

Another thing to consider is that you will be dealing with double and simple quotes in the second method that could cause errors:

echo "<div id='a'"+$var+"'...>";

But the 2 options are valid.

There are others questions like that: Outputting HTML with echo considered bad practice in PHP?

The first method is good. The second in a bad idea.

All code inside of <?php ?> is sent to PHP to be interpreted.This means your website is slower. So don't echo HTML tags without any reason.

You could try out some templating engine like Twig for server side page generation.

For example Twig allows you to do this:

{{ var }}

instead of this:

<?php echo $var ?>

You can also do stuff like this:

<h1>Members</h1>
<ul>
    {% for user in users %}
        <li>{{ user.username|e }}</li>
    {% endfor %}
</ul>

Twig references

gogle: php template engine - for other templating engines

There's a third choice:

<html>
....
<body>
....    
<?php
while ($wp_query->have_posts()) : $wp_query->the_post();    
    if (have_rows('table-b-table')):
        while (have_rows('table_row')) : the_row();
            $var1 = get_sub_field('single_cell');
            include 'template.php';
        endwhile;
    endif;    
endwhile
?>
...
</body></html>

template.php

<div class='front-title-blocks'>
    <div class='table'>
        <div class='table-row'>
            <div class='table-cell'>
                <?= $var1 ?>
            </div>
        </div>
    </div>
</div>

Personally I prefer this one because it minimizes HTML code within PHP tags.

Yess first option is good ,go with it

but we have some shortcodes tags like you should do settings in the php.ini file for shortcodes