TP5的ajax异步列表加载更多

一、前端(只是模拟,没有把项目中的前端全部搬过来)

<div class="box">
	<ul></ul>
	<div class="tj_more">
		<a href="javascript:;" class="load-more">查看更多</a>
	</div>
</div>

 

二、js代码

<script>
		//列表加载更多
		var page = 1;
		$('.load-more').click(function(){
			var _this = $(this),
			html = '';
			if(_this.text() == '查看更多'){
				_this.html('加载中...');
			}else{
				return false;
			}
            
			//下面的属性
			var categoryIds = '{$cateid}';

			$.ajax({
				type: "post",
				url: "/article/mlist.html",
				data: {page:page, status:1, cateid:categoryIds},
				dataType: "json",
				success: function(date) {
					if(date.status == 1){
						setTimeout(function(){
							_this.parents('.box').children('ul').append(date.data);
							page = page+1;
							if(date.message < 2){
								_this.html('暂无更多');
								_this.css('background', 'none');
								_this.css('color', '#000');
							}else{
								_this.html('查看更多');
							}
							
						}, 500);
					}else{
	
					}
				}
			});
			
		});
</script>

 

三、后端控制器

//手机列表页
        $num = 2;
        if(request()->isAjax()){
            $data['page'] = input('page');
            $cateid = input('cateid');
             //页数
            $articles = model('Article')->mGetypeArticle($cateid,$data['page']*$num,$num);
            
            $count = count($articles);
           
             //循环数据
            $htmls = '';
            foreach ($articles as $key => $value) {
                $html = "<li class='news_top'>
                            <a href='news/".$value['id']."'>
                                <div class='n_t_text'>
                                    <span>".$value['title']."</span>
                                    <span>".$value['short']."</span>
                                </div>
                                <div class='time'>
                                    <span>小编:".$value['author']."</span>
                                    <span>浏览量:".$value['click']."</span>
                                    <span>".date("Y-m-d",$value['create_time'])."</span>
                                </div>
                            </a>
                        </li>";
                $htmls .= $html;
            }
            return show('1',$count,$htmls);
        }else{
            $articles = model('Article')->mGetypeArticle($cateid,0,$num);
        }

四、还有模型中的代码就不贴了,毕竟数据库也看不到,项目中世纪效果是有的,主要就是js跟控制器的返回json数据

TP5 中实现异步任务可以使用 Swoole 扩展或者 PHP 原生的多进程和多线程技术。 1. Swoole 实现异步任务 Swoole 是一个 PHP 的异步、并行、高性能网络通信框架,它提供了异步、多进程、协程等多种编程模式,可以实现高性能的异步任务。 具体实现方式可以参考以下代码: ```php use think\facade\Db; use Swoole\Process; // 创建异步子进程 $process = new Process(function (Process $worker) { // 子进程中执行异步任务 // ... // 任务执行完成,向主进程发送消息 $worker->push('task finished'); }); // 启动子进程 $process->start(); // 等待子进程返回结果 echo $process->pop(); ``` 上述代码创建了一个异步子进程,然后在子进程中执行异步任务,最后向主进程发送消息。 2. PHP 原生实现异步任务 PHP 原生提供了多进程和多线程技术,可以实现异步任务。 具体实现方式可以参考以下代码: ```php use think\facade\Db; // 创建新进程 $pid = pcntl_fork(); if ($pid === -1) { // 创建进程失败 } else if ($pid) { // 父进程中 // ... // 等待子进程返回结果 pcntl_wait($status); } else { // 子进程中执行异步任务 // ... // 任务执行完成,退出子进程 exit(); } ``` 上述代码使用 `pcntl_fork` 函数创建新进程,并在子进程中执行异步任务,最后退出子进程。在父进程中可以等待子进程返回结果。 需要注意的是,PHP 原生的多进程和多线程技术需要注意进程间的数据同步和通信,以避免数据不一致和死锁等问题。 总之,TP5 实现异步任务可以通过 Swoole 扩展或者 PHP 原生的多进程和多线程技术来实现。需要根据实际情况选择合适的技术方案,并注意数据同步和通信的问题。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值