【最全最详细】publiccms常用的代码片段

简介: 【最全最详细】publiccms常用的代码片段

🧘‍♂️往期系列

这两天一直在整理Publiccms系列的教程,有需要的小伙伴们可以点击以下链接查看:

  1. publiccms使用教程(使用方式整理)
  2. 使用publiccms实现动态可维护的首页轮播
  3. 使用publiccms实现动态可维护的导航菜单栏
  4. 使用publiccms实现将公共部分提取成单独页面片段

✍本文目录

@[toc]

👨‍🏫前言

整理publiccms的教程到现在为止,发现这里面的东西其实也没多少,每个页面的实现方法有多种,思路不一样,方式也就不一样。

难的其实是,用到了许多稀奇古怪的代码,每次都记不住,虽然官方提供了模板帮助,去上面查第一浪费时间,第二里面的帮助文档不一定很全面,有的可能找不到。

介于此,我今天就来整理一些常用的代码片段。

👩‍💻页面片段

  1. 遍历所有页面片段的内容(一般用于遍历轮播、导航菜单等公共动态维护的信息)
<#list page.list>
    <ul>
    <#items as a>
        <li>
            <figure>
                <!-- ${a.itemType!} : ${a.itemId!} ,place/redirect:count and 301 jump to a.url,place/click:count and 302 jump to a.url-->
                <a href="${site.dynamicPath}place/redirect?id=${a.id!}" target="_blank"><img src="${a.cover!}"></a>
                <figcaption><a href="${a.url!}" target="_blank">${a.title!}</a>(${a.clicks!})</figcaption>
                扩展字段:<#assign attribute=getPlaceAttribute(a.id)/>
            </figure>
        </li>
    </#items>
    </ul>
</#list>

注意:

  • 链接如果是动态则:${site.dynamicPath}place/redirect?id=${a.id!}
  • 封面:${a.cover!}
  • 点击次数:${a.clicks!}
  • 提交用户:a.userId
  • 审核用户: a.checkUserId
  • 创建日期:a.publishDate
  • 标题:a.title

扩展字段的获取方式:

比如我们这个页面片段中有一个扩展数据,编码为info,那么我们在代码中如何获取呢?

${getPlaceAttribute(a.id).info!?no_esc}

★★★?no_esc:主要是用于富文本编辑器的时候,可以直接解析html代码。

👩‍💻分类模板

  1. 分类的模板文件中接受id或者其他参数
<@_category id=id>
    <#assign category=object/>
<#-- 参数:分类ID -->
<#assign attribute=getCategoryAttribute(id)/>
</@_category>

注意:首先需要在元数据中,开启允许动态访问,其次开设置一个可接受参数id,不设置是接收不到的。

image-20210825072504586

  1. 在分类模板文件中获取类别相关的信息:

    • 类别名称:category.name
    • 类别父编号:category.parentId
    • 分类类型:category.typeId
    • 所有子分类的id:category.childIds
    • 类别编码:category.code
    • 模板路径:category.templatePath
    • 首页路径:category.Path
    • 首页地址:category.url
    • 内容路径:category.contentPath

    3.判断该类别的父分类是否为空的案例操作:

     <div class="index_section sec02">
            <div class="container">
                <div class="row zxl99">
                    <div class="col-lg-12 col-md-12 col-sm-12 col-xs-12" data-scroll-reveal="enter bottom move 20px over 1.5s after 0.05s">
                        <div class="zxlb2">
                              <#if category.parentId??>
                                                <ul>
    
                                                <@_categoryList parentId=category.parentId>
                                                <#list page.list as a>
                                            <#if a.id==category.id>
                                                    <li class="zxlb10">
                                                            <a href="${a.url!}">${a.name}</a>
                                                    </li>
                                                        <#else>
                                                        <li>
                                                            <a href="${a.url!}">${a.name}</a>
                                                    </li>
                                            </#if>
    
                                                </#list>
                                            </@_categoryList>
                                        </ul>
                            
                            <#else>
                                  <ul>
    
                                                <@_categoryList parentId=category.id>
                                                 <#assign counts_a=true>
                                                <#list page.list as a>
                                      
                                            <#if counts_a==true>
                                                    <li class="zxlb10">
                                                            <a href="${a.url!}">${a.name}</a>
                                                    </li>
                                                        <#else>
                                                        <li>
                                                            <a href="${a.url!}">${a.name}</a>
                                                    </li>
                                            </#if>
                                                <#assign counts_a=false>   
                                                </#list>
                                            </@_categoryList>
                                        </ul>
                            
                              </#if>
                                
                        </div>
                    </div>

    此案例的实现的功能:先判断父分类是否为空,如果不为空时,则根据父分类遍历其子分类的内容链接地址

