文档章节

Onethink1.1 钩子和插件的使用!

史帝文
 史帝文
发布于 2016/11/19 21:31
字数 585
阅读 42
收藏 0

高手(略),只是针对和我一样需要了解的菜鸟。

主要讲一讲onethink插件的使用,因为这对我们的快速开发有帮助,所以记录一下,同时也希望能够帮助一下正在想要了解的朋友。

 

我们从钩子讲起,先看下面的后台界面:

Onethink1.1 钩子和插件的使用! PHP 第1张

 

step1.   选择“新增”

Onethink1.1 钩子和插件的使用! PHP 第2张

 

step2.   根据需求填写(钩子名唯一),然后点击“确定”,提示创建成功。

如图:

Onethink1.1 钩子和插件的使用! PHP 第3张

 

钩子创建完毕。

 

Next:

Onethink1.1 钩子和插件的使用! PHP 第4张

step4.   有钩子就要调用,找到需要调用的模板,添加如下语句:      {:hook('BannerImageSlide')}

注意:是hook,不是hooks;

 

Next:

Onethink1.1 钩子和插件的使用! PHP 第5张

step5.  点击“插件管理”的“快速创建”

 

Next:

 Onethink1.1 钩子和插件的使用! PHP 第6张

Onethink1.1 钩子和插件的使用! PHP 第7张

step6.   根据需要选择或填写,点击"确定"。

 

Next:

Onethink1.1 钩子和插件的使用! PHP 第8张

step7.  点击安装。

 

返回文件,查看生成的目录和文件:

Onethink1.1 钩子和插件的使用! PHP 第9张

在./Addons/下生成了ImageSlide目录和config.php,ImageSlideAddon.class.php两个文件

 

如何看我们的插件在你自己的钩子下有效果呢?

Onethink1.1 钩子和插件的使用! PHP 第10张

在类中找到你的钩子的方法,并且打印一下试试。

Onethink1.1 钩子和插件的使用! PHP 第11张

如果调用的地方打印了刚才插件中echo的信息,说明就可以调用了。如果没有调用,就要重新仔细检查一下,看是不是没有调用对位置。

 

插件怎么写呢?

 

Next,编写插件模板:

Onethink1.1 钩子和插件的使用! PHP 第12张

step9.  问号中的内容是分配给这个模板的变量,可以先用占位符表示。

值得一提的是,编写插件模板就和我们写html页面没区别。同样可以在页面中引入插件需要的css,js,images等资源。

 

在插件类分配变量:

Onethink1.1 钩子和插件的使用! PHP 第13张

这里的配置不是很方便说明,后面再解释。

配置好以后,就可以使用插件的“设置”操作

没有配置前:

Onethink1.1 钩子和插件的使用! PHP 第14张

添加了插件配置信息过后:

Onethink1.1 钩子和插件的使用! PHP 第15张

step10.  如果没有出现“设置”操作,请先“卸载”,再安装。点击“设置”;

 

Next:

Onethink1.1 钩子和插件的使用! PHP 第16张

 

step11.   填入要显示的值

 

Onethink1.1 钩子和插件的使用! PHP 第17张

step13.  点击“确定”。

 

Next:

Onethink1.1 钩子和插件的使用! PHP 第18张

step15.  找到插件类文件,并且获取配置信息,并分配变量到模板文件content.html

 

Onethink1.1 钩子和插件的使用! PHP 第19张

效果如上,下一步很自然,在插件模板中获取变量值。

 

Next:

Onethink1.1 钩子和插件的使用! PHP 第20张

 

最后效果如图:

Onethink1.1 钩子和插件的使用! PHP 第21张

注意如果红框中的值,没有得到,很有可能你没有在插件“设置”中设置值。

本文转载自:

共有 人打赏支持
史帝文
粉丝 6
博文 56
码字总数 22088
作品 0
武汉
后端工程师
私信 提问
WordPress 插件开发教程 Part 3 – 钩子( Hooks )

钩子是 WordPress 的精髓。他们允许插件开发人员钩进 WordPress 工作流程内部来改变它的工作,而不用直接修改核心代码。这就使得用户可以方便的升级到 WordPress 的新版本而不需要修改一行代...

Amamatthew
2014/07/07
0
0
【webpack进阶】可视化展示webpack内部插件与钩子关系📈

往期文章: 【webpack进阶】前端运行时的模块化设计与实现 【webpack进阶】使用babel避免webpack编译运行时模块依赖 引言 webpack的成功之处,不仅在于强大的打包构建能力,也在于它灵活的插...

AlienZHOU
10/01
0
0
干货!撸一个webpack插件(内含tapable详解+webpack流程)

目录 Tabable是什么? Tabable 用法 进阶一下 Tabable的其他方法 webpack流程 总结 实战!写一个插件 Webpack可以将其理解是一种基于事件流的编程范例,一个插件合集。 而将这些插件控制在w...

圆儿圈圈
昨天
0
0
wemall 7.0 开源系统发布,支持公众号和小程序开发

wemall7.0 开源系统,基于thinkphp5开发,支持composer,优化核心,减少依赖,基于全新的架构思想和命名空间。 wemall7.0特性: 基于TP5,性能优越 前后分离,简单方便 插件扩展,功能丰富 ...

einsqing
2017/05/03
953
7
einsqing/wemall

WeMall商城 7.0 (不含商城) wemall7.0 开源系统,基于thinkphp5开发,支持composer,优化核心,减少依赖,基于全新的架构思想和命名空间。 thinkphp5.0特性 基于命名空间和众多PHP新特性 核心...

einsqing
2014/05/24
0
0

没有更多内容

加载失败,请刷新页面

加载更多

用any-loader封装jQuery的XHR —— 随便写着玩系列

哎,都说没人用JQuery啦,叫你别写这个。 其实我也是好高骛远使用过npm上某个和某个很出名的XHR库,嗯,认识我的人都知道我喜欢喷JQ,以前天天喷,见面第一句,你还用JQ,赶紧丢了吧。但我也...

曾建凯
今天
1
0
聊聊storm的AggregateProcessor的execute及finishBatch方法

序 本文主要研究一下storm的AggregateProcessor的execute及finishBatch方法 实例 TridentTopology topology = new TridentTopology(); topology.newStream("spout1", spout......

go4it
今天
3
0
大数据教程(7.5)hadoop中内置rpc框架的使用教程

博主上一篇博客分享了hadoop客户端java API的使用,本章节带领小伙伴们一起来体验下hadoop的内置rpc框架。首先,由于hadoop的内置rpc框架的设计目的是为了内部的组件提供rpc访问的功能,并不...

em_aaron
今天
5
0
CentOS7+git+github创建Python开发环境

1.准备CentOS7 (1)下载VMware Workstation https://pan.baidu.com/s/1miFU8mk (2)下载CentOS7镜像 https://mirrors.aliyun.com/centos/ (3)安装CentOS7系统 http://blog.51cto.com/fengyuns......

枫叶云
昨天
3
0
利用ibeetl 实现selectpicker 的三级联动

1. js 直接写在html页面上面,ibeetl 就可以动态地利用后台传上来的model List ,不需要每次点击都要ajax请求后台 2. 使用selectpicker 的时候,除了对selecct option的动态处理后,还需要 $("#...

donald121
昨天
3
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部