Vue获取element table 单元格的内容([object HTMLTableCellElement] JQ转换)并实现一键复制功能(记录1)(input,span等文本内容复制)

vue中通过点击表格单元格获取单元格内容,取出innerHTML,并在dom中显示

1.了解document.execCommand()=====

execCommand方法是执行一个对当前文档/当前选择/给出范围的命令。大佬整理的直接拿来用!香

2D-Position 允许通过拖曳移动绝对定位的对象。
AbsolutePosition 设定元素的 position 属性为“absolute”(绝对)。
BackColor 设置或获取当前选中区的背景颜色。
BlockDirLTR 目前尚未支持。
BlockDirRTL 目前尚未支持。
Bold 切换当前选中区的粗体显示与否。
BrowseMode 目前尚未支持。
Copy 将当前选中区复制到剪贴板。
CreateBookmark 创建一个书签锚或获取当前选中区或插入点的书签锚的名称。
CreateLink 在当前选中区上插入超级链接,或显示一个对话框允许用户指定要为当前选中区插入的超级链接的 URL。
Cut 将当前选中区复制到剪贴板并删除之。
Delete 删除当前选中区。
DirLTR 目前尚未支持。
DirRTL 目前尚未支持。
EditMode 目前尚未支持。
FontName 设置或获取当前选中区的字体。
FontSize 设置或获取当前选中区的字体大小。
ForeColor 设置或获取当前选中区的前景(文本)颜色。
FormatBlock 设置当前块格式化标签。
Indent 增加选中文本的缩进。
InlineDirLTR 目前尚未支持。
InlineDirRTL 目前尚未支持。
InsertButton 用按钮控件覆盖当前选中区。
InsertFieldset 用方框覆盖当前选中区。
InsertHorizontalRule 用水平线覆盖当前选中区。
InsertIFrame 用内嵌框架覆盖当前选中区。
InsertImage 用图像覆盖当前选中区。
InsertInputButton 用按钮控件覆盖当前选中区。
InsertInputCheckbox 用复选框控件覆盖当前选中区。
InsertInputFileUpload 用文件上载控件覆盖当前选中区。
InsertInputHidden 插入隐藏控件覆盖当前选中区。
InsertInputImage 用图像控件覆盖当前选中区。
InsertInputPassword 用密码控件覆盖当前选中区。
InsertInputRadio 用单选钮控件覆盖当前选中区。
InsertInputReset 用重置控件覆盖当前选中区。
InsertInputSubmit 用提交控件覆盖当前选中区。
InsertInputText 用文本控件覆盖当前选中区。
InsertMarquee 用空字幕覆盖当前选中区。
InsertOrderedList 切换当前选中区是编号列表还是常规格式化块。
InsertParagraph 用换行覆盖当前选中区。
InsertSelectDropdown 用下拉框控件覆盖当前选中区。
InsertSelectListbox 用列表框控件覆盖当前选中区。
InsertTextArea 用多行文本输入控件覆盖当前选中区。
InsertUnorderedList 切换当前选中区是项目符号列表还是常规格式化块。
Italic 切换当前选中区斜体显示与否。
JustifyCenter 将当前选中区在所在格式化块置中。
JustifyFull 目前尚未支持。
JustifyLeft 将当前选中区所在格式化块左对齐。
JustifyNone 目前尚未支持。
JustifyRight 将当前选中区所在格式化块右对齐。
LiveResize 迫使 MSHTML 编辑器在缩放或移动过程中持续更新元素外观,而不是只在移动或缩放完成后更新。
MultipleSelection 允许当用户按住 Shift 或 Ctrl 键时一次选中多于一个站点可选元素。
Open 打开。
Outdent 减少选中区所在格式化块的缩进。
OverWrite 切换文本状态的插入和覆盖。
Paste 用剪贴板内容覆盖当前选中区。
PlayImage 目前尚未支持。
Print 打开打印对话框以便用户可以打印当前页。
Redo 重做。
Refresh 刷新当前文档。
RemoveFormat 从当前选中区中删除格式化标签。
RemoveParaFormat 目前尚未支持。
SaveAs 将当前 Web 页面保存为文件。
SelectAll 选中整个文档。
SizeToControl 目前尚未支持。
SizeToControlHeight 目前尚未支持。
SizeToControlWidth 目前尚未支持。
Stop 停止。
StopImage 目前尚未支持。
StrikeThrough 目前尚未支持。
Subscript 目前尚未支持。
Superscript 目前尚未支持。
UnBookmark 从当前选中区中删除全部书签。
Underline 切换当前选中区的下划线显示与否。
Undo 撤消。
Unlink 从当前选中区中删除全部超级链接。
Unselect 清除当前选中区的选中状态。

2.[object HTMLTableCellElement] 是什么???=========

[object HTMLTableCellElement] 这个对象就相当于getDocumentElementById(“”)获取到的内容,可以直接使用JQ进行dom与jq对象之间的转换,然后就是正常的操作步骤去操作

完整代码

table注册单元格点击事件

@cell-click="clickMessage"//在table组件中

clickMessage方法

clickMessage(row, column, cell) {
    if (column.property == 'messageContent') {//根据prop判断点击一行的哪一个单元格
        let content = $(cell); //[object HTMLTableCellElement] 转jq对象    ==== cell =>dom对象
        this.compoment = content.children()[0].innerHTML; //获取到单元格的文本内容
    }
},

template代码,加入展示获取的文本dom以及复制按钮

<el-input type="textarea" v-model="compoment" :rows="8" id="copytext"> </el-input>
<el-button type="success" @click="copyMessage"> 复 制 </el-button>

copyMessage方法

copyMessage() {
    let dom = document.getElementById('copytext');//获取要复制的文本dom 
    dom.select();//选中
    document.execCommand('Copy');//处理Html数据 copy
    this.$notify({
        message: '复制成功'
    });
},
这里就实现了点击表格单元格获取单元格内容,取出innerHTML,并在dom中显示的功能。主要问题,在获取到[object HTMLTableCellElement]时有点蒙蔽,网上找到一些相关资料,可以把它理解为相当于getDocumentElementById(“”)获取到的内容。然后就简单了

更新

上面是必须要文本内容,及html标签为input,再添加一个其他html标签的复制内容方法,如span
<span id="copytext"> {{ compoment }} </span>
copy() {
    let dom = document.getElementById('copytext');
    let g = window.getSelection();
    let d = document.createRange();
    d.selectNodeContents(dom);
    g.removeAllRanges();
    g.addRange(d);
    document.execCommand('Copy');
    this.$notify({
        message: '复制成功'
    });
},

基本上处理一直,只是在选中dom时有所不同,看大佬这样用的~~~

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值