| |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
-> JavaScript知识库 -> 仿百度百科的网站项目源码开发 第三篇 -> 正文阅读 |
|
[JavaScript知识库]仿百度百科的网站项目源码开发 第三篇 |
前面开发了几个板块,关于模仿百度百科的网站项目,现在接着更新后面的内容,今天主要的功能是内容页模块,前面的几篇可以看我的个人主页就行。 public function index($id) { //导航条 $nav = CateModel::where(['id'=>$id])->find(); //一级分类 $cate = CateModel::getList(['pid'=>0,'id'=>['neq',56]],'id desc','20'); $cate = Db::table('e_cate')->where(['pid'=>0,'id'=>['neq',56]])->order('id desc')->limit(20)->select(); //文章排行榜 $ranking = ArticleModel::getList(['adopt'=>1],'click desc','10'); //最新代码 $codenew = Down::getList([],'softid desc',10); //获取数据 // $data = ArticleModel::getList(['cateid'=>$id],'id desc','8'); $snum = substr_count($id,'_'); if(!$snum){ $page = 1; }else{ $page = explode('_',$id)[1]; } $data = Db::table('e_article')->where(['cateid'=>$id,'adopt'=>1])->order('id desc')->limit(($page-1)*10,10)->select(); $count = Db::table('e_article')->where(['cateid'=>$id,'adopt'=>1])->count(); $page = $this->pageHtml($page,$count,10,'/list/'.explode('_',$id)[0].'_'); $data = ToArray($data); foreach ($data as $key=>$val){ $data[$key]['content'] = $this->cutstr_html($val['content']); $data[$key]['keyword'] = explode(',',$val['keywords']); } //字数截取 // $data = ArticleModel::SubstrField($data,'content'); return $this->fetch('',[ 'nav'=>$nav, 'data'=>$data, 'cate'=>$cate, 'page'=>$page, 'ranking'=>$ranking, 'codenew'=>$codenew ]); } 所有数据量 public function pageHtml($page,$count,$num=10,$address='/list/') { //所有数据量 $number = $count; //页码数量 $pageNum = ceil($number/$num); $list = " <ul class='J_page'> <li><a href='".$address."1.html'>首页</a></li>"; $list .= ($page==1)?"":"<li><a href='".$address.($page-1).".html'>上一页</a></li>"; $list .= (($page-2)>0)?"<li><a href='".$address.($page-2).".html'>".($page-2)."</a></li>":''; $list .= (($page-1)>0)?"<li><a href='".$address.($page-1).".html'>".($page-1)."</a></li>":''; $list .= " <li class='nowpage'><a href='javascript:void(0);'>$page</a></li>"; $list .= ($page+1)<=$pageNum?"<li><a href='".$address.($page+1).".html'>".($page+1)."</a></li>":''; $list .= ($page+2)<=$pageNum?"<li><a href='".$address.($page+2).".html'>".($page+2)."</a></li>":''; $list .= ($page+1)<=$pageNum?"<li><a href='".$address.($page+1).".html'>下一页</a></li>":''; $list .= "<li><a href='".$address.$pageNum.".html'>尾页</a></li>"; $list .= "<li><a href='javascript:void(0);'>跳转到</a><input type='text' value='".$page."' class='jump_page' style='width: 30px;text-align:center;color: #fff;background: transparent;outline: none;'><a>页</a><a style='margin-left: 20px;cursor: pointer' οnclick='jumpToPage(\"$address\",$pageNum)'>跳转</a></li>"; $list .=" </ul>"; return $list; } public function cutstr_html($string, $sublen='') { $string = strip_tags($string); return trim($string); } 公共文件 class Common extends Controller { public function _initialize() { parent::_initialize(); // TODO: Change the autogenerated stub $titleConf = db('conf1')->where(['cnname'=>'板块站点名称'])->value('value'); $this->assign('titleConf',$titleConf); if(isset($_COOKIE['session_id'])){ session_id($_COOKIE['session_id']); session('n',''); if(isset($_SESSION['user_id'])){ session('user_id',$_SESSION['user_id']); } if(isset($_SESSION['username'])){ session('username',$_SESSION['username']); } if(isset($_SESSION['userpic'])){ session('userpic',$_SESSION['userpic']); } } } public function index($id='') { if(!$id){ $id = Db::table('e_imgclass')->value('classid'); $this->redirect('/list/'.$id.'_1.html');die; } $res = strpos(Str::lower($id),'y'); if($res){ $id = substr($id,4); } //统计字符串出现的次数 $snum = substr_count($id,'_'); $page = substr($id,strripos($id,'_')+1); $route = '/list/'.substr($id,0,strripos($id,'_')+1); if($snum==2){ $sid = substr($id,strpos($id,'_')+1); $sid = substr($sid,0,strpos($sid,'_')); if($sid){ //获取分类信息 $data = SoftCate::where(['classid'=>$sid])->field('classkey,classintro,classid,classname')->find(); //获取分类下的所有源码产品信息 $CateIDs = self::getCateIds($sid); //获取三级子分类 if(!empty($CateIDs)){ $thirdCate = DB::table('e_imgclass')->where(['classid'=>['in',$CateIDs]])->select(); $this->assign('thirdCate',$thirdCate); } $CateIDs[] = $sid; $nid = strpos($id,'_'); $id = substr($id,0,$nid); $firstData = SoftCate::where(['classid'=>$id])->field('classkey,classintro,classid,classname')->find(); $this->assign('firstData',$firstData); }else{ $id = substr($id,0,strpos($id,'_')); //获取分类信息 $data = SoftCate::where(['classid'=>$id])->field('classkey,classintro,classid,classname')->find(); //获取分类下的所有源码产品信息 $CateIDs = self::getCateIds($id); $CateIDs[] = $id; } $this->assign('sid',$sid); }elseif ($snum==3){ //三级分类 $tid = substr($id,0,strripos($id,'_')); $tid = substr($tid,strripos($tid,'_')+1); $sid = substr($id,strpos($id,'_')+1); $sid = substr($sid,0,strpos($sid,'_')); $thirdCateIDs = self::getCateIds($sid); //获取三级子分类 $thirdCate = DB::table('e_imgclass')->where(['classid'=>['in',$thirdCateIDs]])->select(); $this->assign('thirdCate',$thirdCate); $this->assign('sid',$sid); $this->assign('tid',$tid); if($tid){ $data = SoftCate::where(['classid'=>$tid])->field('classkey,classintro,classid,classname')->find(); //获取分类下的所有源码产品信息 $CateIDs = self::getCateIds($tid); $CateIDs[] = $tid; $nid = strpos($id,'_'); $id = substr($id,0,$nid); }else{ $id = substr($id,0,strpos($id,'_')); //获取分类信息 $data = SoftCate::where(['classid'=>$sid])->field('classkey,classintro,classid,classname')->find(); $CateIDs = self::getCateIds($sid); $CateIDs[] = $sid; } }else{ //获取分类信息 $data = SoftCate::where(['classid'=>$id])->field('classkey,classintro,classid,classname')->find(); $id = substr($id,0,strpos($id,'_')); //获取分类下的所有源码产品信息 $CateIDs = self::getCateIds($id); $CateIDs[] = $id; } $LatestCate = SoftCate::LatestCate(); $HotCate = SoftCate::HotCate(); //获取所有一级分类 $firstCate = Db::table('e_imgclass')->where(['bclassid'=>0])->select(); //获取一级分类下面的二级分类 $secondCate = Db::table('e_imgclass')->where(['bclassid'=>$id])->select(); $page = $page?$page:1; // $list = db('img')->where(['classid'=>['in',$CateIDs],'checked'=>1,'softpic'=>['neq','']]) // ->order('softid desc,classid desc') // ->paginate('12',false,['query'=>request()->param()]); $list2 = db('img')->where(['classid'=>['in',$CateIDs],'checked'=>1,'softpic'=>['neq','']]) ->order('softid desc,classid desc') ->limit(($page-1)*12,12)->select(); $count = db('img')->where(['classid'=>['in',$CateIDs],'checked'=>1,'softpic'=>['neq','']]) ->order('softid desc,classid desc') ->count(); $pageShow = $this->pageHtml($page,$count,12,$route); //获取子级类目 $childCate = SoftCate::childCate($id); return $this->fetch('',[ 'secondCate'=>$secondCate, 'id'=> $id, 'firstCate'=>$firstCate, 'childCate'=>$childCate, 'data'=>$data, 'soft'=>$list2, 'current'=>4, 'latest'=>$LatestCate, 'hotCate'=>$HotCate, 'pageShow'=>$pageShow ]); } 自定义分页 public function pageHtml($page,$count,$num=12,$address='/list/') { //所有数据量 $number = $count; //页码数量 $pageNum = ceil($number/$num); $list = " <ul class='J_page'> <li><a href='".$address."1.html'>首页</a></li>"; $list .= ($page==1)?"":"<li><a href='".$address.($page-1).".html'>上一页</a></li>"; $list .= (($page-2)>0)?"<li><a href='".$address.($page-2).".html'>".($page-2)."</a></li>":''; $list .= (($page-1)>0)?"<li><a href='".$address.($page-1).".html'>".($page-1)."</a></li>":''; $list .= " <li class='nowpage'><a href='javascript:void(0);'>$page</a></li>"; $list .= ($page+1)<=$pageNum?"<li><a href='".$address.($page+1).".html'>".($page+1)."</a></li>":''; $list .= ($page+2)<=$pageNum?"<li><a href='".$address.($page+2).".html'>".($page+2)."</a></li>":''; $list .= ($page+1)<=$pageNum?"<li><a href='".$address.($page+1).".html'>下一页</a></li>":''; $list .= "<li><a href='".$address.$pageNum.".html'>尾页</a></li>"; $list .= "<li><a href='javascript:void(0);'>跳转到</a><input type='text' value='".$page."' class='jump_page' style='width: 30px;text-align:center;color: #fff;background: transparent;outline: none;'><a>页</a><a style='margin-left: 20px;cursor: pointer' οnclick='jumpToPage(\"$address\",$pageNum)'>跳转</a></li>"; $list .=" </ul>"; return $list; } |
|
JavaScript知识库 最新文章 |
ES6的相关知识点 |
react 函数式组件 & react其他一些总结 |
Vue基础超详细 |
前端JS也可以连点成线(Vue中运用 AntVG6) |
Vue事件处理的基本使用 |
Vue后台项目的记录 (一) |
前后端分离vue跨域,devServer配置proxy代理 |
TypeScript |
初识vuex |
vue项目安装包指令收集 |
|
上一篇文章 下一篇文章 查看所有文章 |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 | -2025/1/10 10:26:04- |
|
网站联系: qq:121756557 email:121756557@qq.com IT数码 |