繁体   English   中英

Javascript .onclick 不调用函数

[英]Javascript .onclick not calling function

当我单击页面上的按钮时,我希望它在控制台中显示电子邮件对象,但它没有这样做。

document.addEventListener('DOMContentLoaded', function() {
document.querySelector('#email-btn').onclick = email_select;
});
function email_select(id){
  fetch(`/emails/${id}`)
  .then(response => response.json())
  .then(email => {
    console.log(email);
  });
}

例如,当我运行时,控制台中的此代码:

email_select(3);

它向我显示电子邮件对象,以便告诉我该功能正常工作,但是当我单击浏览器中的按钮时,它没有在控制台中向我显示电子邮件对象。 我尝试将其从 .onclick 更改为:

  document.querySelector('#email-btn').addEventListener('click', email_select);

这也不起作用。 知道我可能做错了什么吗?

编辑:我确实动态添加了 #email-btn,所以它不在原始 HTML 中,我实际上想知道这是否是真正的问题。 下面是我如何动态添加#email-btn:

function load_mailbox(mailbox){

  // Show emails in mailbox
  fetch(`/emails/${mailbox}`)
  .then(response => response.json())
  .then(emails => {
    let output = '<div class="list-group">';
    emails.forEach(function(email){
      if(mailbox === "inbox"){
        if(email.body.length > 15){
          email.body = email.body.substring(0,15) + "...";
        } else {
          email.body = email.body
        }
        output += `
        <button type="button" id="email-btn" class="list-group-item list-group-item-action">
          <strong>${email.sender}</strong><br>
          ${email.subject}<br>
          ${email.body}
        </button>
      `;
      } else if(mailbox === "sent"){
        if(email.body.length > 30){
          email.body = email.body.substring(0,30) + "...";
        } else {
          email.body = email.body
        }
        output += `
        <button type="button" id="email-btn" class="list-group-item list-group-item-action">
          <strong>${email.recipients}</strong><br>
          ${email.subject}<br>
          ${email.body}
        </button>
      `;
      }
    });
    output += '</div>'
    var Emails = document.createElement('div')
    Emails.innerHTML = output;
    document.querySelector('#emails-view').appendChild(Emails);
});
}

您的 onclick 中没有 id 参数。 像这样制作onclick,以便您可以添加参数。

document.addEventListener('DOMContentLoaded', function() {
document.querySelector('#email-btn').onclick = () => email_select(id);
});
  1. 如果您通过 id 查找元素,则只需使用document.getElementById('email-btn')

  2. 任何事件处理程序将接收的第一个参数是“事件”。

  3. 没有看到您的实际email-btn ,很难看出您如何将id给事件处理程序,那么您的处理程序方法如何知道要使用哪个id呢?

  4. 处理程序中的this是对定义了 onclick 处理程序的元素的引用,除非您将该方法.bind()到另一个上下文。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM