首頁  >  文章  >  web前端  >  extjs表格文字啟用選擇複製功能具體實作_extjs

extjs表格文字啟用選擇複製功能具體實作_extjs

WBOY
WBOY原創
2016-05-16 17:20:121382瀏覽

extjs提供了方便的表格元件grid供使用,但是預設表格中的文字是不能被選取的,自然也是無法複製的。

而選擇複製文本的需要也是很平常的,於是我們就需要自己動手來解決這個問題,實現extjs的grid文本選擇複製功能。

說明一點,文中所列出的程式碼片段都是在目前ext 4.0.2a版本下的,其它版本未做測試,請自行斟酌。

先自訂樣式,來覆寫預設的css樣式:

複製程式碼



複製程式碼


程式碼>
複寫extjs的table類,阻止滑鼠選擇文字的就是這個unselectable


複製程式碼


程式碼如下:


/**
* 覆蓋表類
*/
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樣式


複製程式碼


程式碼如下:


* *
* 定義選擇特徵
*/
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 tpl = metaRowTpl[i]; = 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;
};
}
});


複製程式碼


程式碼如下:


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 }
陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn