完整代码:
~~~
<?php
namespace plugins\d_comment;
use cmf\lib\Plugin;
use plugins\d_comment\model\CommentModel;
class DCommentPlugin extends Plugin
{
public $info=[
'name'=>'DComment',
'title'=>'D之食卓评论插件',
'description'=>'基于官网评论插件',
'status'=>1,
'version'=>'1.0.0',
];
public $hasAdmin = 1;
public function install()
{
// TODO: Implement install() method.
return true;
}
public function uninstall()
{
// TODO: Implement uninstall() method.
return false;
}
public function dcomment($param)
{
$commentModel = new CommentModel();
$comment = $commentModel->where([
"table_name" => $param['table_name'],
"object_id" => $param['object_id'],
"status" => 1,
])
->order('create_time DESC')
->paginate(10,false,['var_page'=>'comment_page']);
$config = $this->getConfig();
$this->assign($config);
$this->assign('param', $param);
$this->assign('user', cmf_get_current_user());
$this->assign('page', $comment->render());
return $this->fetch('widget');
}
}
~~~
全是插件标准写法,现解析dcomment内容
table_name 评论内容挂载在哪个表下,如:portal_post
object_id 评论内容的id
仅仅用object_id不能定位唯一值,加上table_name就可以定位唯一了。这大大扩展了表的灵活性,使我们不仅仅局限于post一张表上
status 1为已审核
这里虽然写了config属性,但是其实我们并没有config文件。
也就是说 我们不需要后台传值
- php套路
- 套路之类结构
- thinkphp分块解析之Collection
- thinkphp基础之collection
- Collection在thinkphp中的运用
- thinkcmf模块分析
- Controller按界面点击顺序排列表
- user模块-Controller分析
- portal模块-Controller分析
- admin模块-Controller分析
- user模块-脑图
- portal模块-脑图
- admin模块-脑图
- cmf公共函数解析-common.php
- thinkcmf点滴记录
- 自定义标签详解
- 插件
- 系统信息插件
- 插件演示插件
- 留言板插件
- 留言板1 建立胚胎
- 留言板1-1 数据库变化
- 留言板1-2 自定义钩子
- 留言板2 连接数据库
- 留言板3 读取后台界面数据
- 留言板4 前端模板
- 留言板5 分离cssjs文件
- 留言板6 验证
- 留言板7 图形验证码
- 留言板8 后台留言列表页
- 留言板9 后记
- 评论插件
- 1 分析数据表
- 2 CommentModel.php
- 3 UserModel.php
- 4 DCommentPlugin.php
- 前端调用代码
- 喜欢插件
- 1 分析
- 2 收藏功能
- 3 插件建模
- 4 数据库设计
- 5 插入一条数据
- 多语言
- thinkphp多语言
- thinkcmf多语言