Discuz!X 插件制作教程(三) ------ 页面嵌入 & 导航
2013-04-03 10:36
686 查看
现在我遇到一个问题:我想更改自己网站的页面内容,比如我希望能在不使用二次开发更改系统模板的情况下来更改部分布局和内容,我应该怎么做? 似乎现在的DX很强大,但是这样的功能它支持么?很高兴地告诉你:你完全可以做到!你甚至可以通过自己的内容来对页面的任意一部分内容进行更改,这就是DX插件最最强大的地方,当然前提是你需要去了解它。
现在我们来实现一个内容,我们以我自己的一个插件:帖子导读的显示部分为例。
首先,我们需要了解DX的一个概念:嵌入点。
在每个标准的DX页面都有一些DX已经设定好的嵌入点,要查看这些嵌入点,我们需要对系统的代码进行一些修改,方法如下:
在config\config_global.php 文件里设置$_config['plugindeveloper'] = 2 如果没这个变量自己加一行。顾名思义,开启插件开发模式,开启后后台会多出现些菜单,前台会显示出嵌入点。
更新一下缓存,然后你就会看到如下图的内容:
有一段js代码需要我们在每个页面都进行调用,我们需要编写一个调用类
到source/plugin/下创建demo目录,在demo目录里创建demo.class.php文件,内容如下
[php] view
plaincopy
<?php
if(!defined('IN_DISCUZ')) {
exit('Access Denied');
}
class plugin_demo {
function __construct(){
}
function global_footer(){
return '<script>alert("插件我来了")</script>';
}
}
然后,随便访问一个前台页面,都会有“插件我来了”弹出。
现在,您基本上已经可以做常用的插件了。不过,如果您需要一个导航栏怎么办?天啊!我需要一个类似于每日签到 这样的一个签到页面,我应该怎么来做呢?
不用着急,接下来我们就来实验一个导航栏,然后进去之后输出一个hello,world的代码。
首先,我们需要在设计模块里面增加一个导航栏
有了它,我们就可以写:.inc.php这个文件了,不过我们似乎还需要一点点模板的支持,那么我们在这个文件夹下,新建一个文件夹:template,然后在它的下面新建一个文件:.htm,内容如下:
[html] view
plaincopy
{template common/header}
<p>Hello,WORLD!!!</p>
{template common/footer}
在demo.inc.php这个文件里,我们写入:
[php] view
plaincopy
<?php
if(!defined('IN_DISCUZ')){
exit('Access Denied');
}
include template('demo:demo');
?>
然后,更新一下缓存,然后刷新一下站点首页,看看有什么效果?
现在我们来实现一个内容,我们以我自己的一个插件:帖子导读的显示部分为例。
首先,我们需要了解DX的一个概念:嵌入点。
在每个标准的DX页面都有一些DX已经设定好的嵌入点,要查看这些嵌入点,我们需要对系统的代码进行一些修改,方法如下:
在config\config_global.php 文件里设置$_config['plugindeveloper'] = 2 如果没这个变量自己加一行。顾名思义,开启插件开发模式,开启后后台会多出现些菜单,前台会显示出嵌入点。
更新一下缓存,然后你就会看到如下图的内容:
有一段js代码需要我们在每个页面都进行调用,我们需要编写一个调用类
到source/plugin/下创建demo目录,在demo目录里创建demo.class.php文件,内容如下
[php] view
plaincopy
<?php
if(!defined('IN_DISCUZ')) {
exit('Access Denied');
}
class plugin_demo {
function __construct(){
}
function global_footer(){
return '<script>alert("插件我来了")</script>';
}
}
然后,随便访问一个前台页面,都会有“插件我来了”弹出。
现在,您基本上已经可以做常用的插件了。不过,如果您需要一个导航栏怎么办?天啊!我需要一个类似于每日签到 这样的一个签到页面,我应该怎么来做呢?
不用着急,接下来我们就来实验一个导航栏,然后进去之后输出一个hello,world的代码。
首先,我们需要在设计模块里面增加一个导航栏
有了它,我们就可以写:.inc.php这个文件了,不过我们似乎还需要一点点模板的支持,那么我们在这个文件夹下,新建一个文件夹:template,然后在它的下面新建一个文件:.htm,内容如下:
[html] view
plaincopy
{template common/header}
<p>Hello,WORLD!!!</p>
{template common/footer}
在demo.inc.php这个文件里,我们写入:
[php] view
plaincopy
<?php
if(!defined('IN_DISCUZ')){
exit('Access Denied');
}
include template('demo:demo');
?>
然后,更新一下缓存,然后刷新一下站点首页,看看有什么效果?
相关文章推荐
- Discuz!X 插件制作教程 ------ 页面嵌入 & 导航
- Discuz!X 插件制作教程(三) ------ 页面嵌入 & 导航
- Discuz!X&nbsp;插件制作教程(三)&amp;n…
- Discuz X 多页面专题制作教程
- 插件__Discuz!X 插件制作教程[以DST官方网站的"扩展"为例]
- Discuz!X 插件制作教程( 网站基本数据)
- [插件制作]&nbsp;Discuz插件…
- Discuz!X 插件制作教程(一) ------ 网站基本数据
- Discuz!X 插件制作教程 --管理中心
- Discuz!X 插件制作教程(二) ------ 管理中心
- [插件制作]&nbsp;Discuz!插…
- Discuz!X 插件制作教程(四) ------ 发布插件
- Discuz!开发之页面插件嵌入点列表
- Discuz!X 插件制作教程( 网站基本数据)
- 使用jQuery制作Web页面遮罩层插件的实例教程
- [手把手教]【整理一些discuz插件开发制作入门级教程】
- Breadcrumb NavXT – WordPress页面导航”面包屑”插件使用方法教程
- Discuz!X 插件制作教程 ------ 发布插件
- Discuz&nbsp;x2.5&nbsp;单页制作的教程
- Discuz!X 插件制作教程( 网站基本数据)