thinkphp5学习路程 十 详情页和上下页功能实现

2021-03-16 21:11:10 浏览数 (1)

详情页实现思路:

用户在观看留言页面中点击标题,就会导航到详情页面,通过获取请求页面中的id值来确定哪条数据,然后再与数据库进行交互将数据取出显示在页面中;

上下页实现思路:

第一种方式就是改变url中的id值加一减一来实现,但会出现当没有某条数据时不能继续工作的弊端;

另外一种方式,就是查询大于id值的然后按从小到大排序,然后从取出的第一个id就是下页的id,查询小于id值的然后从大到小排序,取出第一个id就是上一页的id值;

代码语言:javascript复制
//展示详情
	public function view(){
		echo input('param.id');

		$id = input('id');

		if($id<>''){
			//查询数据
		$list = Db::table('user')
		->where('id','=',$id)
		->select();
		dump($list);

		//下一条数据
		$up = Db::table('user')
		->where('id','>',$id)
		->order('id','')
		->limit(1)
		->value('id');
		dump($up);

		//上一条数据
		$next = Db::table('user')
		->where('id','<',$id)
		->order('id','desc')
		->limit(1)
		->value('id');

		dump($next);

		$this->assign('up',$up);
		$this->assign('next',$next);
		$this->assign('list',$list);

		return $this->fetch();
		}

		return '查询的文章不存在';
	}

在下图中的 {$list.0.title} 是为了取第一个匹配的数据

代码语言:javascript复制
eq或者equal         表示       等于
neq或者notequal     表示       不等于
gt                  表示       大于
egt                 表示       大于等于
it                  表示       小于
eit                 表示       小于等于


//condition条件    当$next不为空时
{if condition="$next neq ''"}
      <a href="/studytp5/public/index.php/index/Lyb/view/id/{$next}">上一页</a>
{else /}  上一页没有了
{/if}


{eq name="name" value="value"}    //当name中的变量等于value中的值时
   相等
{else/}
   不相等
{/eq}

0 人点赞