帝国模板之家为广大用户提供专业、一站式建站服务。

帝国cms插件

帝国cms插件栏目,我们会推荐一些常用的插件,比如帝国cms采集插件、微信支付、分享,会员中心插件等等。

当前位置:首页 > 插件 > 帝国cms插件 > 正文

帝国cms可单选和多选的结合项插件

帝国模板之家 2020-09-02 帝国cms插件 评论

帝国cms官方推出的结合项插件,只能用作单项筛选。今天帝国模板之家小编给大家分享一款可单选和多选的帝国cms结合项插件。插件效果图如下:

插件使用方法:

1. 将userfun.php中的函数 retUrl 放到/e/class/userfun.php中,函数代码如下:

//---------------------------用户自定义标签函数文件
function retUrl($field, $fval, $mult = 1) {
    $urlPares = $GLOBALS['urlPares'];
    // 如果结合项字段在GET中,写入参数
    foreach ($GLOBALS['fieldData'] as $key => $value) if (isset($_GET[$value])) $urlPares[$value] = $_GET[$value];
    $res = '';
    // 结合项单选
    if (!$mult || !isset($_GET[$field])) {
        $copy = $urlPares;
        foreach ($fval as $key => $value) {
            $css = '';
            // 如果url中有此参数 则删除
            if (isset($_GET[$field]) && $_GET[$field] == $value) {
                unset($copy[$field]);
                $css = 'active';
            } else {
                $copy[$field] = $value;
            }
            $tpl = '/e/action/ListInfo.php?'.http_build_query($copy);
            $tpl = urldecode($tpl);
            $res .= sprintf('<a class="%s" href="%s">%s</a>', $css, $tpl, $value);
        }
        return $res;
    }
    // 结合项多选
    
    // 如果url中不是数组形式
    if (!is_array($_GET[$field])) {
        foreach ($fval as $key => $value) {
            $css = '';
            // 如果当前值在url中
            if ($value == $_GET[$field]) {
                $css = 'active';
                $copy = $urlPares;
                unset($copy[$field]);
            } else {
                $copy = $urlPares;
                $copy[$field] = array();
                $copy[$field][] = $_GET[$field];
                $copy[$field][] = $value;
            }
            $tpl = '/e/action/ListInfo.php?'.http_build_query($copy);
            $tpl = urldecode($tpl);
            $res .= sprintf('<a class="%s" href="%s">%s</a>', $css, $tpl, $value);
        }
        return $res;
    }

    // 数组形式的
    foreach ($fval as $key => $value) {
        $css = '';
        $copy = $urlPares;
        // 如果url中存在则删除
        if (in_array($value, $copy[$field])) {
            unset($copy[$field][array_search($value, $copy[$field])]);
            $css = 'active';
        } else {
            $copy[$field][] = $value;
        }
        sort($copy[$field]);
        $tpl = '/e/action/ListInfo.php?'.http_build_query($copy);
        $tpl = urldecode($tpl);
        $res .= sprintf('<a class="%s" href="%s">%s</a>', $css, $tpl, $value);
    }
    return $res;
}

2. 新建列表模板,将 结合项列表模板.txt 中的内容放进去,模板代码如下:

<?php
/*  结合项组合参数  */
$GLOBALS['urlPares'] = array(
    'classid' => 1,    // 栏目ID
    'tempid' => 9,    // 结合项列表模板ID
    'ph' => 1,    // 结合项字段,固定值不需要修改,
    'line' => 3,    // 每页显示条数
);
/*
    @fieldData    array
        参与筛选的字段,有多少字段参与筛选就填写多个
*/
$GLOBALS['fieldData'] = array('myarea', 'sex', 'day');
/*
    retUrl(string, array, int @1)
    string    字段名称
    array     字段值
    int       单选或多选,0单选 1多选,默认1
*/
$a = retUrl('myarea', array('东城区', '西城区', '崇文区'), 1);
$b = retUrl('sex', array('男', '女', '人妖'), 1);
$c = retUrl('day', array(1,2,3,4,5,6,7), 1);
?>
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1, user-scalable=no">
    <title>Document</title>
    <link rel="stylesheet" href="https://cdn.bootcss.com/bootstrap/3.3.7/css/bootstrap.min.css">
    <style>
    .sx + .sx{
        margin-top: 1.5em;
    }
    .sx a {
        margin-left: 10px;
        border: 1px solid blue;
    }
    .active {
        background-color: #dedede;
    }
    </style>
</head>
<body>

<div class="contianer">
    <div class="h4">
        <div class="sx">地区: <?=$a?></div>
        <div class="sx">性别: <?=$b?></div>
        <div class="sx">星期: <?=$c?></div>
    </div>
</div>

<div class="contianer">
    <ul>
[!--empirenews.listtemp--]
<!--list.var1-->
[!--empirenews.listtemp--]
</ul>
<div>
    [!--show.listpage--]
</div>
</div>
<script src="https://cdn.bootcss.com/jquery/1.12.4/jquery.min.js"></script>
<script src="https://cdn.bootcss.com/bootstrap/3.3.7/js/bootstrap.min.js"></script>
</body>
</html>

3. 修改 $GLOBALS['urlPares'] 数组中的参数,改为你需要的。

至此,帝国cms可单选和多选的结合项插件整合完成,大家赶紧去测试一下吧。更多好用帝国cms插件请关注帝国模板之家

这世上无忧无虑的人,反而相对寿命会长点。

已有 位小伙伴发表了看法

欢迎 发表评论

  • 匿名发表

关于

帝国cms模板

网页插件

帝国模板之家 | www.moyouyouw.cn

本站所有模板/文章除标明原创外,均来自网络转载,版权归原作者所有,如果有侵犯到您的权益,请联系站长删除,谢谢! 寻找帝国cms模板首选帝国模板之家,用心做站,上线至今广受好评,值得信赖!

  • 交流群1:帝国cms交流群1
  • 交流群2:帝国cms交流群2
在线QQ 给我留言