vue操作dom并为dom增加点击事件

本文实现的效果是利用js 在element图片放大后新增加一个下载的按钮 效果如下

实现效果

在这里插入图片描述

环境

项目中采用 vue + element 的方式
图片放大预览主要借助 element里面内部的一个未公开组件
有兴趣的小伙伴可以自行查看源码

分析过程

打开控制台后 发现这里实际 是在一个名字为el-image-viewer__actions__innerclass 下追加一个 i 元素的标签 ,icon 使用element自带的图标即可
在这里插入图片描述
分析可以得知,我们只需要在 class el-image-viewer__actions__inner 后追加元素即可

vue由于是虚拟dom 追加元素必须要等待 dom的渲染完成
也就是必须要在 mounted 钩子完成
但是这个时候 我们不能使用vue的 @click 来绑定事件
到 mounted 这个步骤的时候 vue 已经进行过模板的编译 添加@click 就无法识别
所以这里需要用到原生的方法来添加dom

代码实现
	// 需要在页面渲染完后
	this.$nextTick(() => {
		// 获取对应的 dom元素
      var otest = document.querySelector("div.el-image-viewer__actions__inner");
      // 创建一个新dom,并设置icon,绑定点击事件
      var newEle = document.createElement("i");
      newEle.className = "el-icon-download";
      newEle.onclick = () => {
        window.open(
          this.srcList[0] + "?response-content-type=application/octet-stream"
        );
      };
      // 在对应dom 下追加创建的dom
      otest.appendChild(newEle);
    });

到此为止 即可实现

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值