位置: IT常识 - 正文

phpcms文章如何筛选分类?(phpcms怎么用)

编辑:rootadmin
phpcms文章筛选分类的方法:首先替换【phpcms/libs/functions/extention.func.php】中的内容;然后在内容的模型管理里选择一个模型添加新字段;最后在要调用产品筛选的栏目模板页添加标签即可。

推荐整理分享phpcms文章如何筛选分类?(phpcms怎么用),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:php筛选功能,php筛选txt内容,php站内搜索,php筛选功能,php筛选txt内容,php筛选功能,phpcms怎么用,php筛选功能,内容如对您有帮助,希望把文章链接给更多的朋友!

phpcms文章如何筛选分类

phpcms文章如何筛选分类?(phpcms怎么用)

phpcms文章筛选分类的方法:

首先,用下面这些代码替换掉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;}/*** 构造筛选URL*/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传值构造URLif (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'])) {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'";}} else {$sql .=" AND `$k` = '$r'";}}}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;}}?>

然后,内容——模型管理——选择一个模型添加新字段,如图。

最后,在要调用产品筛选的栏目模板页添加标签 ,如下。

<span>性别:</span>{loop filters('xingbie',$modelid) $r}{$r[menu]}{/loop}{php $sql = structure_filters_sql($modelid)}{php $urlrule = makeurlrule()}{pc:content action="lists" where="$sql" catid="$catid" num="10" order="id DESC" page="$page" urlrule="$urlrule"}<ul class="photo-list picbig">{loop $data $r}<li><div class="img-wrap"><a href="{$r[url]}"><img src="{thumb($r[thumb],150,112)}" width="150" height="112" alt="{$r[title]}"/></a></div><span style="color:{$r[style]}">{str_cut($r[title],28)}</span></li>{/loop}</ul><div id="pages" class="text-c">{$pages}</div>{/pc}

推荐教程:《phpcms》

本文链接地址:https://www.jiuchutong.com/zhishi/311753.html 转载请保留说明!

上一篇:帝国CMS商城系统如何实现在线支付后发送订单邮件提醒功能(帝国cms使用手册)

下一篇:OK源码中国首发微擎破解模块首页主题永和自适应代理首页v9.1.3-OK源码破解(okr开源软件)

  • 个人车辆无偿给公司使用
  • 个体户季报网上怎么报税
  • 个税什么情况可以抵扣
  • 开给个人的普票购买方怎么写
  • 出租包装物租金是营业外收入吗
  • 房产税简易征收的时间
  • 办公家具可以一次性税前扣除吗
  • 企业控股情况怎么填写
  • 为什么租赁只能20年
  • 事务所和公司的专利工程师
  • 如何申请免税
  • 持有待售固定资产按照账面价值与可收回金额
  • 一般纳税人财务报表月报还是季报
  • 企业破产的费用的承担
  • 事业基金弥补收支差额是什么意思
  • 非独立核算的分公司如何报税
  • 民间非营利组织会计科目
  • 公司拖欠工资还要继续工作吗?
  • 培训费可以抵扣企业所得税
  • 购买理财产品会损失本金吗
  • 公司买汽车怎么做内账
  • 收到社保补助不发放
  • 购进商品用于样品赠送的账务处理
  • 计提增值税的账务处理小规模
  • 增值税季度不超过30万
  • 1697508019
  • 城镇土地使用税税率
  • 土地使用税和房产税
  • 小规模纳税人进项税额怎么算
  • 无法查明原因现金盘盈计入什么科目
  • win10更新kb5006670
  • 个人所得税计算方法及抵扣方法
  • qtzgacer.exe - qtzgacer进程是什么文件 .作用是什么
  • php生成app
  • linux传输数据
  • 好的投资理财项目
  • 一本书装订费多少钱
  • 石榴石的功效与作用价值
  • rtp webrtc
  • 高温补贴 个人所得税
  • php获取文件内容
  • 前端框架源码
  • ChatGPT全面升级,GPT4支持多模态数据。
  • 气温和降水空间变化一月平均气温规律是什么原因是什么
  • linux嵌入式开发教程
  • 计提增值税依据
  • mongodb4.4.2安装教程
  • 会计准则中规范性的内容
  • 零星采购入什么科目
  • 甲方向乙方支付
  • 如何计算保费合同未规定加成比例
  • 未取得发票如何报销
  • 一般纳税人的招待费会计分录
  • 政府补助冲减成本
  • 外出经营活动需要预缴税款吗2020年
  • 营改增涉及哪些项目
  • 企业会计制度对固定资产无入账价值怎么入账
  • 如何合理的运用网络
  • 业务招待费可以结转下年抵扣吗
  • 金税盘买发票还要填交验旧表吗?
  • 缴纳注册资金印花税怎么做账
  • MYSQL数据库原理及应用
  • windows7升级到windows8.1
  • sun solaris 8何启用telnet ftp 功能
  • 怎样打开windows设置页面
  • 硬盘安装好了显示不出来怎么办
  • ubuntu安装kdevelop
  • win8.1开始菜单改win7
  • 猫的所有视频
  • javascript 二维码
  • android studio右边的视图不见了
  • JavaScript+html5 canvas实现图片破碎重组动画特效
  • shell脚本实现Linux运维监控
  • android的图片文件保存在工程的哪个文件夹
  • 怎么用python播放音乐
  • 公益性捐赠支出属于什么会计科目
  • 预缴的增值税怎么做账务处理
  • 2006年发生哪一些大案
  • 日照公交305发车时间表
  • 预缴增值税申报表申报期限
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设