首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

js 获取当前点击的按钮

在JavaScript中获取当前被点击的按钮,可以通过为按钮添加事件监听器,并在事件处理函数中使用this关键字或者event.target来引用触发事件的按钮元素。

以下是一个简单的示例代码,展示了如何获取当前点击的按钮:

代码语言:txt
复制
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>获取点击按钮示例</title>
<script>
// 当文档加载完成后执行函数
document.addEventListener('DOMContentLoaded', function() {
    // 获取页面上所有的按钮元素
    var buttons = document.querySelectorAll('button');
    
    // 遍历所有按钮并添加点击事件监听器
    buttons.forEach(function(button) {
        button.addEventListener('click', function(event) {
            // 方法一:使用 this 关键字
            var currentButton = this;
            console.log('当前点击的按钮(使用this):', currentButton);
            
            // 方法二:使用 event.target
            var clickedButton = event.target;
            console.log('当前点击的按钮(使用event.target):', clickedButton);
        });
    });
});
</script>
</head>
<body>

<button>按钮1</button>
<button>按钮2</button>
<button>按钮3</button>

</body>
</html>

在这个示例中,我们首先等待文档加载完成,然后选择页面上的所有<button>元素。对于每个按钮,我们添加了一个点击事件监听器。当按钮被点击时,事件处理函数会被触发。

在事件处理函数中,我们使用this关键字来引用当前正在处理事件的按钮元素。同时,我们也可以使用event.target来获取触发事件的实际元素,这在事件冒泡或捕获阶段可能会很有用。

这两种方法都可以用来获取当前点击的按钮,你可以根据实际情况选择使用哪一种。

如果你遇到了问题,比如无法获取到点击的按钮,可能的原因包括:

  1. 事件监听器没有正确添加到按钮上。
  2. JavaScript代码在DOM元素加载之前执行了,导致无法获取到元素。
  3. 选择器使用错误,没有正确选中想要添加监听器的按钮。

解决方法:

  1. 确保使用正确的选择器来选中按钮元素。
  2. 使用DOMContentLoaded事件或将其脚本放在文档底部,确保DOM元素加载完成后再绑定事件。
  3. 检查是否有JavaScript错误,这可能会阻止代码的执行。
  4. 使用浏览器的开发者工具来调试,查看是否有错误信息,以及thisevent.target的值是否正确。
