最近在学javascript,才慢慢开始读懂JS代码。对HTML前台AJAX加载技术研究了一番,像博客站或者图片站运用AJAX异步无限加载,做成瀑布流,提高用户体验,这是AJAX异步加载的优点。
AJAX异步加载的弊端:属于WEB前端技术,蜘蛛不会抓JS调用的内容,也就是并不利于SEO优化。所以要运用这个功能的话最好有一部分直接调用,另一部分采用AJAX异步加载。
接下来用织梦来做AJAX异步加载WEB前端开发。网上有诸多教程,经过笔者整理,给出详细说明,修正后分享给大家。
打开/plus/list.php,找到
require_once(dirname(__FILE__).”/../include/common.inc.php”);
下面增加代码
if(isset($_GET[‘ajax‘])){
$typeid = isset($_GET[‘typeid']) ? intval($_GET[‘typeid']): 0;//传递过来的分类ID
$page = isset($_GET[‘page']) ? intval($_GET[‘page']): 0;//页码
$pagesize = isset($_GET[‘pagesize']) ? intval($_GET[‘pagesize']): 15;//每页多少条,也就是一次加载多少条数据
$start = $page>0 ? ($page-1)*$pagesize : 0;//数据获取的起始位置。即limit条件的第一个参数。
$typesql = $typeid ? ” WHERE typeid=$typeid” : ”;//这个是用于首页实现瀑布流加载,因为首页加载数据是无需分类的,所以要加以判断,如果无需
$total_sql = “SELECT COUNT(id) as num FROM `dede_archives` $typesql “;
$temp = $dsql->GetOne($total_sql);
$total = 0;//数据总数
$load_num =0;
if(is_array($temp)){
$load_num= round(($temp[‘num']-15)/$pagesize);//要加载的次数,因为默认已经加载了
$total = $temp[‘num'];
}
$sql = “SELECT a.*,t.typedir,t.typename,t.isdefault,t.defaultname,t.namerule,
t.namerule2,t.ispart, t.moresite,t.siteurl,t.sitepath
FROM `dede_archives` as a JOIN `dede_arctype` AS t ON a.typeid=t.id $typesql ORDER BY id DESC LIMIT $start,$pagesize”;
//echo “$sql”;
$dsql->SetQuery($sql);
$dsql->Execute(‘list');
$statu = 0;//是否有数据,默认没有数据
$data = array();
$index = 0;
while($row = $dsql->GetArray(“list”)){
$row[‘info'] = $row[‘info'] = $row[‘infos'] = cn_substr($row[‘description'],160);
$row[‘id'] = $row[‘id'];
$row[‘filename'] = $row[‘arcurl'] = GetFileUrl($row[‘id'],
$row[‘typeid'],$row[‘senddate'],$row[‘title'],$row[‘ismake'],
$row[‘arcrank'],$row[‘namerule'],$row[‘typedir'],$row[‘money'],
$row[‘filename'],$row[‘moresite'],$row[‘siteurl'],$row[‘sitepath']);
$row[‘typeurl'] = GetTypeUrl($row[‘typeid'],$row[‘typedir'],
$row[‘isdefault'],$row[‘defaultname'],$row[‘ispart'],
$row[‘namerule2'],$row[‘moresite'],$row[‘siteurl'],$row[‘sitepath']);
if($row[‘litpic'] == ‘-‘ || $row[‘litpic'] == ”){
$row[‘litpic'] = $GLOBALS[‘cfg_cmspath'].'/images/defaultpic.gif';
}
if(!preg_match(“#^http://#i”, $row[‘litpic']) &&$GLOBALS[‘cfg_multi_site'] == ‘Y'){
$row[‘litpic'] = $GLOBALS[‘cfg_mainsite'].$row[‘litpic'];
}
$row[‘picname'] = $row[‘litpic'];//缩略图
$row[‘stime'] = GetDateMK($row[‘pubdate']);
$row[‘typelink'] = “”.$row[‘typename'].””;//分类链
$row[‘fulltitle'] = $row[‘title'];//完整的标题
$row[‘shorttitle'] = $row[‘shorttitle'];//副标题
$row[‘title'] = cn_substr($row[‘title'], 60);//截取后的标题
$data[$index] = $row;
$index++;
}
if(!empty($data)){
$statu = 1;//有数据
}
$result =array(‘statu'=>$statu,'list'=>$data,'total'=>$total,'load_num'=>$load_num);
echo json_encode($result);//返回数据
exit();
}
模板文件增加内容
在需要用AJAX异步加载的模板的前增加代码
首页HTML代码示例
注意:首页模板用arclist标签,用row='3'是初始化调用的3条;列表模板用list标签,用pagesize='3'。模板里面的
查看源码打印代码帮助
- [field:array runphp='yes']@me = (empty(@me[‘litpic']) ? “” : “
”); [/field:array]
[[field:typelink/]] [field:title/] 日期:[field:pubdate function=”GetDateTimeMK(@me)”/] 点击:[field:click/] 好评:[field:scores/]
[field:description/]…
{dede:arclist row='3′}
{/dede:arclist}
文章名称:《织梦模板DEDE首页列表页AJAX无限加载瀑布流修正版》
文章链接:https://www.ibytx.com/645.html
本站资源仅供个人学习交流,请于下载后24小时内删除,不允许用于商业用途,否则法律问题自行承担。
相关推荐
#十月狂欢#Hostease:购虚拟主机送独立IP,购买美国/香港服务器,加送125个独立IP,可选不同C段,新老同享,先到先得,送完即止
#即将结束#SiteGround:19周年庆特别优惠,外贸主机/WordPress主机,年付低至$23.88,月付$1.99起
SiteGround:19周年庆特别优惠,外贸主机/WordPress主机,年付低至$23.88,月付$1.99起
bacloud黑五促销:便宜服务器,E5v4U26Q独立服务器6折,Linux KVM VPS 5折,虚拟主机7折,可选美国/荷兰/立陶宛机房
php中方法和函数的区别
Laravel框架Warning: require(../vendor/autoload.php): failed to open stream: No such file or directory in .../autoload.php on line 17错误的解决办法
layer.closeAll()无效的解决办法
php获取前一小时、前一天、三天前、前一个月、三个月前、前一年的时间

博悦天下



