aardio - 【库】imgPager图形化的分页组件

33 篇文章 16 订阅

先看效果:

6564c308d200426e85667e6f6604e114.gif

70683720fe3c47d79f6efbb05ef70565.gif

08f37830ac5745809a5645148901be55.gif

9452c494cf8c4d7c8ba2cb9219c4768e.gif

81ed334cc1b742ae9d7be779af915979.png

7061267585034d24bb032aad98487a50.png

库特色: 

1、只需要指定plus、表格,数据,所有翻页操作都自动处理,非常简单。

2、支持 listview、vlistEx、egrid 等所有带 setTable() 函数的表格组件。

3、支持自定义图片(仅前景、背景两张即可),可以自己设计个性化皮肤。

4、支持自定义按钮事件( 默认显示函数、翻页函数 )。

5、支持无列表操作。

6、可隐藏组件,纯代码指令控制。

7、支持自定义按钮:

      (1)、本组件内置以下按钮和点击事件:

按钮名称按钮作用对应的点击事件函数名称
btnSelectAll列表框项目全选onSelectAll
btnSelectReverse列表框项目反选onSelectReverse
btnRefresh刷新列表框项目onRefresh
btnPageFirst到第一页onPageFirst
btnPagePrev到上一页onPagePrev
btnPageNext到下一页onPageNext
btnPageLast到最后一页onPageLast
btnGoto到指定页onGoto

        (2)、添加自定义按钮的方法:

        只需在皮肤配置文件 skin.cfg 中定义 btn 开头的按钮元素名称,定义好其位置(如:btnDclick={}),对应着代码中定义一个 on 开头的同名函数(如:p.onDclick=function(){})即可,当鼠标点击该按钮区域时,则自动执行指定的函数。

库下载: 

库文件下载:

http://chengxu.online → aardio资源下载 → imgPager.rar

解压缩后,将 imgPager 文件夹放到 aardio/lib/godking/ 目录即可。

调用代码:

import win.ui;
import godking.vlistEx;
import godking.imgPager
/*DSG{{*/
mainForm = win.form(text="vlistEx - table adapter";right=859;bottom=539;bgcolor=16777215;mode="popup")
mainForm.add(
plus={cls="plus";left=10;top=470;right=490;bottom=550;db=1;dl=1;notify=1;z=2};
vlist={cls="vlistEx";left=10;top=10;right=850;bottom=460;db=1;dl=1;dr=1;dt=1;edge=1;transparent=1;z=1}
)
/*}}*/

var t = { fields={"序号","姓名","年龄","地址","身份证"} }
for(i=1;100000;1){
    var tt={}
	tt["序号"]=i  // 行序号标记是不允许编辑修改的
	tt["姓名"]=math.random(1000,9999)+"姓名"
	tt["年龄"]=math.random(10,99)
	tt["地址"]=math.random(1000,9999)+"地址"
	tt["身份证"]=math.random(1000,9999)+"身份证"
	..table.push(t,tt)
}
 
mainForm.vlist.checkBox.show = true;
 
// 只需要两步即可设置完成:
// 第1步:绑定plus组件和皮肤文件:
// 方法1:不内嵌皮肤,使用默认皮肤目录:“~/lib/godking/imgPager/skin/blue/”目录:
var p = godking.imgPager(mainForm.plus,mainForm.vlist,"blue") ;
// 方法2:不内嵌皮肤,使用自定义皮肤目录:
var p = godking.imgPager(mainForm.plus,mainForm.vlist,"d:/imgPager/skin/blue") ;
// 方法3:内嵌皮肤,使用res资源文件:
var p = godking.imgPager(mainForm.plus,mainForm.vlist,"/res/blue") ;
// 方法4:内嵌皮肤,直接指定文件数据:
var p = godking.imgPager(mainForm.plus,mainForm.vlist,{
			cfg = $"~/lib/godking/imgPager/skin/blue/skin.cfg";
			forepic = $"~/lib/godking/imgPager/skin/blue/forepic.png";
			backpic = $"~/lib/godking/imgPager/skin/blue/backpic.png"},)
// 方法5:直接使用集成的各个皮肤库,已内部处理为嵌入皮肤:
import godking.imgPager.blue
var p = godking.imgPager.blue(mainForm.plus,mainForm.vlist) ;
			
// 第2步:进行初始化设置(数据表、每页记录数、自定义显示函数)
//此处初始化分页设置,不指定onShow函数,使用默认的setTable()函数自动设置标题,并填充第一页数据。
p.init(t,100,null); 

//指定onShow函数,用于后期的数据填充,可用来绕过setTable()函数,避免重设标题。如果不指定此函数,则每次填充都使用setTable()并重设标题。
p.onShow = function(startIndex,endIndex){
	/* 点击翻页按钮时执行本函数,用来手动刷新表格数据。参数1:开始记录索引;参数2:结束记录索引。
	   显示函数执行顺序(返回true则继续往下执行):翻页函数 > onShow()函数 > 表格setTable()函数 */
	var ct = ..table.slice(t,startIndex,endIndex);
	ct.fields = {"序号","姓名","年龄","地址","身份证"};
	mainForm.vlist.setTable(ct,false/*列标题*/,/*列宽*/,/*对齐方式*/,/*字典转为数组*/,/*字符串转为Utf8*/,/*是否克隆新表*/)
}
 
