extjs表格文本启用选择复制功能具体实现


Posted in Javascript onOctober 11, 2013

extjs提供了方便的表格组件grid供使用,但是默认情况下表格中的文本是不能被选中的,自然也是无法复制的。

而选择复制文本的需要也是很平常的,于是我们就需要自己动手来解决这个问题,实现extjs的grid文本选择复制功能。

说明一点,文中所列出的代码片断都是在当前ext 4.0.2a版本下的,其它版本未做测试,请自行斟酌。

首先自定义一下样式,来覆盖默认的css样式:

<style type="text/css"> 
.x-selectable, .x-selectable * { 
-moz-user-select: text!important; 
-khtml-user-select: text!important; 
} 
</style>

复写extjs的table类,阻止鼠标选择文本的就是这个unselectable
/** 
* override the table class 
*/ 
Ext.override(Ext.view.Table, { 
afterRender : function() { 
var me = 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样式
/** 
* define the select feature 
*/ 
Ext.define('Myext.grid.SelectFeature', { 
extend : 'Ext.grid.feature.Feature', 
alias : 'feature.selectable', 
mutateMetaRowTpl : function(metaRowTpl) { 
var i, ln = metaRowTpl.length; 
for (i = 0; i < ln; i++) { 
tpl = metaRowTpl[i]; 
tpl = tpl.replace(/x-grid-row/, 'x-grid-row x-selectable'); 
tpl = tpl.replace(/x-grid-cell-inner x-unselectable/g, 'x-grid-cell-inner'); 
tpl = tpl.replace(/unselectable="on"/g, ''); 
metaRowTpl[i] = tpl; 
}; 
} 
});

现在可以声明一个selectFeature了

var selectFeature = Ext.create('Myext.grid.SelectFeature');

需要启用文本选择的表格,在创建时添加这个feature就可以了

Ext.create('Ext.grid.Panel', { 
title : 'grid example', 
store : gridStore, // define before 
width : 600, 
height : 300, 
features : [selectFeature], 
columns : [{ 
text:'name', 
dataIndex:'name' 
}] 
// other code 
}
Javascript 相关文章推荐
JS.elementGetStyle(element, style)应用示例
Sep 24 Javascript
JavaScript原型链示例分享
Jan 26 Javascript
使用jquery写个更改表格行顺序的小功能
Apr 29 Javascript
下拉框select的绑定示例
Sep 04 Javascript
全面解析Bootstrap弹窗的实现方法
Dec 01 Javascript
新手学习前端之js模仿淘宝主页网站
Oct 31 Javascript
react-router实现按需加载
May 09 Javascript
基于Bootstrap分页的实例讲解(必看篇)
Jul 04 Javascript
使用JS实现气泡跟随鼠标移动的动画效果
Sep 16 Javascript
js与jQuery实现的用户注册协议倒计时功能实例【三种方法】
Nov 09 jQuery
详解KOA2如何手写中间件(装饰器模式)
Oct 11 Javascript
JavaScript实现像雪花一样的Hexaflake分形
Jul 07 Javascript
JS验证身份证有效性示例
Oct 11 #Javascript
JS分页效果示例
Oct 11 #Javascript
appendChild() 或 insertBefore()使用与区别介绍
Oct 11 #Javascript
JQuery对class属性的操作实现按钮开关效果
Oct 11 #Javascript
鼠标划过实现延迟加载并隐藏层的js代码
Oct 11 #Javascript
javascript自然分类法算法实现代码
Oct 11 #Javascript
jQuery阻止事件冒泡具体实现
Oct 11 #Javascript
You might like
第1次亲密接触PHP5(2)
2006/10/09 PHP
php&amp;java(一)
2006/10/09 PHP
PHP 实例化类的一点摘记
2008/03/23 PHP
php cookis创建实现代码
2009/03/16 PHP
php pcntl_fork和pcntl_fork 的用法
2009/04/13 PHP
深入理解PHP原理之错误抑制与内嵌HTML分析
2011/05/02 PHP
PHP5权威编程阅读学习笔记 附电子书下载
2012/07/05 PHP
使用HMAC-SHA1签名方法详解
2013/06/26 PHP
在WordPress中安装使用视频播放器插件Hana Flv Player
2016/01/04 PHP
PHP实现限制域名访问的实现代码(本地验证)
2020/09/13 PHP
node.js中的url.parse方法使用说明
2014/12/10 Javascript
nodejs实现bigpipe异步加载页面方案
2016/01/26 NodeJs
一些实用性较高的js方法
2016/04/19 Javascript
JS实现的几个常用算法
2016/11/12 Javascript
利用canvas中toDataURL()将图片转为dataURL(base64)的方法详解
2017/11/20 Javascript
详解vue2.0+vue-video-player实现hls播放全过程
2018/03/02 Javascript
nodejs实现超简单生成二维码的方法
2018/03/17 NodeJs
layui点击按钮添加可编辑的一行方法
2018/08/15 Javascript
vue-auto-focus: 控制自动聚焦行为的 vue 指令方法
2018/08/25 Javascript
vue element-ui之怎么封装一个自己的组件的详解
2019/05/20 Javascript
原生js实现二级联动菜单
2019/11/27 Javascript
Python浅复制中对象生存周期实例分析
2018/04/02 Python
Python获取网段内ping通IP的方法
2019/01/31 Python
Python使用matplotlib绘制Logistic曲线操作示例
2019/11/28 Python
Python数据存储之 h5py详解
2019/12/26 Python
python批量合成bilibili的m4s缓存文件为MP4格式 ver2.5
2020/12/01 Python
植物选择:Botanic Choice
2017/02/15 全球购物
编写类String 的构造函数、析构函数和赋值函数
2012/09/09 面试题
天网面试题
2013/04/07 面试题
客房主管岗位职责
2013/12/09 职场文书
门卫人员岗位职责
2013/12/24 职场文书
门面房租房协议书
2014/08/20 职场文书
讲文明懂礼貌演讲稿
2014/09/11 职场文书
学习计划书怎么写
2014/09/15 职场文书
2015年事业单位工作总结
2015/04/27 职场文书
民事起诉书范本
2015/05/19 职场文书