![](https://box.kancloud.cn/896b44a3739d9d42169a0ec2cb01890f_614x347.jpg)
下面讲解,在首页,如何调用圈子的同时也调用他们相关的贴子.
单单调用圈子,就像调用文章一样,很多人都能轻松实现,
比如下面的代码
~~~
{qb:tag name="xxx" type="qun" rows="4"}
<div style="border:1px solid #333;margin:20px;">
<div>圈子名称:{$rs.title}</div>
</div>
{/qb:tag}
~~~
如果还要调用圈子的贴子或商品的话,很多人就会想到内循环,在过去,包括现在很多同行,也是这么做的,通过内循环去调用相关的数据,
但是我们非常反对这样做,因为这样效率非常低,容易把页面卡死,所以齐博标签不支持内循环.
要实现内部数据相关联,我们要借助JS实现异步加载, 这样就不会影响页面的打开,提高用户体验.
代码如下
~~~
{qb:tag name="xxx" type="qun" rows="4"}
<div style="border:1px solid #333;margin:20px;">
<div>圈子名称:{$rs.title}</div>
<div class="qun_bbs_title" data-id="{$rs.id}">
<!--圈子的相关联的贴子数据,外层的qun_bbs_title是给JS处理数据做标志的,data-id就是标志圈子的ID,外层的这两个元素必须要存在-->
</div>
</div>
{/qb:tag}
<div style="display:none;">
<!--圈子相关联的贴子数据的标签,移动这里来了,这是一个孤岛,他要通过下面的JS处理,才能把数据转移到圈子里边-->
<!--其中关键点 ext_id=$ext_id 就是贴子数据表中的字段,用来跟圈子做关联的 -->
{qb:tag name="bbs_tpl_001" type="bbs" rows="3" js="xx01" where="ext_id=$ext_id"}
<li>{$i}、<a href="{:urls('bbs/content/show','id='.$rs.id)}">{$rs.title}</a></li>
{/qb:tag}
</div>
<!--JS异步获取相关数据-->
<script type="text/javascript">
$(".qun_bbs_title").each(function(){
var that = $(this); //下面进行DIV赋值贴子数据要用
var id = $(this).data('id'); //对应每个圈子的ID
var page = 1; //只显示第一页的内容
var url = "{qb:url name='bbs_tpl_001'}" + page + "&ext_id=" + id; //这里的跟之前讲的标签获取更多数据一样的,重点就ext_id是贴子里的字段要跟圈子相关联
//下面这一段,都是通用代码,取得贴子数据后,就传给圈子
$.get(url,function(res){
if(res.code==0){
if(res.data!=''){
that.html(res.data);
}
}
});
});
</script>
~~~
上面的代码当中,由于标签不支持嵌套, 所以把 圈子的相关数据,即贴子的标签移了出来.
以下这部分就是圈子的贴子标签部分,其中标签里边的内容,才是有用的.标签外的就是把他隐藏起来,不要影响页面布局.
~~~
<div style="display:none;">
<!--圈子的相关数据的标签,移动这里来了-->
{qb:tag name="bbs_tpl_001" type="bbs" rows="3" js="xx01" where="ext_id=$ext_id"}
<li>{$i}、<a href="{:urls('bbs/content/show','id='.$rs.id)}">{$rs.title}</a></li>
{/qb:tag}
</div>
~~~
另外在圈子部分中关联贴子的DIV代码也有两项关键参数
~~~
<div class="qun_bbs_title" data-id="{$rs.id}">
~~~
其中`data-id="{$rs.id}"` 就是标志圈子的ID值
而`class="qun_bbs_title"` 就是标志给下面JS处理数据用的.
![](https://box.kancloud.cn/4bc8bec66f45f6c8f8d86d15b6182f0e_1202x796.jpg)
贴子标签中,有一项关键的参数
`where="ext_id=$ext_id"` 这个就是非常关键的地方, 之前跟大家讲解过where就是条件筛选用的.这里要用变量参数,
在这里,贴子里边的ext_id字段是跟圈子相关联的.所以这里就这么写,如果是用户相关联的话,就要换成`where="uid=$uid"`
下面这段JS代码,大家必须要熟练,因为到处都会用到
~~~
<script type="text/javascript">
$(".qun_bbs_title").each(function(){
var that = $(this);
var id = $(this).data('id'); //对应圈子的ID
var page = 1; //只显示第一页的内容
var url = "{qb:url name='bbs_tpl_001'}" + page + "&ext_id=" + id;
$.get(url,function(res){
if(res.code==0){
if(res.data!=''){
that.html(res.data);
}
}
});
});
</script>
~~~
其中下面这个就是JQ的知识,就是说寻找 qun_bbs_title这样的类的元素,对他进行相关处理, 我们上面标注了圈子里相关的贴子,要进行相关处理
~~~
$(".qun_bbs_title").each(function(){
//执行相关操作
});
~~~
而其中这个
~~~
var url = "{qb:url name='bbs_tpl_001'}" + page + "&ext_id=" + id;
~~~
就跟之前跟大家讲解的标签获取分页数据,异步更新类似的. 用得非常多,所以大家必须要熟悉. 这里的标签名`bbs_tpl_001`跟上面的贴子标签名必须是一致的, 这里的页码,只取第一页, `"&ext_id=" + id` 这个就是关键之处了,圈子id就是通过JS得到的,然后传递给贴子数据表中的关联字段 ext_id ,这样就可以调取到对应的贴子了
* * *
上面讲解的是调用论坛的贴子, 换一下就能调用圈子的商品 或文章 .
另外,还可以同时调用的. 需要把JS复制多一份, 标签名与类名不要重复即可.
- 序言
- 声明
- 齐博X1基础
- 齐博X1的诞生
- 齐博X1目录结构
- 如何安装齐博X1
- 新手快速入门教程
- 常用文件目录说明
- 齐博X1标签
- 什么是标签
- 当前URL标签
- 图片标签
- 单张图片标签的使用
- 多张组图的标签调用
- 标签进阶之幻灯片制作
- 背景图如何设置标签
- 内容页标签
- 内容页中下一页上一页的标签
- 内容评论标签的风格制作
- 标签实例
- 做模板组图单图无图混排的处理
- 列表页制作及无滚动加载内容
- 调用多个圈子同时调用贴子
- 调用多个圈子同时调用相关会员
- 标签的嵌套用法,调用聚合数据
- 标签如何调用论坛内容
- 标签设置取组图不存在就取内容中的图片
- 标签之无刷新显示更多
- 异步加载标签数据
- 标签动态调用数据
- 文本代码标签的使用
- where 标签动态变量查询
- where 实现条件筛选与数据关联
- 会员中心如何加标签
- 模板中常用的TP标签数据处理
- 同一个标签要更换不同模块的数据
- 万能数据统计之fun函数
- 齐博X1模块
- 什么是模块?模块的组成。
- 如何添加字段
- 栏目名称的调用
- 栏目名称调用详解
- 相关栏目名称的调用
- 辅栏目(专题)的使用说明
- 模块后期要加参数的方法
- 表单自动生成器
- 简单的模块制作说明(随风编写)
- 齐博X1插件
- 插件.七牛云.配置说明
- 齐博X1钩子
- 钩子简单制作-tag加连接解说版(随风编写)
- 齐博X1模板
- 模板目录文件说明
- 几个关键模板文件要熟知
- 新模板要注意问题
- 模板文件调用的优先级
- 2018.8.13模板制作升级调整
- block模板的分块替换
- 模板包含文件使用说明
- 圈子黄页风格制作说明
- 齐博X1配置
- 微信和小程序的配置
- 如何对接公众号
- 对接小程序设置
- 在线支付接口的使用
- 支付宝对接收款配置
- 阿里云短信配置
- 邮箱接口设置
- 邮箱接口设置之QQ普通邮箱
- 邮箱接口设置之163普通邮箱
- 邮箱接口设置之QQ企业邮箱
- QQ登录接口配置
- 齐博X1路由
- URL伪静态设置
- route.php与routemy.php短网址设置
- 齐博X1二次开发
- 二次开发的灵魂fun函数
- 商城判断是否购买过
- 如何调取当前模块ID
- 模块安装文件讲解
- 表单快速启用城市地区功能
- 自定义字段多文件多图的显示处理
- 后台网站参数配置修改与添加
- 频道插件如何对接圈子
- 自定义字段下拉菜单关联其它数据表
- 自定义字段表单默认调用会员资料
- 齐博X1注意事项
- 云市场注意事项
- 如何强制进后台
- 换服务器如何转移网站
- 再强调严禁用记事本改任何文件
- 解决Web部署 svg/woff/woff2字体 404错误
- 齐博X1更新记录
- 关于thinkphp5