当前位置: 首页 > news >正文

gf框架之分页模块(五) - 自定义分页

文章来源:http://gf.johng.cn/597435

由于分页对象预定义的样式比较有限,有的时候我们想自定义分页的样式(标签输出),由于分页对象的的所有方法都是公开的,这便为开发者自定义分页样式提供了非常高的灵活度。开发者可以通过以下方式实现自定义分页内容:

  1. (推荐)对输出内容进行正则匹配替换实现自定义;
  2. 根据分页对象公开的方法自行组织分页内容实现自定义;
  3. 也可以自定义一个分页对象(继承于原有分页对象),使用方法重载的方式来实现自定义;

示例1,使用第一种方式实现分页自定义:

package main

import (
    "gitee.com/johng/gf/g"
    "gitee.com/johng/gf/g/os/gview"
    "gitee.com/johng/gf/g/util/gstr"
    "gitee.com/johng/gf/g/net/ghttp"
    "gitee.com/johng/gf/g/util/gpage"
)

// 分页标签使用li标签包裹
func wrapContent(page *gpage.Page) string {
    content := page.GetContent(4)
    content  = gstr.ReplaceByMap(content, map[string]string {
        "<span"  : "<li><span",
        "/span>" : "/span></li>",
        "<a"     : "<li><a",
        "/a>"    : "/a></li>",
    })
    return "<ul>" + content + "</ul>"
}

func main() {
    s := ghttp.GetServer()
    s.BindHandler("/page/custom2/*page", func(r *ghttp.Request){
        page      := gpage.New(100, 10, r.Get("page"), r.URL.String(), r.Router.Uri)
        content   := wrapContent(page)
        buffer, _ := gview.ParseContent(`
        <html>
            <head>
                <style>
                    a,span {padding:8px; font-size:16px;}
                    div{margin:5px 5px 20px 5px}
                </style>
            </head>
            <body>
                <div>{{.page}}</div>
            </body>
        </html>
        `, g.Map{
            "page" : gview.HTML(content),
        })
        r.Response.Write(buffer)
    })
    s.SetPort(10000)
    s.Run()
}

执行后,页面输出结果为:
91ab58599ed9f155043305724480bfb4_378x358.png

示例2,使用第二种方式实现分页自定义:

package main

import (
    "gitee.com/johng/gf/g/os/gview"
    "gitee.com/johng/gf/g/net/ghttp"
    "gitee.com/johng/gf/g/util/gpage"
)

// 自定义分页名称
func pageContent(page *gpage.Page) string {
    page.NextPageTag  = "NextPage"
    page.PrevPageTag  = "PrevPage"
    page.FirstPageTag = "HomePage"
    page.LastPageTag  = "LastPage"
    pageStr := page.FirstPage()
    pageStr += page.PrevPage()
    pageStr += page.PageBar("current-page")
    pageStr += page.NextPage()
    pageStr += page.LastPage()
    return pageStr
}

func main() {
    s := ghttp.GetServer()
    s.BindHandler("/page/custom/*page", func(r *ghttp.Request) {
        page      := gpage.New(100, 10, r.Get("page"), r.URL.String(), r.Router.Uri)
        buffer, _ := gview.ParseContent(`
        <html>
            <head>
                <style>
                    a,span {padding:8px; font-size:16px;}
                    div{margin:5px 5px 20px 5px}
                </style>
            </head>
            <body>
                <div>{{.page}}</div>
            </body>
        </html>
        `, g.Map{
            "page" : gview.HTML(pageContent(page)),
        })
        r.Response.Write(buffer)
    })
    s.SetPort(8199)
    s.Run()
}

执行后,页面输出结果为:
036961cfbe86a2c17d7f783b33829f98_581x112.png

相关文章:

  • SQL Server 2005 日常运维检查操作手册
  • FPGA设计中遇到的奇葩问题之“芯片也要看出身”(一)
  • UI自动化测试篇 :webdriver+ant+jenkins自动化测试实践
  • 再谈DOMContentLoaded与渲染阻塞—分析html页面事件与资源加载
  • mysql alter 曾删改查
  • jsonp
  • find_first_zore_bit-一个位图的实现
  • 素材锦囊——50个高质量的 PSD 素材免费下载《上篇》
  • Spark2.1.1spark写入Hbase的三种方法性能对比
  • javascript框架概览备忘
  • mybatis 逆向工程配置文件
  • O2O?啥是“呕吐呕”?
  • 快速搞定常用的ES6新特性
  • Excel 将换行符替换为空
  • android PhoneGap源码详解
  • 【RocksDB】TransactionDB源码分析
  • ES6--对象的扩展
  • Idea+maven+scala构建包并在spark on yarn 运行
  • IP路由与转发
  • JS数组方法汇总
  • learning koa2.x
  • LeetCode算法系列_0891_子序列宽度之和
  • Linux gpio口使用方法
  • springMvc学习笔记(2)
  • Vultr 教程目录
  • windows下如何用phpstorm同步测试服务器
  • 关于for循环的简单归纳
  • 记录:CentOS7.2配置LNMP环境记录
  • 技术:超级实用的电脑小技巧
  • 开发基于以太坊智能合约的DApp
  • 批量截取pdf文件
  • 深度学习入门:10门免费线上课程推荐
  • 使用common-codec进行md5加密
  • 学习Vue.js的五个小例子
  • 大数据全解:定义、价值及挑战
  • # C++之functional库用法整理
  • (3)(3.2) MAVLink2数据包签名(安全)
  • (ISPRS,2023)深度语义-视觉对齐用于zero-shot遥感图像场景分类
  • (js)循环条件满足时终止循环
  • (pytorch进阶之路)CLIP模型 实现图像多模态检索任务
  • (ZT)北大教授朱青生给学生的一封信:大学,更是一个科学的保证
  • (剑指Offer)面试题34:丑数
  • (十)T检验-第一部分
  • (一)Thymeleaf用法——Thymeleaf简介
  • . ./ bash dash source 这五种执行shell脚本方式 区别
  • ./configure,make,make install的作用
  • .NET 8.0 发布到 IIS
  • .NET Entity FrameWork 总结 ,在项目中用处个人感觉不大。适合初级用用,不涉及到与数据库通信。
  • .NET 的静态构造函数是否线程安全?答案是肯定的!
  • .Net 知识杂记
  • .net6+aspose.words导出word并转pdf
  • .NET框架设计—常被忽视的C#设计技巧
  • .NET面试题(二)
  • .pyc文件是什么?
  • /var/spool/postfix/maildrop 下有大量文件