Javascript 语法 getElementById outerHTML
Javascript Syntax getElementById outerHTML
我有一个关于 outerHTML 语法的问题。也有可能是我思路错了
我的html文件如下:
<!DOCTYPE html>
<html lang="en">
<body>
<label for="language">Choose a language:</label>
<select name="language" id="language" value="val1">
<option value="val1">English</option>
<option value="val2">German</option>
</select>
<p>You selected: <span id="language"></span></p> <!-- shall display either "English" or "German" -->
<p>You selected the following option: <span id="language"></span></p> <!-- shall display either "val1" or "val2" -->
<script src="./script.js"></script>
</body>
</html>
我指的是一个脚本,目前唯一的内容是
var selectedlang = document.getElementById("language").outerHTML;
在 html 文件中,它应该显示它的值和变量。我不知道如何进行。
一份文档中不能有多个元素具有相同的 id
值;您当前的标记在三个不同的元素上使用 id="language"
。您至少需要更改其中两个。
我想你问的是如何:
在两个 span
和
中显示当前选择的选项的文本和值
如果用户更改选择,如何更新您显示的内容。
如果您只想要选定的值,可以使用 select
元素的 value
属性。但是对于文本 和 值,您需要 selectedIndex
属性 和 options
集合:
function showTextAndValue(select, textSpan, valueSpan) {
const option = select.options[select.selectedIndex];
if (option) {
textSpan.textContent = option.text;
valueSpan.textContent = option.value;
} else {
// No option is selected
textSpan.textContent = "";
valueSpan.textContent = "";
}
}
在那个例子中,我让它接受 select
和 span
作为函数的参数。
您会在页面加载时调用该函数,然后在 select
的 input
事件触发时再次调用。
这是一个例子:
const select = document.getElementById("language-select");
const textSpan = document.getElementById("text-span");
const valueSpan = document.getElementById("value-span");
function showTextAndValue(select, textSpan, valueSpan) {
const option = select.options[select.selectedIndex];
if (option) {
textSpan.textContent = option.text;
valueSpan.textContent = option.value;
} else {
// No option is selected
textSpan.textContent = "";
valueSpan.textContent = "";
}
}
// Show on page load
showTextAndValue(select, textSpan, valueSpan);
// Hook the `input` event
select.addEventListener("input", () => {
// Update the contents of the elements
showTextAndValue(select, textSpan, valueSpan);
});
<label for="language">Choose a language:</label>
<select name="language" id="language-select" value="val1">
<option value="val1">English</option>
<option value="val2">German</option>
</select>
<p>You selected: <span id="text-span"></span></p> <!-- shall display either "English" or "German" -->
<p>You selected the following option: <span id="value-span"></span></p> <!-- shall display either "val1" or "val2" -->
<script src="./script.js"></script>
(请注意,我更改了所有三个 id
。)
我有一个关于 outerHTML 语法的问题。也有可能是我思路错了
我的html文件如下:
<!DOCTYPE html>
<html lang="en">
<body>
<label for="language">Choose a language:</label>
<select name="language" id="language" value="val1">
<option value="val1">English</option>
<option value="val2">German</option>
</select>
<p>You selected: <span id="language"></span></p> <!-- shall display either "English" or "German" -->
<p>You selected the following option: <span id="language"></span></p> <!-- shall display either "val1" or "val2" -->
<script src="./script.js"></script>
</body>
</html>
我指的是一个脚本,目前唯一的内容是
var selectedlang = document.getElementById("language").outerHTML;
在 html 文件中,它应该显示它的值和变量。我不知道如何进行。
一份文档中不能有多个元素具有相同的 id
值;您当前的标记在三个不同的元素上使用 id="language"
。您至少需要更改其中两个。
我想你问的是如何:
在两个
中显示当前选择的选项的文本和值span
和如果用户更改选择,如何更新您显示的内容。
如果您只想要选定的值,可以使用 select
元素的 value
属性。但是对于文本 和 值,您需要 selectedIndex
属性 和 options
集合:
function showTextAndValue(select, textSpan, valueSpan) {
const option = select.options[select.selectedIndex];
if (option) {
textSpan.textContent = option.text;
valueSpan.textContent = option.value;
} else {
// No option is selected
textSpan.textContent = "";
valueSpan.textContent = "";
}
}
在那个例子中,我让它接受 select
和 span
作为函数的参数。
您会在页面加载时调用该函数,然后在 select
的 input
事件触发时再次调用。
这是一个例子:
const select = document.getElementById("language-select");
const textSpan = document.getElementById("text-span");
const valueSpan = document.getElementById("value-span");
function showTextAndValue(select, textSpan, valueSpan) {
const option = select.options[select.selectedIndex];
if (option) {
textSpan.textContent = option.text;
valueSpan.textContent = option.value;
} else {
// No option is selected
textSpan.textContent = "";
valueSpan.textContent = "";
}
}
// Show on page load
showTextAndValue(select, textSpan, valueSpan);
// Hook the `input` event
select.addEventListener("input", () => {
// Update the contents of the elements
showTextAndValue(select, textSpan, valueSpan);
});
<label for="language">Choose a language:</label>
<select name="language" id="language-select" value="val1">
<option value="val1">English</option>
<option value="val2">German</option>
</select>
<p>You selected: <span id="text-span"></span></p> <!-- shall display either "English" or "German" -->
<p>You selected the following option: <span id="value-span"></span></p> <!-- shall display either "val1" or "val2" -->
<script src="./script.js"></script>
(请注意,我更改了所有三个 id
。)