源码网商城,靠谱的源码在线交易网站 我的订单 购物车 帮助

源码网商城

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

  • 时间:2022-02-02 22:47 编辑: 来源: 阅读:
  • 扫一扫,手机访问
摘要:extjs表格文本启用选择复制功能具体实现
extjs提供了方便的表格组件grid供使用,但是默认情况下表格中的文本是不能被选中的,自然也是无法复制的。 而选择复制文本的需要也是很平常的,于是我们就需要自己动手来解决这个问题,实现extjs的grid文本选择复制功能。 说明一点,文中所列出的代码片断都是在当前ext 4.0.2a版本下的,其它版本未做测试,请自行斟酌。 首先自定义一下样式,来覆盖默认的css样式:
[u]复制代码[/u] 代码如下:
<style type="text/css"> .x-selectable, .x-selectable * { -moz-user-select: text!important; -khtml-user-select: text!important; } </style>
复写extjs的table类,阻止鼠标选择文本的就是这个unselectable
[u]复制代码[/u] 代码如下:
/** * 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样式
[u]复制代码[/u] 代码如下:
/** * 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就可以了
[u]复制代码[/u] 代码如下:
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 }
  • 全部评论(0)
联系客服
客服电话:
400-000-3129
微信版

扫一扫进微信版
返回顶部