页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

  • JS实现动态获取当前点击事件的id属性值

    原本要实现的功能如下: 点击下图播放按钮,要弹窗播放对应的视频链接。...整个页面是通过ajax请求最新的4部视频进行填充完成,视频列表又是通过template-web.js插件补上去的,所以导致所有ID值都是一样的,一开始给按钮添加一个事件,结果是所有播放按钮都是播放第一个视频...于是,想了好多办法,又把ID属性给弄成动态的ajax请求的属性值,实现了每个id不一样,接下来,因为点击播放要调用一个方法,进行解析视频播放,拼接成API+视频链接的格式在新打开的弹窗进行展示。...具体可以看下图: 要实现点击不同按钮,并且按钮ID是动态从ajax请求获取的,还要添加点击视频拼接视频链接,参考了文章,可以获取点击按钮的id值,然后使用button,将链接放在value中 Dom...对象的id属性可以获取元素的id值。

    25.9K20

    vue 点击事件获取当前元素

    在开发中我们可能会使用单击事件去获取当前元素,这样就需要进行传参: 关键词: $event  在括号中输入这个关键词,然后在方法中就可以使用以下的方法去获取你当前所需要使用的元素 //当前点击的元素...e.target //是你绑定事件的元素 e.currentTarget //获得点击元素的前一个元素 e.currentTarget.previousElementSibling.innerHTML...//获得点击元素的第一个子元素 e.currentTarget.firstElementChild //获得点击元素的下一个元素 e.currentTarget.nextElementSibling...//获得点击元素中id为string的元素 e.currentTarget.getElementById("string") //获得点击元素的string属性 e.currentTarget.getAttributeNode...('string') //获得点击元素的父级元素 e.currentTarget.parentElement //获得点击元素的前一个元素的第一个子元素的HTML值 e.currentTarget.previousElementSibling.firstElementChild.innerHTML

    1.8K10

    js点击按钮返回页面顶部

    2016-08-22 03:08:28 在进行官网一类的网站建设时,经常会出现页面太长的现象,当用户滚动滚动条到最底部时返回顶部需要滚动多下滚动条,用户体验相当不好,于是就出现了当滚动条滚动到一定位置后出现返回顶部按钮...,点击该按钮返回顶部,并且有一定的效果。...该方法就是利用锚点的方式来返回顶部。即给最顶部的div设置一个id,然后a标签的链接地址写成该id,当点击时就会返回顶部,但是缺点为过于突兀,因为是立即返回顶部。...值为fixed,始终固定为浏览器的某一特定位置。...,只不过给其添加了一个点击事件,此事件需要进入jquery.js文件,点击之后滚动条会有一个滚动过程,不是一下子回到顶部,个人感觉不错。

    25.1K10

    JS获取当前网址信息

    通过window.location对象获取对应的属性 1、设置或获取对象指定的文件名或路径(pathname) window.location.pathname 2、设置或获取整个 URL 为字符串(href...) window.kk 3、设置或获取与 URL 关联的端口号码(port) window.location.port 4、设置或获取 URL 的协议部分(protocol) window.location.protocol...设置或获取 href 属性中在井号“#”后面的分段(hash) window.location.hash 设置或获取 location 或 URL 的 hostname 和 port 号码(host)...(url.lastIndexOf('=')+1, url.length); 用来得到当前网页的域名 document.domain 注意: 1、获取过后直接使用substring方法截取我们需要的信息。...2、通过正则表达式准确的获取我们需要的参数。

    13.8K30

    js如何获取计算机当前时间,js获取当前系统时间实例代码

    x(0-6,0代表星期天) mydate.gettime(); //获取当前时间(从1970.1.1开始的毫秒数) mydate.gethours(); //获取当前小时数(0-23) mydate.getminutes...mydate.tolocalestring( ); //获取日期与时间 例1,js获取当前时间 js中日期操作: 复制代码 代码示例: var mydate = new date(); mydate.getyear...(); //获取当前年份(2位) mydate.getfullyear(); //获取完整的年份(4位,1970-????)...6,0代表星期天) mydate.gettime(); //获取当前时间(从1970.1.1开始的毫秒数) mydate.gethours(); //获取当前小时数(0-23) mydate.getminutes...获取想要的时间: 复制代码 代码示例: /*获取当前时间及当前时间加n分钟后的时间*/ function curenttime(addtime) { var now = new date(); var

    17.1K40

    前端如何获取当前时间_js 获取年份

    前端js获取当前时间的方法: var time = new Date(); time.getYear(); //获取当前年份 time.getFullYear(); //获取完整的年份(4位,1970...time.getMonth(); //获取当前月份(0-11,0代表1月) time.getDate(); //获取当前日(1-31) time.getDay(); //获取当前星期X(0-6,0代表星期天...) time.getTime(); //获取当前时间(从1970.1.1开始的毫秒数) time.getHours(); //获取当前小时数(0-23) time.getMinutes(); //...获取当前分钟数(0-59) time.getSeconds(); //获取当前秒数(0-59) time.getMilliseconds(); //获取当前毫秒数(0-999) time.toLocaleDateString...(); //获取当前日期 var mytime=time.toLocaleTimeString(); //获取当前时间 time.toLocaleString( ); //获取日期与时间 为了让大家有一个更感官的了解

    34.1K20

    对抗蠕虫 —— 如何让按钮不被 JS 自动点击

    在社交网络里,很多操作都是通过点击按钮发起的,例如发表留言。...除非,用户在点击按钮时会产生一个「特殊数据」,让后端校验它。 但是,XSS 也可以直接调用按钮元素的 click 方法,这样效果和用户点击仍然一样。后端仍无法识别是「脚本点的」还是「用户点的」。...演示 Demo: http://www.etherdream.com/FunnyScript/anti-xssworm/ 注意:这个案例不是看能不能注入 XSS,而是看能不能通过当前页面的 JS 自动发留言...另外,通过第三方服务器发表是不算的。这里为简单,省略了登录态;真实场合下,会话 Cookie 是 HttpOnly 的,无法被 JS 获取到,也就无法让第三方服务器代替发表。...细节: 使用者加载 safebutton.js,引入 SafeButton 类 使用者实例化 SafeButton 对象 A,创建出一个不同源的 iframe 作为按钮界面 用户点击 iframe 按钮后

    9.2K60

    js获取鼠标当前位置坐标

    2017-03-01 10:08:42 在页面中获取鼠标坐标通常有三种方式,这三种方式各有不同,所的的值也是不一样的。  首先是相对于页面的pageX和pageY。...他值的是鼠标在页面上可视区域的位置,从浏览器可视区域左上角开始,即是以浏览器滑动条此刻的滑动到的位置为参考点,随滑动条移动 而变化。 相对于屏幕来说的screenX/screenY。...这是一个IE特有的属性,鼠标相比较于触发事件的元素的位置,以元素盒子模型的内容区域的左上角为参考点,如果有boder,可能出现负值 相对于坐标系的layerX/layerY。...FF特有,鼠标相比较于当前坐标系的位置,即如果触发元素没有设置绝对定位或相对定位,以页面为参考点,如果有,将改变参考坐标系,从触发元素盒子模型的border区域的左上角为参考点也就是当触发元素设置了相对或者绝对定位后...完全支持所有属性.其中(offsetX和layerX都是以border为参考点) 下面这个是获取相对于屏幕的坐标 document.onmousemove = function(e) { e =

    14.8K20

    JS实现一键点击按钮复制文本

    背景描述现在有这样一个需求,想要在页面实现点击按钮,一键复制指定列表字段内容的操作,就像这样的效果复制成功之后的内容在Notepad++ 粘贴可以看到正式列表中链接地址字段的内容,那么如何实现一键点击按钮复制指定列字段内容的操作呢...JS代码实现首先来看页面按钮点击事件对应的方法在点击 复制链接 按钮时需要传入您想要复制的字段内容,这里通过 row.url 取值 copylink() 方法内容如下function copylink(...(text) { // 创建一个隐藏的textarea元素 var textarea = document.createElement("textarea"); // 保存当前焦点元素...元素,然后再将传入的文本设置为textarea的值,最后执行复制命令就可以了。...大家有需要的可以放心拿去用,这里我已经验证过是好用的。总结总的来说这个基于 JavaScript 实现页面点击按钮一键复制文本的操作还是比较简单的,但是可能功能不太常用,容易遗忘。

    27220
    领券