PHPCMS V9发现者说网站开发 分类信息筛选
2017-03-10 17:40
543 查看
http://www.dsays.tv/
开发部分:
前端:PC开发html+css
后端:PC开发基于phpcms
功能点:新闻ajax异步加载、分类信息筛选等
开发部分:
前端:PC开发html+css
后端:PC开发基于phpcms
功能点:新闻ajax异步加载、分类信息筛选等
添加自定义函数: 将以下代码添加到 phpcms/libs/functions/extention.func.php 文件 <?php /** * extention.func.php 用户自定义函数库 * * @copyright (C) 2005-2010 PHPCMS * @license http://www.phpcms.cn/license/ * @lastmodify 2010-10-27 */ /********************实现筛选功能************************/ /** * 通过指定keyid形式显示所有联动菜单 * @param $keyid 菜单主id * @param $linkageid 联动菜单id,0调用顶级 * @param $modelid 模型id * @param $fieldname 字段名称 */ function show_linkage($keyid, $linkageid = 0, $modelid = '', $fieldname='zone') { $datas = $infos = $array = array(); $keyid = intval($keyid); $linkageid = intval($linkageid); //当前菜单id $field_value = intval($_GET[$fieldname]); $urlrule = structure_filters_url($fieldname,$array,1,$modelid); if($keyid == 0) return false; $datas = getcache($keyid,'linkage'); $infos = $datas['data']; foreach($infos as $k=>$v){ if($v['parentid']==$field_value){ $array[$k]['name'] = $v['name']; $array[$k]['value'] = $k; $array[$k]['url'] = str_replace('{$'.$fieldname.'}',$k,$urlrule); $array[$k]['menu'] = $field_value == $k ? '<em>'.$v['name'].'</em>' : '<a href='.$array[$k]['url'].'>'.$v['name'].'</a>' ; } } return $array; } function structure_filters_url($fieldname,$array=array(),$type = 1,$modelid) { if(empty($array)) { $array = $_GET; } else { $array = array_merge($_GET,$array); } //TODO $fields = getcache('model_field_'.$modelid,'model'); if(is_array($fields) && !empty($fields)) { ksort($fields); foreach ($fields as $_v=>$_k) { if($_k['filtertype'] || $_k['rangetype']) { if(strpos(URLRULE,'.html') === FALSE) $urlpars .= '&'.$_v.'={$'.$_v.'}'; else $urlpars .= '-{$'.$_v.'}'; } } } //后期增加伪静态等其他url规则管理,apache伪静态支持9个参数 if(strpos(URLRULE,'.html') === FALSE) $urlrule =APP_PATH.'index.php?m=content&c=index&a=lists&catid={$catid}'.$urlpars.'&page={$page}' ; else $urlrule =APP_PATH.'list-{$catid}'.$urlpars.'-{$page}.html'; //根据get传值构造URL if (is_array($array)) foreach ($array as $_k=>$_v) { if($_k=='page') $_v=1; if($type == 1) if($_k==$fieldname) continue; $_findme[] = '/{\$'.$_k.'}/'; $_replaceme[] = $_v; } //type 模式的时候,构造排除该字段名称的正则 if($type==1) $filter = '(?!'.$fieldname.'.)'; $_findme[] = '/{\$'.$filter.'([a-z0-9_]+)}/'; $_replaceme[] = ''; $urlrule = preg_replace($_findme, $_replaceme, $urlrule); return $urlrule; } /** * 生成分类信息中的筛选菜单 * @param $field 字段名称 * @param $modelid 模型ID */ function filters($field,$modelid,$diyarr = array()) { $fields = getcache('model_field_'.$modelid,'model'); $options = empty($diyarr) ? explode("\n",$fields[$field]['options']) : $diyarr; $field_value = intval($_GET[$field]); foreach($options as $_k) { $v = explode("|",$_k); $k = trim($v[1]); $option[$k]['name'] = $v[0]; $option[$k]['value'] = $k; $option[$k]['url'] = structure_filters_url($field,array($field=>$k),2,$modelid); $option[$k]['menu'] = $field_value == $k ? '<em>'.$v[0].'</em>' : '<a href='.$option[$k]['url'].'>'.$v[0].'</a>' ; } $all['name'] = '全部'; $all['url'] = structure_filters_url($field,array($field=>''),2,$modelid); $all['menu'] = $field_value == '' ? '<em>'.$all['name'].'</em>' : '<a href='.$all['url'].'>'.$all['name'].'</a>'; array_unshift($option,$all); return $option; } /** * 获取联动菜单层级 * @param $keyid 联动菜单分类id * @param $linkageid 菜单id * @param $leveltype 获取类型 parentid 获取父级id child 获取时候有子栏目 arrchildid 获取子栏目数组 */ function get_linkage_level($keyid,$linkageid,$leveltype = 'parentid') { $child_arr = $childs = array(); $leveltypes = array('parentid','child','arrchildid','arrchildinfo'); $datas = getcache($keyid,'linkage'); $infos = $datas['data']; if (in_array($leveltype, $leveltypes)) { if($leveltype == 'arrchildinfo') { $child_arr = explode(',',$infos[$linkageid]['arrchildid']); foreach ($child_arr as $r) { $childs[] = $infos[$r]; } return $childs; } else { return $infos[$linkageid][$leveltype]; } } } // 根据linkageid递归到父级 function get_parent_url($modelid,$field,$linkageid=0,$array = array()){ $modelid = intval($modelid); if(!$modelid || empty($field)) return false; $fields = getcache('model_field_'.$modelid,'model'); $keyid = $fields[$field]['linkageid']; $datas = getcache($keyid,'linkage'); $infos = $datas['data']; if(empty($linkageid)){ $linkageid = intval($_GET[$field]); if(!$linkageid) return false; } $urlrule = structure_filters_url($field,array(),1,$modelid); $urlrule = str_replace('{$'.$field.'}',$infos[$linkageid]['parentid'],$urlrule); array_unshift($array,array('name'=> $infos[$linkageid]['name'],'url'=>$urlrule)); if($infos[$linkageid]['parentid']){ return get_parent_url($modelid,$field,$infos[$linkageid]['parentid'],$array); } return $array; } /** * 构造筛选时候的sql语句 */ function structure_filters_sql($modelid) { $sql = $fieldname = $min = $max = ''; $fieldvalue = array(); $modelid = intval($modelid); $model = getcache('model','commons'); $fields = getcache('model_field_'.$modelid,'model'); $fields_key = array_keys($fields); //TODO $sql = '`status` = \'99\''; foreach ($_GET as $k=>$r) { if(in_array($k,$fields_key) && intval($r)!=0 && ($fields[$k]['filtertype'] || $fields[$k]['rangetype']|| $fields[$k]['boxtype'])) { if($fields[$k]['formtype'] == 'linkage') { $datas = getcache($fields[$k]['linkageid'],'linkage'); $infos = $datas['data']; if($infos[$r]['arrchildid']) { $sql .= ' AND `'.$k.'` in('.$infos[$r]['arrchildid'].')'; } } elseif($fields[$k]['rangetype']) { if(is_numeric($r)) { $sql .=" AND `$k` = '$r'"; } else { $fieldvalue = explode('_',$r); $min = intval($fieldvalue[0]); $max = $fieldvalue[1] ? intval($fieldvalue[1]) : 999999; $sql .=" AND `$k` >= '$min' AND `$k` < '$max'"; } }elseif($fields[$k]['boxtype']=='checkbox') { $sql .=" AND `$k` like '%,$r,%'"; } else { $sql .=" AND `$k` = '$r'"; } } } // echo $sql; return $sql; } /** * 分页,如去掉则分页会有问题 */ function makeurlrule() { if(strpos(URLRULE,'.html') === FALSE) { return url_par('page={$'.'page}'); } else { $url = preg_replace('/-[0-9]+.html$/','-{$page}.html',get_url()); return $url; } } /********************实现前台输出“选项名称”功能************************/ /** * 根据box类型字段获取显示名称 * @param $field 字段名称 * @param $value 字段值 * @param $modelid 字段所在模型id */ function box($field, $value, $modelid='') { $fields = getcache('model_field_'.$modelid,'model'); extract(string2array($fields[$field]['setting'])); $options = explode("\n",$fields[$field]['options']); foreach($options as $_k) { $v = explode("|",$_k); $k = trim($v[1]); $option[$k] = $v[0]; } $string = ''; switch($fields[$field]['boxtype']) { case 'radio': $string = $option[$value]; break; case 'checkbox': $value_arr = explode(',',$value); foreach($value_arr as $_v) { if($_v) $string .= $option[$_v].' 、'; } break; case 'select': $string = $option[$value]; break; case 'multiple': $value_arr = explode(',',$value); foreach($value_arr as $_v) { if($_v) $string .= $option[$_v].' 、'; } break; } return $string; } ?> 模板调用: {template "content","header"} <!--main--> <div class="main"> <div class="col-left"> <div class="crumbs"><a href="{siteurl($siteid)}">首页</a><span> > </span>{catpos($catid)} 列表</div> {php $sql = structure_filters_sql($modelid)} {php $urlrule = makeurlrule()} {pc:content action="lists" catid="$catid" where="$sql" num="3" order="id DESC" page="$page" moreinfo="1" urlrule="$urlrule"} <ul> {loop $data $r} <li><h2><a href="{$r[url]}" title="{$r[title]}" target="_blank">{$r[title]}</a></h2>设计风格: {box('sjfg',$r[sjfg],$modelid)} 户型:{box('hx',$r[hx],$modelid)} 面积:{box('mj',$r[mj],$modelid)} </li> {/loop} </ul> <div id="pages" class="text-c">{$pages}</div> {/pc} </div> <div class="col-auto"> <div class="box"> <h5 class="title-2">设计风格</h5> <ul class="content digg"> {loop filters('sjfg',$modelid) $r} <li>{$r[menu]} </li> {/loop} </ul> </div> <div class="bk10"></div> <div class="box"> <h5 class="title-2">户型</h5> <ul class="content digg"> {loop filters('hx',$modelid) $r} <li>{$r[menu]} </li> {/loop} </ul> </div> <div class="bk10"></div><div class="box"> <h5 class="title-2">面积</h5> <ul class="content digg"> {loop filters('mj',$modelid) $r} <li>{$r[menu]} </li> {/loop} </ul> </div> <div class="bk10"></div> </div> </div> {template "content","footer"} 调用解析: pc标签调用筛选后的结果代码: {php $sql = structure_filters_sql($modelid)} {php $urlrule = makeurlrule()} {pc:content action="lists" catid="$catid" where="$sql" num="3" order="id DESC" page="$page" moreinfo="1" urlrule="$urlrule"} 输出自定义字段的选项名称代码: {box('sjfg',$r[sjfg],$modelid)} //sjfg为添加的自定义字段 $modelid为模型id号 调用筛选字段并展现代码: {loop filters('sjfg',$modelid) $r} //sjfg为添加的自定义字段 $modelid为模型id号 <li>{$r[menu]}</li> {/loop}
相关文章推荐
- PHPCMS V9 分类信息列表页title里面如何调用显示筛选分类
- PHPCMS V9模板设计程序二级开发中常用的一些网站相关信息变量列表
- PHPCMS V9 分类信息列表页title里面如何调用显示筛选分类
- Nutch二次开发之定制爬取网站信息
- 赶集网杨浩涌:分类信息网站的未来之路
- 分类信息网站成逆市上扬主力
- 也来谈下本地分类信息网站推广些许心得——网赚系列
- 购物、机票、酒店、打折信息网站开发完成beekle.com
- 一个网站要提供很多种商品和信息 当然就有很多分类了 请问数据库怎么设计阿?
- lp0606分类信息网站,诚信商家联盟
- 分类信息网站拼的是技术和执行力
- 项目调试之供求网站信息开发----实现网页中搜索匹配查询功能
- 分类信息网站大量涌现 信息本地化凸显
- MongoDB被全球最大的分类信息网站Craigslist使用
- 基于ASP.NET MVC2 EntityFramework 实现的分类信息网站的原型!
- 基于ASP.NET MVC2 EntityFramework 实现的分类信息网站的原型!
- 信息分类能给网站设计带来巨大好处
- 互联网中文分类信息网站收集
- 分类信息网站发展进入快车道
- NDK开发的网站信息