📅  最后修改于: 2023-12-03 15:41:57.688000             🧑  作者: Mango
有许多方法可用于在 HTML 中选择 onclick 输入的所有文本。这里将介绍两种不同的方法。
使用 JavaScript,我们可以轻松地获取 onclick 中的所有文本,并将其传递给另一个函数。
function getTextFromOnClick(onclickText) {
// 用正则表达式匹配 onclick 中的所有文本
const regex = /'([^']|'')*'|"[^"]*"/g;
const matches = onclickText.match(regex);
// 创建一个包含所有匹配项的字符串
let text = "";
for (let i = 0; i < matches.length; i++) {
// 去除引号和双引号
const match = matches[i].replace(/(^['"]|['"]$)/g, "");
text += match + " ";
}
// 返回处理过的字符串
return text.trim();
}
要使用此函数,请将 onclick 属性的文本作为参数传递给它:
<button onclick="alert('你点击了按钮')">点击我</button>
const onclickText = document.querySelector("button").getAttribute("onclick");
const text = getTextFromOnClick(onclickText);
console.log(text); // 输出 "你点击了按钮"
注意,这种方法仅适用于 onclick 属性的文本使用引号或双引号括起来的情况。如果没有括号,则需要另一种方法。
如果我们希望从在 HTML 中设置 onclick 属性的事件处理程序中获取文本,则可以使用 Element.onclick 属性。这种方法适用于没有引号或双引号括起来的 onclick 属性的文本。
<button id="myButton">点击我</button>
// 设置 onclick 属性
document.getElementById("myButton").onclick = function() {
alert("你点击了按钮");
};
// 获取 onclick 属性的文本
const onclickText = document.getElementById("myButton").getAttribute("onclick");
console.log(onclickText); // 输出 "function() {\n alert(\"你点击了按钮\");\n}"
然后,我们可以使用一些字符串处理技巧来获取所需的文本:
const text = onclickText.slice(
onclickText.indexOf("alert(\"") + 7,
onclickText.lastIndexOf("\")")
);
console.log(text); // 输出 "你点击了按钮"
这种方法还允许我们获取 onclick 属性的任何 JavaScript 代码,而不仅仅是文本。
以上就是在 HTML 中选择 onclick 输入的所有文本的两种不同方法。该选择也可以取决于您的具体需求和使用情况。