推荐一个基于ThinkPHP生成静态站点控制器类

# JKBuildHtml 基于ThinkPHP生成静态站点控制器类

项目地址:https://gitee.com/ray2017/jk-build-html

## 介绍

完美嫁接[http://www.thinkphp.cn/](THINKPHP)的静态页面生成控制器,可自定义生成规则,支持动态参数,支持参数的范围设置。 是一个在原来开发过程没有变化的情况下搭建静态站的解决方案。 性能方面测试有时间搞一下。 暂时不是composer版本,如果需要的,可以留言。 使用中有其他问题的欢迎留言。

build static site, thinkphp class, build html page

## 特点

* 纯静态:生成的网站是静态htm页面,拷贝文件就是部署站点。

* 方便改造:原来TP开发代码不用变动,原来TP的view文件照常写,以前怎么写模板还怎么写。

* 边开发边生成html:建议封装控制器的fetch方法,边查看静态效果边开发,避免后期重新搭建后页面显示有问题,你可以盯着`public/dist`目录下的静态页面按F5刷新静态页面效果,也可以用原来的tp路径或路由查看模板效果。

## 用法

在任意控制器里放置一下语句即可批量生成全部静态页,你需要做的是把它放到后台的某个地方了。

页面显示是flush逐行显示的,如果想用ajax自行搞一下代码当然也行。

```

controller('common/JKBuildHtml')->buildAll();

```

也可以单个页面生成,一般在列表页的每行数据后面加一个 `生一个页面` 按钮:

```

controller('common/JKBuildHtml')->buildOne($path, ['id' => 5]);

```

需要注意的是单个页面生成的path 一般为控制器和方法名,必须在静态生成规则中声明,否则会提示错误。

也可以封装tp controller 的 fetch方法,这样可以边开发边生成。

```

protected function fetchHtml()

{

    controller('common/JKBuildHtml')->buildFromFetch( $html = $this->fetch(), input('get.') );

    return $html;

}

```

## 注意事项

* 所有静态资源js,css,上传文件等,必须放置在 `dist_dir_name` 配置文件夹下,静态页面会访问这些资源,如果放到这个文件夹外面,除非站点目录不是这个目录,否则访问不到。

* 所有静态规则<键>全用小写

* 静态规则中的<值>的路径原则是,只要能请求到的地址就可以,建议不要使用的TP路由动态参数。

* 请求路径只支持GET请求

## 配置步骤

* `JKBuildHtml.php` 放置在common的controller里 别处也可 注意命名空间

* `config.php` 增加公共配置参数

* `dist_rules.php` 静态生成规则文件,放置在application目录下

## config.php 参数设置

公共配置文件`config.php`中加入以下参数,注意看注释:

```

    // 静态站放置路径:

    'dist_path' => ROOT_PATH. 'public/',

    // 静态页存放文件夹名 一般放置在public下;静态站点直接指向这个目录即可:

    'dist_dir_name' => 'dist',

    // 生成的静态页子页的存放目录,即匹配规则中没有@符号的页面的存放目录,注意例中路径中的'dist/site-pages'会进行目录匹配作为替换./或../的依据,所以这个名称在项目文件夹名中最好唯一:

    'dist_sub_dir' => 'site-pages',

    // 要生成静态页的模块名:

    'dist_module_name' => 'index',

    // 静态页文件名字中的参数分隔符:

    'dist_file_dot' => '_',

    // 静态资源路径替换 静态站点根目录下会替换成 `./` 其他会替换成 `../`

    'dist_src_match' => '/public/static/',

```

## 关于静态资源路径

本来tp的资源是放在public下任何位置的,但是有了静态生成类,那么就得按规则来

以下是建议:

* 首先在public下建一个dist目录(dist的由来是写js项目的时候build的目录名,此处借用;也可改配置)

* 然后把所有前端扔给你的所有静态资源文件 js,css,images放到这个文件夹下。

* 把上传的文件也放dist目录里

* 生成完毕后这个目录下就会生成相关的html页面

## 生成静态页规则文件dist_rules.php说明

* 注:这个文件不是路由文件,和tp路由不是一回事。


键值对说明:

* <键> 为生成静态页文件名:@代表dist的根目录,@index 代表首页,其他不带@的会生成在dist/site-pages;全用小写

* <值> 为静态页生成模块的路径(即控制器、方法、参数),生成过程中,会直接请求这个路径。

原TP模板文件a链接路径:

* 在模板里写a链接路径的时候需要按照键的规则,路径里不需要@符号

```

<?php

// +----------------------------------------------------------------------

// | 生成静态页的规则文件

// +----------------------------------------------------------------------

return [

    '@index'        => 'index/index', // 这个是首页 会生成在dist目录下

    '@news'        => 'news/index',

    'news_:id'      => ['news/find', 'article'],  // 这个是带db的,表示要查询article表的id列,循环生成静态页

    'job_:id'      => ['jobs/find', 'func:getjobids'],  // 这个是带自定义方法的,表示要执行getjobis方法返回id为键的二维数组,循环生成静态页

    'job_:id_:code' => ['index/index', 'func:dist/index/test'], // 这个是请求tp的模块/控制器/方法,返回一个二维数组

];

```

### <键>

* 键中带:号的是有动态参数的 会生成在`dist/site-pages`目录下

* 参数命名必须和db里的字段名称一致

* 为防止生成错误不同参数之间需用_分开(可以修改配置)

### <值>

* 值可以是一个“请求路径”,用`控制器/方法`的形式即可,请求时会自动加上自定义模块名

* 值也可以是一个数组,第一个是请求路径,会传参请求;第二个是db的名字,即参数字段所在列的所有值,系统会根据参数批量生成页面:比如'news_:id' => ['news/find', 'article'], 是查询article表里的id列,

* 如果想加入db查询条件,那么就放第三个值里 比如 `id < 100`,这个会传入到db的where条件中需要符合tp查询语法, 就成了`'news_:id' => ['news/find', 'article', ['id' =>  ['<',100]]],` 或  `..."id < 100"]`

* 如果想自定义生成id的函数,可以把第二个参数设置成一个全局的方法,可以放common.php里(函数名不用带`func:`),或任意一个控制器里 写法:`'func:admin/index/getJobIds'` 或 `'func:getjobids'`

* 若采用func类型的,返回值必须是以参数为键相符的二维数组。如:`['id' => [2,3,4,5]]`

* func类型可以有第三个值,作为func的参数传入

### 请求路径出现异常怎么办

静态生成控制器会直接把异常页面也生成到html文件中,不会停止生成

## 作者

冷风崔 <541720500@qq.com>

## LICENSE

完全遵循 996ICU 协议 完美开源

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 202,723评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,080评论 2 379
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 149,604评论 0 335
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,440评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,431评论 5 364
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,499评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,893评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,541评论 0 256
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,751评论 1 296
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,547评论 2 319
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,619评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,320评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,890评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,896评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,137评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,796评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,335评论 2 342

推荐阅读更多精彩内容