| 在论坛上好几天,都没有解决这个问题。。 最后是在这个帖子找到的灵感。。。
 
 PS:此教程只适合编程人员观看,不会PHP的请跳过。谢谢
 
 http://ggmmchou.blog.163.com/blog/static/59333149201142075017844/
 
 具体如下:
 打开文件夹source\class\block\然后在此目录新建一个文件夹 名称自己写。必须英文的.例如 mdir
 然后在source\class\block\mdir里建立一个文件
 文件名:blockclass.php 这个不能变,必须是这个名
 编辑blockclass.php
 写入以下内容:
 当当当。重点来了。。复制代码<?php
        $blockclass = array(
                'name' => '我的小小模块', //为此目录定义一个名字
        );
?>
新建一个.php文件  文件名必须以block_开头 例如block_mdir.php
 然后写入以下内容:
 请自行编辑以上内容。以上是你最终要处理的事情了。复制代码<?php
if(!defined('IN_DISCUZ')) {
        exit('Access Denied');
}
class block_prices {
        function block_prices(){
                
                }
        /**
         * 必须!
         * 返回本数据调用类的显示名称(显示在创建模块时选择“模块数据”的下拉列表里)
         * @return 
         */
        function name() {
                return '示例数据类';
        }
        /**
         * 必须!
         * 返回一个数组: 第一个值为本数据类所在的模块分类;第二个值为模块分类显示的名称(显示在 DIY 模块面板)
         * @return 
         */
        function blockclass() {
                return array('sample', '示例分类');
        }
        /**
         * 必须!
         * 返回数据类中可供“模块样式”使用的字段。
         * 格式见示例:
         * name 为该字段的显示名称
         * formtype 决定编辑单条数据时该字段的显示方式: 类型有: text, textarea, date, title, summary, pic; 详见 portalcp_block.htm 模板(搜 $field[formtype] )
         * datatype 决定该字段的数据展示,类型有: string, int, date, title, summary, pic; 详见 function_block.php 中 block_template 函数
         * @return 
         */
        function fields() {
                return array(
                        'field1' => array('name' => '示例字段1', 'formtype' => 'text', 'datatype' => 'string'),
                        'field2' => array('name' => '示例字段2', 'formtype' => 'title', 'datatype' => 'title'),
                );
        }
        /**
         * 必须!
         * 返回使用本数据类调用数据时的设置项
         * 格式见示例:
         * title 为显示的名称
         * type 为表单类型, 有: text, password, number, textarea, radio, select, mselect, mradio, mcheckbox, calendar; 详见 function_block.php 中 block_makeform() 函数
         * @return 
         */
        function getsetting() {
                return array(
                        'param1' => array(
                                'title' => '数据调用参数1',
                                'type' => 'text',
                                'default' => ''
                        ),
                        'param2' => array(
                                'title' => '数据调用参数2',
                                'type' => 'mcheckbox',
                                'value' => array(
                                        array('1', '选项1'),
                                        array('2', '选项2'),
                                ),
                                'default' => '1'
                        ),
                );
        }
        /**
         * 必须!
         * 处理设置参数,返回数据
         * 返回数据有两种:
         * 一种是返回 html,放到模块 summary 字段,直接显示; 返回格式为: array('html'=>'返回内容', 'data'=>null)
         * 一种是返回 data,通过模块样式渲染后展示,返回的数据应该包含 fields() 函数中指定的所有字段; 返回格式为: array('html'=>'', 'data'=>array(array('title'=>'value1'), array('title'=>'value2')))
         * 特别的:
         * parameter 参数包含 getsetting() 提交后的内容; 并附加了字段:
         * items ,为用户指定显示的模块数据条数;
         * bannedids ,为用户选择屏蔽某数据时记录在模块中的该数据 id。 应该在获取数据时屏蔽该数据;
         *
         * 如果返回的数据给 data, 那么应该包含 fields() 函数指定的所有字段。并附加以下字段:
         * id 标志该数据的 id,如果用户屏蔽某数据时,会将该数据的 id 添加到 parameter[bannedids] 里
         * idtype 标志该数据的 idtype
         *
         * @param  $style 模块样式(见 common_block_style 表)。 可以根据模块样式中用到的字段来选择性的获取/不获取某些数据
         * @param  $parameter 用户对 getsetting() 给出的表单提交后的内容。
         * @return 
         */
        function getdata($style, $parameter) {
                // 返回summary
                return array('html' => '这是一个演示模块数据类', 'data' => null);
                // 返回数据
                // 需要注意: 除 id,idtype, title, url, pic, picflag, summary 几个字段外,其它字段需要放到 fields 数组里。 可以参考系统内置模块类 source/class/block/block_thread.php
                return array('html'=>'', 'data' => array(
                        array(
                                'id' => '1',
                                'idtype' => 'sampleid',
                                'title' => 'title1',
                                'url' => '#',
                                'pic' => 'nophoto.gif',
                                'picflag' => '1',
                                'summary' => '',
                                'fields' => array(
                                        'field1' => 'value1'
                                )
                        )
                ));
        }
}
?>
然后在:后台——工具——更新缓存  只选择DIY模块分类缓存   然后 点更新  ..去前台看看。有无你亲爱的小模块。。
 
 什么??看不懂?? sorry! 那不是本帖的内容,请去baidusearch 找PHP教程了。 end.
 
 
 
 
 |