Table of Contents
Reply content:
Home Backend Development PHP Tutorial How to separate PHP from HTML code?

How to separate PHP from HTML code?

Sep 06, 2016 am 08:57 AM
html javascript mysql php

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

<code><?php

include "db.php";

if(isset($_POST["category"])){

 

    $category_query = "SELECT * FROM categories";

 

    $run_query = mysqli_query($con,$category_query);

    echo "

    <div class='nav nav-pills nav-stacked'>

    <li class='active'><a href='#'><h4>Categories</h4></a></li>

    ";

if(mysqli_num_rows($run_query)>0){

     

        while($row = mysqli_fetch_array($run_query)){

            $cid = $row["cat_id"];

            $cat_name = $row["cat_title"];

            echo "

<li><a href='#' class='category' cid='$cid'>$cat_name</a></li>

            ";

        }

        echo "</div>";

    }

}

?></code>

Copy after login
Copy after login

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

<code>//JS

$(document).ready(function() {

    cat();

    function cat() {

        $.ajax({

                url: 'action.php',

                type: 'POST',

                data: {

                    category: 1

                }

            })

            .done(function(data) {

                //console.log(data);

                $("#get_category").html(data);

 

            });

    }

})</code>

Copy after login
Copy after login

I am new to PHP. Is there any way to separate the front-end and back-end and return the echo HTML code in json format to the front-end for processing?

Reply content:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

<code><?php

include "db.php";

if(isset($_POST["category"])){

 

    $category_query = "SELECT * FROM categories";

 

    $run_query = mysqli_query($con,$category_query);

    echo "

    <div class='nav nav-pills nav-stacked'>

    <li class='active'><a href='#'><h4>Categories</h4></a></li>

    ";

if(mysqli_num_rows($run_query)>0){

     

        while($row = mysqli_fetch_array($run_query)){

            $cid = $row["cat_id"];

            $cat_name = $row["cat_title"];

            echo "

<li><a href='#' class='category' cid='$cid'>$cat_name</a></li>

            ";

        }

        echo "</div>";

    }

}

?></code>

Copy after login
Copy after login

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

<code>//JS

$(document).ready(function() {

    cat();

    function cat() {

        $.ajax({

                url: 'action.php',

                type: 'POST',

                data: {

                    category: 1

                }

            })

            .done(function(data) {

                //console.log(data);

                $("#get_category").html(data);

 

            });

    }

})</code>

Copy after login
Copy after login

I am new to PHP. Is there any way to separate the front-end and back-end and return the echo HTML code in json format to the front-end for processing?

With just a few lines of code, you can separate the interface and logic and implement MVC:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

<code>/index.php (页面控制器)

if(!defined('ROOT')) define('ROOT', __DIR__);

require ROOT.'/include/common.php';

echo render('index.php'); //输出HTML

echo json_encode(array('Server'=>'PHP')); //输出JSON

 

/include/common.php (公共操作)

if(!defined('ROOT')) exit();

require ROOT.'/include/funclass.php';

 

/include/funclass.php (函数和类)

if(!defined('ROOT')) exit();

function render($view) {

    ob_end_clean();    ob_start();

    require ROOT.'/view/'.$view;

    $html = ob_get_contents();

    ob_end_clean(); ob_start();

    return $html;

}

 

/view/index.php (视图)

require __DIR__.'/header.php'; //if(!defined('ROOT')) exit();

require __DIR__.'/footer.php'; //JS代码一般写在footer.php里</body>前面</code>

Copy after login

1

<code>PHP中</code>

Copy after login

1

<code>echo json_encode($html);</code>

Copy after login

1

<code>前端</code>

Copy after login

1

2

3

<code>success: function(data) {

    $("#get_category").html(data);

}</code>

Copy after login

PHP does this, put it in a separate file, and js can request this file

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

<code><?php

include "db.php";

if(isset($_POST["category"])){

 

    $category_query = "SELECT * FROM categories";

 

    $run_query = mysqli_query($con,$category_query);

    $html="";

    $html.="<div class='nav nav-pills nav-stacked'><li class='active'><a href='#'><h4>Categories</h4></a></li>";

    if(mysqli_num_rows($run_query)>0){  

        while($row = mysqli_fetch_array($run_query)){

            $cid = $row["cat_id"];

            $cat_name = $row["cat_title"];

            $html.="<li><a href='#' class='category' cid='$cid'>$cat_name</a></li>";

        }

        $html.="</div>";

        echo $html;

    }

}

?></code>

Copy after login

Convert the data found in the database into an array, output it under json_encode, call it with js, get the data, traverse the array with js (in the done of ajax that splices the html), and splice the html, so that php and html are completely separated

I think we can first determine what content we want to display on the front-end page. Assume that the content is available and the page is written based on the content. The rest is the data corresponding to the content.
As mentioned above, PHP provides an API interface, such as returning json data, and the data inside can be requested from the server through ajax. After getting the data, just use js to fill the data into the page.

