- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
TLDR 我不知道如何编写函数 onclick("sl") 显示类“sl”的内容&&类“lng”隐藏类“lng”的其他所有内容&& 类“(en, de, it, hr, ru)”
你好,
我正在制作一个多语言注册页面。我目前陷入困境,因为我不知道如何编写/修改一个函数来检测一个元素是否有两个特定的类(类 lng 和类 sl、en、de、it、hr 或 ru),并且取决于该组合显示内容(display: none;
或 display: inline-block;
)。
此外,我希望占位符的内容根据所选语言进行更改。
编辑工作display: none;
/display: inline;
修改后的JS
const lngs = document.getElementsByClassName("lng");
function init() {
for (var i = 0; i < lngs.length; i++) {
lngs[i].style.display = "none";
}
}
init();
function setLanguage(language) {
debugger
console.log(language);
for (var i = 0; i < lngs.length; i++) {
if (lngs[i].className.includes(language)) {
lngs[i].style.display = "inline";
} else {
lngs[i].style.display = "none";
}
}
}
编辑后的 HTML
<html>
<head>
</head>
<body>
<img class="background-image" />
<header>
<div class="top-nav-logo">
<img class="top-logo" src="assets/Logo_Sava.jpg">
</div>
<div class="top-language">
<div>
<input type="image" id="slo" class="zastave" src="assets/drzave/Slo.png" onclick="setLanguage('sl')">
<input type="image" id="ang" class="zastave" src="assets/drzave/Ang.png" onclick="setLanguage('en')">
<input type="image" id="nem" class="zastave" src="assets/drzave/Nem.png" onclick="setLanguage('de')">
<input type="image" id="ita" class="zastave" src="assets/drzave/Ita.png" onclick="setLanguage('it')">
<input type="image" id="hrv" class="zastave" src="assets/drzave/Hrv.png" onclick="setLanguage('hr')">
<input type="image" id="rus" class="zastave" src="assets/drzave/Rus.png" onclick="setLanguage('ru')">
</div>
</div>
</header>
<div class="pasica">
<img src=""/>
</div>
<div class="center-div">
<div class="registerTitle">
<div class="lng si">
Slo - Register
</div>
<div class="lng en">
Eng - Register
</div>
<div class="lng de">
Deu - Register
</div>
<div class="lng it">
Ita - Register
</div>
<div class="lng hr">
Hrv - Register
</div>
<div class="lng ru">
Rus - Register
</div>
</div>
<div class="registerForm">
<form accept-charset="utf-8" name="form" onsubmit="return false;" method="post" id="form">
<input type="text" name="fname" id="fname" required maxlength="50" minlength="1" placeholder="Janez"
onfocus="this.placeholder = ''" onblur="this.placeholder = 'Janez'" /><br />
<input type="text" name="lname" id="lname" required maxlength="50" minlength="1" placeholder="Novak"
onfocus="this.placeholder = ''" onblur="this.placeholder = 'Novak'" /><br />
<span class="lng sl radioS">Spol: </span>
<span class="lng en radioS">Gender: </span>
<span class="lng de radioS">Spol DE: </span>
<span class="lng it radioS">Gendero IT: </span>
<span class="lng hr radioS">Spolov: </span>
<span class="lng ru radioS">секс: </span><br /><br />
<div class="radioC"><label><input type="radio" name="spol" value="M"> <span class="lng sl">Moški SI</span>
<span class="lng en">Moški EN</span>
<span class="lng de">Moški DE</span>
<span class="lng it">Moški IT</span>
<span class="lng hr">Moški HR</span>
<span class="lng ru">Moški RU</span>
</label></div><br />
<div class="radioC"><label><input type="radio" name="spol" value="Z"> <span class="lng sl">Ženski SI</span>
<span class="lng en">Ženski EN</span>
<span class="lng de">Ženski DE</span>
<span class="lng it">Ženski IT</span>
<span class="lng hr">Ženski HR</span>
<span class="lng ru">Ženski RU</span>
</label></div><br />
<div class="radioC"><label><input type="radio" name="spol" value="O"> <span class="lng sl">Ostalo SI</span>
<span class="lng en">Ostalo EN</span>
<span class="lng de">Ostalo DE</span>
<span class="lng it">Ostalo IT</span>
<span class="lng hr">Ostalo HR</span>
<span class="lng ru">Ostalo RU</span>
</label></div><br /><br />
<input type="email" name="email" id="email" autofocus="autofocus" required placeholder="moj@email.com"
onfocus="this.placeholder = ''" onblur="this.placeholder = 'moj@email.com'" />
<br />
<input type="button" value="Submit" id="submit_ok" name="submit_ok" /> <br />
</form>
</div>
</div>
</body>
</html>
HTML
<!DOCTYPE html >
<html>
<head>
<link rel="stylesheet" type="text/css" href="styles/main.css">
<link rel="stylesheet" type="text/css" href="styles/language.css">
<script type="text/javascript" src="js/myScript.js"></script>
<script type="text/javascript" src="js/language.js"></script>
<meta charset="utf-8">
<title>Registration</title>
</head>
<body>
<img class="background-image" />
<header>
<div class="top-nav-logo">
<img class="top-logo" src="assets/Logo_Sava.jpg">
</div>
<div class="top-language">
<div>
<input type="image" id="slo" class="zastave" src="assets/drzave/Slo.png" onclick="setLanguage('sl')">
<input type="image" id="ang" class="zastave" src="assets/drzave/Ang.png" onclick="setLanguage('en')">
<input type="image" id="nem" class="zastave" src="assets/drzave/Nem.png" onclick="setLanguage('de')">
<input type="image" id="ita" class="zastave" src="assets/drzave/Ita.png" onclick="setLanguage('it')">
<input type="image" id="hrv" class="zastave" src="assets/drzave/Hrv.png" onclick="setLanguage('hr')">
<input type="image" id="rus" class="zastave" src="assets/drzave/Rus.png" onclick="setLanguage('ru')">
</div>
</div>
</header>
<div class="center-div">
<div class="registerTitle">
<div class="lng" class="sl">
Slo - Register
</div>
<div class="lng" class="en">
Eng - Register
</div>
<div class="lng" class="de">
Deu - Register
</div>
<div class="lng" class="it">
Ita - Register
</div>
<div class="lng" class="hr">
Hrv - Register
</div>
<div class="lng" class="ru">
Rus - Register
</div>
</div>
<div class="registerForm">
<form accept-charset="utf-8" name="form" onsubmit="return false;" method="post" id="form">
<input type="text" name="fname" id="fname" required maxlength="50" minlength="1" placeholder="Janez"
onfocus="this.placeholder = ''" onblur="this.placeholder = 'Janez'" /><br />
<input type="text" name="lname" id="lname" required maxlength="50" minlength="1" placeholder="Novak"
onfocus="this.placeholder = ''" onblur="this.placeholder = 'Novak'" /><br />
<span class="lng" class="sl" class="radioS">Spol: </span>
<span class="lng" class="en" class="radioS">Gender: </span>
<span class="lng" class="de" class="radioS">Spol DE: </span>
<span class="lng" class="it" class="radioS">Spol IT: </span>
<span class="lng" class="hr" class="radioS">Spol HR: </span>
<span class="lng" class="ru" class="radioS">Spol RU: </span><br /><br />
<div class="radioC"><label><input type="radio" name="spol" value="M"> <span class="lng" class="sl">Moški SI</span>
<span class="lng" class="en">Moški EN</span>
<span class="lng" class="de">Moški DE</span>
<span class="lng" class="it">Moški IT</span>
<span class="lng" class="hr">Moški HR</span>
<span class="lng" class="ru">Moški RU</span>
</label></div><br />
<div class="radioC"><label><input type="radio" name="spol" value="Z"> <span class="lng" class="sl">Ženski SI</span>
<span class="lng" class="en">Ženski EN</span>
<span class="lng" class="de">Ženski DE</span>
<span class="lng" class="it">Ženski IT</span>
<span class="lng" class="hr">Ženski HR</span>
<span class="lng" class="ru">Ženski RU</span>
</label></div><br />
<div class="radioC"><label><input type="radio" name="spol" value="O"> <span class="lng" class="sl">Ostalo SI</span>
<span class="lng" class="en">Ostalo EN</span>
<span class="lng" class="de">Ostalo DE</span>
<span class="lng" class="it">Ostalo IT</span>
<span class="lng" class="hr">Ostalo HR</span>
<span class="lng" class="ru">Ostalo RU</span>
</label></div><br /><br />
<input type="email" name="email" id="email" autofocus="autofocus" required placeholder="moj@email.com"
onfocus="this.placeholder = ''" onblur="this.placeholder = 'moj@email.com'" />
<br />
<input type="button" value="Submit" id="submit_ok" name="submit_ok" /> <br />
</form>
</div>
</div>
</body>
</html>
Javascript - 我目前拥有的和不起作用的
let fname = document.getElementById("fname");
let lname = document.getElementById("lname");
let email = document.getElementById("email");
function setInputs(language) {
var jeziki;
var i;
jeziki = document.getElementsByClassName("lng");
console.log(jeziki);
for (var i=0;i<jeziki.length;i++){
if (jeziki[i].getElementsByClassName === "sl") {
fname.setAttribute('placeholder', 'Janez');
lname.setAttribute('placeholder', 'Novak');
email.setAttribute('placeholder', 'moj@email.si');
} else if (jeziki[i].getElementsByClassName === "en"){
fname.setAttribute('placeholder', 'John');
lname.setAttribute('placeholder', 'Doe');
email.setAttribute('placeholder', 'my@email.com');
} else if (jeziki[i].getElementsByClassName === "de"){
fname.setAttribute('placeholder', 'Comisar');
lname.setAttribute('placeholder', 'Rex');
email.setAttribute('placeholder', 'Rex@hou.dre');
} else if (jeziki[i].getElementsByClassName === "it"){
fname.setAttribute('placeholder', 'Mak');
lname.setAttribute('placeholder', 'Aron');
email.setAttribute('placeholder', 'forza@email.it');
} else if (jeziki[i].getElementsByClassName === "hr"){
fname.setAttribute('placeholder', 'Mirko');
lname.setAttribute('placeholder', 'Mirkic');
email.setAttribute('placeholder', 'nase@more.hr');
} else if (jeziki[i].getElementsByClassName === "ru"){
fname.setAttribute('placeholder', 'Milan');
lname.setAttribute('placeholder', 'Rusky');
email.setAttribute('placeholder', 'rus@go.ru');
} else {
fname.setAttribute('placeholder', 'John');
lname.setAttribute('placeholder', 'Doe');
email.setAttribute('placeholder', 'my@email.com');
}
}
}
Javascript - 有效,但我必须删除 ID,并且页面的设置随后有所不同(每种语言都有自己的形式)。
function setLanguage(language) {
var lngs;
var i;
lngs = document.getElementsByClassName("lng"); //array vseh lng-jev
console.log(lngs);
for (var i=0;i<lngs.length;i++){
if (lngs[i].getElementsByClassName(language) !== language) {
lngs[i].style.display="none";
} else {
lngs[i].style.display="inline-block";
}
}
}
最佳答案
做到这一点的方法是首先隐藏所有内容,然后显示应该可见的元素
var hide = ".lng";
var show = ".lng.sl";
document.querySelectorAll(hide).forEach(function() {
this.style.display = "none";
});
document.querySelectorAll(show).forEach(function() {
this.style.display = "inline-block";
});
关于javascript - 根据元素内的类显示函数 - Javascript vanilla,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59863347/
我的Angular-Component位于一个flexbox(id =“log”)中。可以显示或隐藏flexbox。 我的组件内部有一个可滚动区域,用于显示日志消息。 (id =“message-li
我真的很困惑 有一个 phpinfo() 输出: MySQL 支持 启用 客户端 API 版本 5.5.40 MYSQL_MODULE_TYPE 外部 phpMyAdmin 显示: 服务器类型:Mar
我正在研究这个 fiddle : http://jsfiddle.net/cED6c/7/我想让按钮文本在单击时发生变化,我尝试使用以下代码: 但是,它不起作用。我应该如何实现这个?任何帮助都会很棒
我应该在“dogs_cats”中保存表“dogs”和“cats”各自的ID,当看到数据时显示狗和猫的名字。 我有这三个表: CREATE TABLE IF NOT EXISTS cats ( id
我有一个字符串返回到我的 View 之一,如下所示: $text = 'Lorem ipsum dolor ' 我正在尝试用 Blade 显示它: {{$text}} 但是,输出是原始字符串而不是渲染
我无法让我的链接(由图像表示,位于页面左侧)真正有效地显示一个 div(包含一个句子,位于中间)/单击链接时隐藏。 这是我的代码: Practice
关闭。这个问题需要多问focused 。目前不接受答案。 想要改进此问题吗?更新问题,使其仅关注一个问题 editing this post . 已关闭 4 年前。 Improve this ques
最初我使用 Listview 来显示 oracle 结果,但是最近我不得不切换到 datagridview 来处理比 Listview 允许的更多的结果。然而,自从切换到数据网格后,我得到的结果越来越
我一直在尝试插入一个 Unicode 字符 ∇ 或 ▽,所以它显示在 Apache FOP 生成的 PDF 中。 这是我到目前为止所做的: 根据这个基本帮助 Apache XSL-FO Input,您
我正在使用 node v0.12.7 编写一个 nodeJS 应用程序。 我正在使用 pm2 v0.14.7 运行我的 nodejs 应用程序。 我的应用程序似乎有内存泄漏,因为它从我启动时的大约 1
好的,所以我有一些 jQuery 代码,如果从下拉菜单中选择了带有前缀 Blue 的项目,它会显示一个输入框。 代码: $(function() { $('#text1').hide();
当我试图检查 Chrome 中的 html 元素时,它显示的是 LESS 文件,而 Firefox 显示的是 CSS 文件。 (我正在使用 Bootstrap 框架) 如何在 Chrome 中查看 c
我是 Microsoft Bot Framework 的新手,我正在通过 youtube 视频 https://youtu.be/ynG6Muox81o 学习它并在 Ubuntu 上使用 python
我正在尝试转换从 mssql 生成的文件到 utf-8。当我打开他的输出 mssql在 Windows Server 2003 中使用 notepad++ 将文件识别为 UCS-2LE我使用 file
很难说出这里问的是什么。这个问题是含糊的、模糊的、不完整的、过于宽泛的或修辞性的,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开它,visit the help center 。 已关
我正在尝试执行单击以打开/关闭一个 div 的功能。 这是基本的,但是,点击只显示 div,当我点击“关闭”时,没有任何反应。 $(".inscricao-email").click(function
假设我有 2 张卡片,屏幕上一次显示一张。我有一个按钮可以用其他卡片替换当前卡片。现在假设卡 1 上有一些数据,卡 2 上有一些数据,我不想破坏它们每个上的数据,或者我不想再次重建它们中的任何一个。
我正在使用 Eloquent Javascript 学习 Javascript。 我在 Firefox 控制台上编写了以下代码,但它返回:“ReferenceError:show() 未定义”为什么?
我正在使用 Symfony2 开发一个 web 项目,我使用 Sonata Admin 作为管理面板,一切正常,但我想要做的是,在 Sonata Admin 的仪表板菜单上,我需要显示隐藏一些菜单取决
我试图显示一个div,具体取决于从下拉列表中选择的内容。例如,如果用户从列表中选择“现金”显示现金div或用户从列表中选择“检查”显示现金div 我整理了样本,但样本不完整,需要接线 http://j
我是一名优秀的程序员,十分优秀!