本文详解如何在 input 元素失焦(blur)时,将其输入的 url 动态赋值给同级的 `` 标签的 `href` 属性,确保点击标签即可跳转至用户刚输入的目标链接。
在构建表单交互时,常需实现“输入即生效”的体验:例如用户在 URL 输入框中填写链接后,无需额外操作,只要焦点离开(blur),其上方或旁边的可点击标签(如 )便自动更新 href,实现一键跳转。但实践中容易因 DOM 结构理解偏差或选择器错误导致事件监听失效。
原始代码存在三个关键问题:
以下是修复后的完整、健壮实现:
function addEventListeners() {
const inputs = document.querySelectorAll('input.published-link-input');
inputs.forEach(input => {
input.addEventListener('blur', function() {
const url = this.value.trim();
// 验证 URL 格式(可选增强)
if (url && /^https?:\/\//i.test(url)) {
const linkAnchor = this.parentNode.querySelector('a');
if (linkAnchor) {
linkAnchor.setAttribute('href', url);
}
}
});
});
}
// ⚠️ 必须显式调用,否则监听器不会生效
addEventListeners();确保 HTML 中 与 处于同一父容器内,且 在 之前(顺序不影响 querySelector 查找,但语义更清晰):
? 提示:为提升可访问性,建议为 添加 id 并与 的 for 属性匹配;同时初始 可设为占位符,避免空链接。
通过以上修正,即可实现用户输入 URL 后失焦即刻激活标签跳转功能,逻辑清晰、结构健壮、易于维护。