[thinkPHP5项目实战_06]引入前台页面

一个网站的前端分一般分为前台和后台两个部分,下面说明一下如何在tp5中引入前台页面。

tp5中访问的是模块下的控制器,通过控制器获取视图下的页面(模板布局),输出替换引导页面加载静态文件(css,js,image

1.前台资源布置

project  应用部署目录
├─application           应用目录(可设置)
│  ├─common             公共模块目录(可更改)
│  ├─index              模块目录(可更改)
│  │  ├─config.php      模块配置文件
│  │  ├─common.php      模块函数文件
│  │  ├─controller      控制器目录
│  │  ├─model           模型目录
│  │  ├─view            视图目录
│  │  └─ ...            更多类库目录
│  ├─command.php        命令行工具配置文件
│  ├─common.php         应用公共(函数)文件
│  ├─config.php         应用(公共)配置文件
│  ├─database.php       数据库配置文件
│  ├─tags.php           应用行为扩展定义文件
│  └─route.php          路由配置文件
├─extend                扩展类库目录(可定义)
├─public                WEB 部署目录(对外访问目录)
│  ├─static             静态资源存放目录(css,js,image)
│  ├─index.php          应用入口文件
│  ├─router.php         快速测试文件
│  └─.htaccess          用于 apache 的重写
├─runtime               应用的运行时目录(可写,可设置)
├─vendor                第三方类库目录(Composer)
├─thinkphp              框架系统目录
│  ├─lang               语言包目录
│  ├─library            框架核心类库目录
│  │  ├─think           Think 类库包目录
│  │  └─traits          系统 Traits 目录
│  ├─tpl                系统模板目录
│  ├─.htaccess          用于 apache 的重写
│  ├─.travis.yml        CI 定义文件
│  ├─base.php           基础定义文件
│  ├─composer.json      composer 定义文件
│  ├─console.php        控制台入口文件
│  ├─convention.php     惯例配置文件
│  ├─helper.php         助手函数文件(可选)
│  ├─LICENSE.txt        授权说明文件
│  ├─phpunit.xml        单元测试配置文件
│  ├─README.md          README 文件
│  └─start.php          框架引导文件
├─build.php             自动生成定义文件(参考)
├─composer.json         composer 定义文件
├─LICENSE.txt           授权说明文件
├─README.md             README 文件
├─think                 命令行入口文件

1.1模板视图的首页存放位置

根据tp5的目录介绍,前端文件的视图位于application的模块下面的view文件夹下。

application文件夹下默认已经有了一个index模块,可以拿来直接使用。

渲染模板最常用的是使用\think\View类的fetch方法:

fetch('[模板文件]'[,'模板变量(数组)'])

当fetch中不带任何参数的时候,默认访问规则为:

当前模块/默认视图目录/当前控制器(小写)/当前操作(小写).html
假如当前控制器为Index下面的index类的话,fetch获取的就是view中的Index下面的index.html文件其中html后缀会自动加上;

因此,在该index文件夹下新建一个view文件夹,然后新建一个Index控制器文件夹,将前台的首页index.html拷贝过来:


1.2前台静态资源存放位置

根据tp5的目录介绍,前端的静态资源(css,js,image)存放于puclic/static文件夹下,

因此,在static文件夹中新建一个index文件夹,将index.html引入的文件拷贝过去。


2.模板渲染和输出替换

前台文件布置完成后,http://localhost/tp5/public/index.php/index/index访问的还是tp5的默认页面,因此需要将该页面替换成index.html页面。

打开视图所在的模块index下的controller下的index.php文件,该文件即为http://localhost/tp5/public/index.php/index/index访问的位置,

模板渲染使用到了fetch()方法,需要在index.php中引入并在Index类进行继承:

<?php
namespace app\index\controller;
use think\Controller;
class Index extends Controller
{
    public function index()
    {
        return $this->fetch();
    }
}
保存后打开浏览器输入http://localhost/tp5/public/index.php/index/index

得到了index.html的页面,其中页面加载的静态文件均未找到位置,因此需要重新定位

打开application下的config.php文件,在分页配置下面添加:

//输出替换
    'view_replace_str' => [
        '__PUBLIC__'=>'/tp5/public', //将__PUBLIC__指向tp5下面的public
        '__ROOT__' => '/',
    ]
将__PUBLIC__指向根目录下的public文件夹,再打开index.html文件,将在引入的文件前面添加前缀__PUBLIC__/static/index,

例如原来index.html和css文件夹同一个目录下,在index.html引入css方式为:

<link rel="stylesheet" type="text/css" href="css/demo.css">
则现在的引入方式该为:

<link rel="stylesheet" type="text/css" href="__PUBLIC__/static/index/css/demo.css">
保存后再次打开浏览器访问tp5默认目录,完整的前台视图:

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值