onethink入门笔记(一)

由于公司需求所以大概花了一个星期搞了一个一个基于onethink的数据管理平台demo不得不说onethink这个基于thinkphp3.2.3的框架还是很棒的 让我这个没基础过php的人也能在一星期能搞出东西来整理一下所遇到的坑 希望能给看到这篇文章的你有所帮助

首先安装onethink   

1.连接数据库

 由于onethink是基于mysql的如果你需要用mongo的话需要做数据表迁移由于后台权限逻辑本来就不适合mongo来搞 所以这里建议用mysql如果需求需要mongo数据库那么最好用mysql和mongo数据库结合的方式那么坑就来了

由于thinkphp的原因它本身对mongo的扩展没那么好 亲测 如果mongo为主mysql为辅 使用官方介绍的方法切换数据库完全没问题 反过来那就蛋疼了thinkphp官方接锅需要改底层代码 我这里说具体的解决方案尽量不改源代码 首先参考手册介绍的在common 文件夹下的config里的mysql的链接配置后将mongo数据库的信息写入如下图:(注意这里mongo的表前缀写与不写无所谓由于thinkphp问题(bug)导致它只会用全局的即上面mysql的前缀     解决方法见这里

接下来在Model在新建例如BooksModel.class.php内容如下(thinkphp底层会将表名强行转成小写所以这里使用$trueTableName绕过转化否则会找不到表 也可以采用这里的方法改底层文件):

 然后你就可以愉快的在BooksController操作使用D("Books")进行数据库的这里的 M方法不能用会报找不到表错误的信息仔细一看还是表前缀出的问题(官方背锅M方法里面的也是用的全局前缀你可以通过修改解决)

2.onethink的分页

你可以参考onthink 的ConfigController里的内容 它实现分页是通过红线标出的这一句继承自AdminController 里的lists你可以查看它使用方法这里有更为详细的介绍可以自己去实例化lists

 

3.onethink给的增删改例子都是在mysql下的这里提供在mongo下的增删改供参考

增:

(1)如果你也是将edit和add用一个页面采用在表单里隐藏_id的方法 注意这里有坑先看一下下面的edit的实现由于create方法创建时会把表单里的隐藏的空的_id(如果你name里不用_id那就会在新增时新创建这个为空的垃圾字段拉过来导致数据新增失败这里采用在Model里写:

 或者使用field方法详细介绍见这里

后台新增方法:

注意这里如果你想获得插入的id可以通过下面的方法 我是用$id = $book->add()返回是空

删:

onethink给的menu和config都有点问题这里给出我的

界面显示效果:

批量删除按钮:

需要批量删除的对象name命名和进行单一删除对象命名一个是id[]另一个是id

后台删除方法:

改:

前台:这里貌似一定要使用_id

后台方法:

 

 4.样式修改

onethink 里a 标签实现鼠标放上去显示下划线使用的是border-bottom的方式 使用border:none 进行覆盖 text-decoration:none 是无效的   这个坑 坑了我好久wtf

原文地址:https://www.cnblogs.com/fengbingzi/p/5813340.html