【最全最详细】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:表示分类的扩展中手动增加的编码。

目录
相关文章
文本,Vitepress的优势之处,配合Typora进行页面撰写可以同步设计相同的HTML页面
文本,Vitepress的优势之处,配合Typora进行页面撰写可以同步设计相同的HTML页面
|
9月前
【最全最详细】publiccms常用的代码片段
【最全最详细】publiccms常用的代码片段
|
9月前
【最全最详细】publiccms其他常用代码片段(内容、站点)
【最全最详细】publiccms其他常用代码片段(内容、站点)
|
9月前
|
C++
codeAction提供代码错误解决方案重要笔记
codeAction提供代码错误解决方案重要笔记
189 0
|
9月前
|
弹性计算 人工智能 API
不写代码,5分钟部署chatGPT网站
用阿里云ROS,不会写代码的小白也能分分钟部署一个chatGPT网站,无需开各种代理,快来和chatGPT对话吧!
450 0
不写代码,5分钟部署chatGPT网站
|
前端开发
前端知识学习案例19vs code-显示代码提示
前端知识学习案例19vs code-显示代码提示
94 0
前端知识学习案例19vs code-显示代码提示
|
Java 应用服务中间件
jsp代码没有错,但是总是有红叉(一招解决)
不知道原因jsp一直红 很多人都说把它剪切啦,再粘贴啦,但他还会出现红叉或者自己写jsp的时候没写错也会出现出现红叉 怎么办呢 ??? 怎么办呢??? 如图: 我的项目没错也能运行没错就是没错他就是报红叉 安排解决!!! 如果遇到上述问题来到这里算是找对地方了!!!
jsp代码没有错,但是总是有红叉(一招解决)
|
数据库
代码写的垃圾被嫌弃?这 3 个插件你值得拥有…
今天推荐三个插件,它们都是代码质量检测的神器。可以扫描检测出你项目中不符合规范的代码,他们分别是 SonarLint、SonarQube、Alibaba代码规约插件。
246 0
代码写的垃圾被嫌弃?这 3 个插件你值得拥有…