I think you may be thinking about a question. It's just an issue with the output list, right? This can be done simply
After sending ajax to the front end, the front end gets the json object and can use the front end template engine to do it. Recommend you to use juicer

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

<code><script id="tpl" type="text/template">

    <ul>

        {@each list as it,index}

            <li>${it.name} (index: ${index})</li>

        {@/each}

        {@each blah as it}

            <li>

                num: ${it.num} <br />

                {@if it.num==3}

                    {@each it.inner as it2}

                        ${it2.time} <br />

                    {@/each}

                {@/if}

            </li>

        {@/each}

    </ul>

</script>

 

Javascript 代码:

 

var data = {

    list: [

        {name:' guokai', show: true},

        {name:' benben', show: false},

        {name:' dierbaby', show: true}

    ],

    blah: [

        {num: 1},

        {num: 2},

        {num: 3, inner:[

            {'time': '15:00'},

            {'time': '16:00'},

            {'time': '17:00'},

            {'time': '18:00'}

        ]},

        {num: 4}

    ]

};

 

var tpl = document.getElementById('tpl').innerHTML;

var html = juicer(tpl, data);</code>

Copy after login

Backend:
To return json format: You have to put the html you want to return into an array, for example:
$json = array(
'html' => $html
);

echo $json;

Front-end accepts:
$.ajax(
success: function(json){

1

<code>$("#get_category").html(json['html']);</code>

Copy after login

}
);

Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

Video Face Swap

Video Face Swap

Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

PHP's Purpose: Building Dynamic Websites PHP's Purpose: Building Dynamic Websites Apr 15, 2025 am 12:18 AM

PHP is used to build dynamic websites, and its core functions include: 1. Generate dynamic content and generate web pages in real time by connecting with the database; 2. Process user interaction and form submissions, verify inputs and respond to operations; 3. Manage sessions and user authentication to provide a personalized experience; 4. Optimize performance and follow best practices to improve website efficiency and security.

PHP and Python: Code Examples and Comparison PHP and Python: Code Examples and Comparison Apr 15, 2025 am 12:07 AM

PHP and Python have their own advantages and disadvantages, and the choice depends on project needs and personal preferences. 1.PHP is suitable for rapid development and maintenance of large-scale web applications. 2. Python dominates the field of data science and machine learning.

PHP and Python: Different Paradigms Explained PHP and Python: Different Paradigms Explained Apr 18, 2025 am 12:26 AM

PHP is mainly procedural programming, but also supports object-oriented programming (OOP); Python supports a variety of paradigms, including OOP, functional and procedural programming. PHP is suitable for web development, and Python is suitable for a variety of applications such as data analysis and machine learning.

How to start mysql by docker How to start mysql by docker Apr 15, 2025 pm 12:09 PM

The process of starting MySQL in Docker consists of the following steps: Pull the MySQL image to create and start the container, set the root user password, and map the port verification connection Create the database and the user grants all permissions to the database

PHP: Handling Databases and Server-Side Logic PHP: Handling Databases and Server-Side Logic Apr 15, 2025 am 12:15 AM

PHP uses MySQLi and PDO extensions to interact in database operations and server-side logic processing, and processes server-side logic through functions such as session management. 1) Use MySQLi or PDO to connect to the database and execute SQL queries. 2) Handle HTTP requests and user status through session management and other functions. 3) Use transactions to ensure the atomicity of database operations. 4) Prevent SQL injection, use exception handling and closing connections for debugging. 5) Optimize performance through indexing and cache, write highly readable code and perform error handling.

Why Use PHP? Advantages and Benefits Explained Why Use PHP? Advantages and Benefits Explained Apr 16, 2025 am 12:16 AM

The core benefits of PHP include ease of learning, strong web development support, rich libraries and frameworks, high performance and scalability, cross-platform compatibility, and cost-effectiveness. 1) Easy to learn and use, suitable for beginners; 2) Good integration with web servers and supports multiple databases; 3) Have powerful frameworks such as Laravel; 4) High performance can be achieved through optimization; 5) Support multiple operating systems; 6) Open source to reduce development costs.

MySQL's Role: Databases in Web Applications MySQL's Role: Databases in Web Applications Apr 17, 2025 am 12:23 AM

The main role of MySQL in web applications is to store and manage data. 1.MySQL efficiently processes user information, product catalogs, transaction records and other data. 2. Through SQL query, developers can extract information from the database to generate dynamic content. 3.MySQL works based on the client-server model to ensure acceptable query speed.

HTML: The Structure, CSS: The Style, JavaScript: The Behavior HTML: The Structure, CSS: The Style, JavaScript: The Behavior Apr 18, 2025 am 12:09 AM

The roles of HTML, CSS and JavaScript in web development are: 1. HTML defines the web page structure, 2. CSS controls the web page style, and 3. JavaScript adds dynamic behavior. Together, they build the framework, aesthetics and interactivity of modern websites.

See all articles