👩‍💻分类扩展

如果某一分类无法满足你的需求时,可以利用分类扩展的方式来实现,操作如下:

点击内容--》分类扩展--》创建或者修改分类类型--》名称可以根据实际起即可--》在下面增加行(此处增加的字段,在创建该分类类型时就可以填了,然后在分类的模板文件中即可获取,一般用于在某些分类中,想要动态维护某个单独块的内容比较方便)

image-20210825075058648

获取分类扩展的字段:

${getCategoryAttribute(id).cate_img!}

★★★cate_img:表示分类的扩展中手动增加的编码。

动态维护某个单独块的内容比较方便)

[外链图片转存中...(img-VY6DnuQp-1629850256280)]

获取分类扩展的字段:

${getCategoryAttribute(id).cate_img!}

★★★cate_img:表示分类的扩展中手动增加的编码。

目录
相关文章
|
14天前
|
人工智能 自然语言处理 运维
当你发现同事的代码生成速度比你快,注释比你多,别慌,可能是因为……
当你发现同事的代码生成速度比你快,注释比你多,别慌,可能是因为……
|
5月前
|
数据可视化 IDE 程序员
14 款超赞的代码片段生成工具😍(程序员必备)
在本文中,我将介绍 14 款代码片段图片生成器,每款工具都具备独特功能,能够满足不同需求,帮助你将代码转化为精美、易于分享的视觉内容。
294 13
14 款超赞的代码片段生成工具😍(程序员必备)
|
9月前
|
XML JSON Java
Java开发常用代码总结和分享
Java开发常用代码总结和分享
43 0
|
10月前
【最全最详细】publiccms常用的代码片段
【最全最详细】publiccms常用的代码片段
|
10月前
【最全最详细】publiccms其他常用代码片段(内容、站点)
【最全最详细】publiccms其他常用代码片段(内容、站点)
|
算法 定位技术
连连看核心算法与基本思想(附全部项目代码链接与代码详细注释)
连连看核心算法与基本思想(附全部项目代码链接与代码详细注释)
511 0
|
开发框架 缓存 监控
测试是否有必要看开发代码?如何能看懂?
测试是否有必要看开发代码?如何能看懂?
|
开发工具 数据安全/隐私保护 iOS开发
JoanKing常用代码(下)
JoanKing常用代码(下)
504 0
JoanKing常用代码(下)
|
安全 JavaScript 程序员
写好代码需要举一反三
如何让代码写的更安全高效一直是程序员的不懈追求!在解决问题的同时,简介清爽,逻辑严谨的代码会让程序员更带光环。 简书亦有简码
229 0
写好代码需要举一反三
|
Unix Linux Windows
文件/代码 对比工具推荐
WinMerge 【for Windows】 https://winmerge.org/ WinMerge 开源用于Windows的差分和合并工具。WinMerge可以比较文件夹和文件,以便于理解和处理的可视文本格式呈现差异。 支持MicrosoftWindowsXPSP 3或更高版本 处理Windows、Unix和Mac文本文件格式 Unicode支持 选项卡接口
430 0
文件/代码 对比工具推荐