// 跟随dpi改变进行设置
mainForm.onDpiChanged = function(dpiX,dpiY,suggestedRect){
    p.dpiAdjust() 
}

// 全选
p.onSelectAll = function(){
	mainForm.vlist.setChecked(,true/*勾选状态*/)	
}

// 反选
p.onSelectReverse = function(){
	mainForm.vlist.setChecked(,-1/*勾选状态*/)	
}
 
// 翻页后调到第一行
p.afterShow = function(startIndex,endIndex){
	/*当前页数据显示完毕触发该事件。参数1:开始记录索引;参数2:结束记录索引*/
	mainForm.vlist.ensureVisible(1)	
}

mainForm.show();
win.loopMessage();

注意:

如果不内嵌皮肤,请在发布后,带上皮肤目录文件,并放置到正确的位置。

否则,会出现初始化后 p 为 null 的问题,因为找不到皮肤,所以初始化失败。

内嵌皮肤的方法:

1:皮肤文件放在res资源目录中:

086e03fc70384bf29ce73cfc71611887.png


        var p = godking.imgPager(mainForm.plus,mainForm.vlist,"\res\skin\ico") ;
2:直接包含皮肤文件:
        var p = godking.imgPager(mainForm.plus,mainForm.vlist,{
            cfg = $"~/lib/godking/imgPager/skin/blue/skin.cfg";
            forepic = $"~/lib/godking/imgPager/skin/blue/forepic.png";
            backpic = $"~/lib/godking/imgPager/skin/blue/backpic.png";

        },)
3:使用集成的各个皮肤库,这些库已内部处理为嵌入皮肤:
        import godking.imgPager.blue
        var p = godking.imgPager.blue(mainForm.plus,mainForm.vlist) ;

事件代码示例:

p.onPageNext = function(startIndex,endIndex){
	/* 翻页函数:到下一页。参数1:开始记录索引;参数2:结束记录索引。
	   显示函数执行顺序(返回true则继续往下执行):本函数 > onShow()函数 > 表格setTable()函数 */
	..win.msgbox("即将显示第"++p.curPage++"页");
	return true; 
}
  • 9
    点赞
  • 19
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 26
    评论
要使用 `el-table` 实现分页功能,可以按照以下步骤进行: 1. 在页面上引入 `el-pagination` 组件,或者使用 `el-table` 内置的分页组件。 2. 在 `el-table` 组件中添加 `:data` 属性,绑定数据源。 3. 在 `el-table` 组件中添加 `:page-size` 属性,设置每页显示的数据量。 4. 在 `el-table` 组件中添加 `:current-page` 属性,绑定当前页码。 5. 在 `el-table` 组件中添加 `@size-change` 和 `@current-change` 事件,分别处理分页大小和页码改变的逻辑。 6. 在 `el-table` 组件中添加 `slot="append"`,在表格下方添加分页组件。 下面是一个示例代码: ```html <template> <div> <el-table :data="tableData" :page-size="pageSize" :current-page.sync="currentPage" @size-change="handleSizeChange" @current-change="handleCurrentChange"> <el-table-column prop="name" label="姓名"></el-table-column> <el-table-column prop="age" label="年龄"></el-table-column> <el-table-column prop="address" label="地址"></el-table-column> <el-table-column prop="email" label="邮箱"></el-table-column> <el-table-column prop="phone" label="电话"></el-table-column> <el-table-column prop="company" label="公司"></el-table-column> <template slot="append"> <el-pagination :current-page.sync="currentPage" :page-size="pageSize" :total="total" @size-change="handleSizeChange" @current-change="handleCurrentChange" layout="total, sizes, prev, pager, next, jumper"></el-pagination> </template> </el-table> </div> </template> <script> export default { data() { return { tableData: [], // 数据源 currentPage: 1, // 当前页码 pageSize: 10, // 每页显示数据量 total: 0, // 总数据量 }; }, methods: { // 分页大小改变 handleSizeChange(val) { this.pageSize = val; this.getData(); }, // 页码改变 handleCurrentChange(val) { this.currentPage = val; this.getData(); }, // 获取数据 getData() { // 发送请求获取数据 // ... // 设置总数据量 this.total = 100; // 设置数据源 this.tableData = [{ name: "张三", age: 20, address: "北京市", email: "[email protected]", phone: "13812345678", company: "ABC公司" }, { name: "李四", age: 25, address: "上海市", email: "[email protected]", phone: "13912345678", company: "DEF公司" }, { name: "王五", age: 30, address: "广州市", email: "[email protected]", phone: "13712345678", company: "GHI公司" }]; }, }, mounted() { this.getData(); }, }; </script> ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 26
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

卢光庆

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值