extjs表格文本启用选择复制功能具体实现
实现 功能 选择 复制 文本 表格 具体 启用
2023-06-13 09:15:06 时间
extjs提供了方便的表格组件grid供使用,但是默认情况下表格中的文本是不能被选中的,自然也是无法复制的。
而选择复制文本的需要也是很平常的,于是我们就需要自己动手来解决这个问题,实现extjs的grid文本选择复制功能。
说明一点,文中所列出的代码片断都是在当前ext4.0.2a版本下的,其它版本未做测试,请自行斟酌。
首先自定义一下样式,来覆盖默认的css样式:
复制代码代码如下:
而选择复制文本的需要也是很平常的,于是我们就需要自己动手来解决这个问题,实现extjs的grid文本选择复制功能。
说明一点,文中所列出的代码片断都是在当前ext4.0.2a版本下的,其它版本未做测试,请自行斟酌。
首先自定义一下样式,来覆盖默认的css样式:
<styletype="text/css">
.x-selectable,.x-selectable*{
-moz-user-select:text!important;
-khtml-user-select:text!important;
}
</style>
复写extjs的table类,阻止鼠标选择文本的就是这个unselectable
/**
*overridethetableclass
*/
Ext.override(Ext.view.Table,{
afterRender:function(){
varme=this;
me.callParent();
me.mon(me.el,{
scroll:me.fireBodyScroll,
scope:me
});
if(!me.featuresMC&&(me.featuresMC.findIndex("ftype","unselectable")>=0)){
me.el.unselectable();
}
me.attachEventsForFeatures();
}
});
然后再自定义一个feature,启用文本选择功能,通过替换取消unselectable样式,同时增加x-selectable样式
/**
*definetheselectfeature
*/
Ext.define("Myext.grid.SelectFeature",{
extend:"Ext.grid.feature.Feature",
alias:"feature.selectable",
mutateMetaRowTpl:function(metaRowTpl){
vari,ln=metaRowTpl.length;
for(i=0;i<ln;i++){
tpl=metaRowTpl[i];
tpl=tpl.replace(/x-grid-row/,"x-grid-rowx-selectable");
tpl=tpl.replace(/x-grid-cell-innerx-unselectable/g,"x-grid-cell-inner");
tpl=tpl.replace(/unselectable="on"/g,"");
metaRowTpl[i]=tpl;
};
}
});
现在可以声明一个selectFeature了
varselectFeature=Ext.create("Myext.grid.SelectFeature");
需要启用文本选择的表格,在创建时添加这个feature就可以了
Ext.create("Ext.grid.Panel",{
title:"gridexample",
store:gridStore,//definebefore
width:600,
height:300,
features:[selectFeature],
columns:[{
text:"name",
dataIndex:"name"
}]
//othercode
}
相关文章
- 全栈开发之基于云开发实现微信聊天功能
- 【说站】python集合的底层实现
- javascript实现倒计时功能
- WPF使用AvalonEdit实现代码高亮显示、搜索、替换功能
- Spring boot+redis实现消息发布与订阅的代码
- 使用JAVA实现签名验证示例程序详解架构师
- xhEditor实现插入代码功能详解编程语言
- Jquery+Eayui实现列表选择功能详解编程语言
- editormd实现Markdown编辑器写文章功能详解编程语言
- Linux实现路由功能:一种新的选择(linux做路由器)
- Linux动态加载内核模块实现多样功能(linux可加载内核模块)
- 快速安装Linux: 用ISO镜像实现系统灵活部署(linux安装iso系统)
- 操作Linux分支操作:实现更多的功能(linux的分支)
- Redis Java实现自动过期功能(redisjava过期)
- 操作Linux分支操作:实现强大功能(linux的分支)
- 基于golang+lua虚拟机的日志分析系统实现
- Linux下如何使用C语言实现文件复制功能(linuxc复制文件)
- Linux实现加减法运算(linux加减法)
- 高效实现MySQL排名功能,快速查询数据,提升性能(mysql中做排名)
- 实现数据快速迁移向Redis导入数据(向redis导数据)
- 的联合Oracle中联合两个文件的实现(oracle两个文件)
- Oracle数据库实现三级部门显示结构(oracle三级部门显示)
- java使用淘宝API读写json实现手机归属地查询功能代码
- jquery插件开发之实现google+圈子选择功能
- C++实现寻找最低公共父节点的方法