有没有一种方法可以通过点击输入按钮来更改
元素的类别?

huangapple go评论240阅读模式
英文:

is there a way to change the class on a div by clicking on an input button?

问题

我有一个希望在页面加载时隐藏的

元素。该

元素的类名是"messages-hide"。

当我点击提交按钮时,我希望将该

元素的类更改为"messages-show"。

我的HTML代码如下:

  1. <div class="messages-hide"></div>
  2. <input type="submit" id="btnSubmit" value="发送请求" />

我的CSS代码如下:

  1. .messages-hide {
  2. display: none;
  3. }
  4. .messages-show {
  5. display: block;
  6. }

提交按钮当前可以正常工作,但它没有更改类名(显然)。

我假设使用JavaScript或jQuery可以很简单地解决这个问题,但我不知道从哪里开始。

我找到了几种看起来应该可以工作的解决方案,但没有一种专门适用于 / 按钮。我已经花了几个小时在这上面。我觉得是时候寻求帮助了...

我愿意接受任何有效的方法。

非常感谢任何帮助...谢谢!

英文:

I have a div that I want hidden on page load. The class name on the div is "messages-hide"

When I click on a submit button, I want to change the class on that div to "messages-show".

My HTML is:

  1. &lt;div class=&quot;messages-hide&quot;&gt;&lt;/div&gt;
  2. &lt;input type=&quot;submit&quot; id=&quot;btnSubmit&quot; value=&quot;Send the request&quot; /&gt;

My CSS is:

  1. .messages-hide {
  2. display: none;
  3. }
  4. .messages-show {
  5. display: block;
  6. }

The submit button works as is, but it's not changing the class (obviously).

I'm assuming this is fairly simple using Javascript or jQuery, but I don't know where to begin.

I've found several solutions that look like they should work, but nothing that works specifically with an input/submit button. I've already spent hours on this. Figure it's time to ask for help...

I'm open to anything that will work.

Any help will be greatly appreciated... thanks!

答案1

得分: 1

以下是翻译好的内容:

有多种方法可以实现这一点。

在我看来,最简单的方法是创建一个名为 messages 的默认类,然后在该类中设置 display: none

然后创建一个名为 show 的类,其 display 属性设置为 block

然后在按钮点击事件中,只需将 show 类添加到 messagesdiv 元素上。

不过,需要注意的是,如果这是一个表单中的提交按钮,在表单重新加载页面后,消息将再次被隐藏。除非你的JavaScript提交/点击函数中有其他操作,你尚未发布。

更新
如果你想在页面加载后显示消息 div,那么你可以使用 localStorage.getItemlocalStorage.setItem

由于片段工具的限制,我无法启用 localStorage。但对于你的实现,只需取消注释这些行。

  1. <!-- 开始片段: js 隐藏: false 控制台: true babel: false -->
  2. <!-- 语言: lang-js -->
  3. const btnSubmit = document.querySelector("#btnSubmit");
  4. const messages = document.querySelector(".messages");
  5. //const showMsgs = (localStorage.getItem("showMsgs"))
  6. //if(showMsgs)messages.classList.add("show")
  7. btnSubmit.addEventListener("click",(e) => {
  8. messages.classList.add("show")
  9. // localStorage.setItem("showMsgs",1)
  10. });
  11. <!-- 语言: lang-css -->
  12. .messages{
  13. display: none;
  14. }
  15. .messages.show{
  16. display: block;
  17. }
  18. <!-- 语言: lang-html -->
  19. <div class="messages">MESSAGES</div>
  20. <input type="submit" id="btnSubmit" value="Send the request" />
  21. <!-- 结束片段 -->

希望这对你有所帮助。

英文:

There are multiple ways to do this.

The simplest way in my opinion is have a default class lets call it messages. And in that class is display none.

Then have a class called show that is display block.

Then on click of your button simply add the show class to the messages div.

However, one note is if its a submit button in a form, once the form reloads the page the messages will be hidden again. Unless you have more going on in your javascript submit/click function that you haven't posted.

Update
If you want to show the messages div after page load, then you can use localStorage.getItem and localStorage.setItem.

Due to the limitations in the snippet tool, I can't enable localStorage. But for your implementation, just uncomment those lines.

<!-- begin snippet: js hide: false console: true babel: false -->

<!-- language: lang-js -->

  1. const btnSubmit = document.querySelector(&quot;#btnSubmit&quot;);
  2. const messages = document.querySelector(&quot;.messages&quot;);
  3. //const showMsgs = (localStorage.getItem(&quot;showMsgs&quot;))
  4. //if(showMsgs)messages.classList.add(&quot;show&quot;)
  5. btnSubmit.addEventListener(&quot;click&quot;,(e) =&gt; {
  6. messages.classList.add(&quot;show&quot;)
  7. // localStorage.setItem(&quot;showMsgs&quot;,1)
  8. });

<!-- language: lang-css -->

  1. .messages{
  2. display: none;
  3. }
  4. .messages.show{
  5. display: block;
  6. }

<!-- language: lang-html -->

  1. &lt;div class=&quot;messages&quot;&gt;MESSAGES&lt;/div&gt;
  2. &lt;input type=&quot;submit&quot; id=&quot;btnSubmit&quot; value=&quot;Send the request&quot; /&gt;

<!-- end snippet -->

答案2

得分: 0

你可以使用JavaScript来处理提交按钮的点击事件,并将具有类名"messages-hide"的div的类名更改为"messages-show"。确保添加一些CSS来根据其类来控制div的可见性。

以下是一个完整的示例:

HTML:

  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="UTF-8">
  5. <meta http-equiv="X-UA-Compatible" content="IE=edge">
  6. <meta name="viewport" content="width=device-width, initial-scale=1.0">
  7. <title>Toggle Message</title>
  8. <style>
  9. .messages-hide {
  10. display: none;
  11. }
  12. .messages-show {
  13. display: block;
  14. }
  15. </style>
  16. </head>
  17. <body>
  18. <div class="messages-hide">Your message goes here.</div>
  19. <input type="submit" id="btnSubmit" value="Send the request" />
  20. <script src="script.js"></script>
  21. </body>
  22. </html>

JavaScript (script.js):

  1. document.getElementById('btnSubmit').addEventListener('click', function() {
  2. var div = document.querySelector('.messages-hide');
  3. if (div) {
  4. div.className = 'messages-show';
  5. }
  6. });

这段代码将在单击提交按钮时将div的类从"messages-hide"更改为"messages-show",如果它被隐藏,您的消息将变为可见。确保设置了CSS以隐藏"messages-hide"类并显示"messages-show"类,就像上面演示的那样。

您还可以使用类似切换的行为来在连续点击提交按钮时显示和隐藏div。您可以通过检查当前的类然后相应更改它来实现这一点。

以下是更新后的JavaScript代码:

  1. document.getElementById('btnSubmit').addEventListener('click', function() {
  2. var div = document.querySelector('.messages-hide') || document.querySelector('.messages-show');
  3. if (div) {
  4. if (div.className === 'messages-hide') {
  5. div.className = 'messages-show';
  6. } else {
  7. div.className = 'messages-hide';
  8. }
  9. }
  10. });
英文:

You can use JavaScript to handle the click event of the submit button and change the class name of the div with the class "messages-hide" to "messages-show". Make sure to add some CSS to control the visibility of the div based on its class.

Here's a full example:

HTML:

  1. &lt;!DOCTYPE html&gt;
  2. &lt;html lang=&quot;en&quot;&gt;
  3. &lt;head&gt;
  4. &lt;meta charset=&quot;UTF-8&quot;&gt;
  5. &lt;meta http-equiv=&quot;X-UA-Compatible&quot; content=&quot;IE=edge&quot;&gt;
  6. &lt;meta name=&quot;viewport&quot; content=&quot;width=device-width, initial-scale=1.0&quot;&gt;
  7. &lt;title&gt;Toggle Message&lt;/title&gt;
  8. &lt;style&gt;
  9. .messages-hide {
  10. display: none;
  11. }
  12. .messages-show {
  13. display: block;
  14. }
  15. &lt;/style&gt;
  16. &lt;/head&gt;
  17. &lt;body&gt;
  18. &lt;div class=&quot;messages-hide&quot;&gt;Your message goes here.&lt;/div&gt;
  19. &lt;input type=&quot;submit&quot; id=&quot;btnSubmit&quot; value=&quot;Send the request&quot; /&gt;
  20. &lt;script src=&quot;script.js&quot;&gt;&lt;/script&gt;
  21. &lt;/body&gt;
  22. &lt;/html&gt;

JavaScript (script.js):

  1. document.getElementById(&#39;btnSubmit&#39;).addEventListener(&#39;click&#39;, function() {
  2. var div = document.querySelector(&#39;.messages-hide&#39;);
  3. if (div) {
  4. div.className = &#39;messages-show&#39;;
  5. }
  6. });

This code will switch the class of the div from "messages-hide" to "messages-show" when the submit button is clicked, and your message will become visible if it's hidden. Make sure the CSS is set up to hide the "messages-hide" class and show the "messages-show" class as demonstrated above.

You can also use a toggle-like behavior to show and hide the div on successive clicks of the submit button. You can achieve this by checking the current class and then changing it accordingly.

Here's the updated JavaScript code:

  1. document.getElementById(&#39;btnSubmit&#39;).addEventListener(&#39;click&#39;, function() {
  2. var div = document.querySelector(&#39;.messages-hide&#39;) || document.querySelector(&#39;.messages-show&#39;);
  3. if (div) {
  4. if (div.className === &#39;messages-hide&#39;) {
  5. div.className = &#39;messages-show&#39;;
  6. } else {
  7. div.className = &#39;messages-hide&#39;;
  8. }
  9. }
  10. });

答案3

得分: 0

mdn 提到:
> 请注意,提交事件会在 <form> 元素本身上触发,而不会在其中的任何 <button> 或 <input type="submit"> 上触发。然而,发送用于指示表单提交操作已触发的 SubmitEvent 会包含一个 submitter 属性,该属性是触发提交请求的按钮。

因此,您需要监听表单上的提交事件。假设您的表单具有 id 为 "myForm",您可以在 jQuery 中执行以下操作:

  1. $(&quot;#myForm&quot;).on(&#39;submit&#39;, function() {
  2. $(&quot;.message-hide&quot;).addClass(&quot;message-show&quot;);
  3. $(&quot;.message-hide&quot;).removeClass(&quot;message-hide&quot;);
  4. });
英文:

mdn says:
> Note that the submit event fires on the <form> element itself, and not on any <button> or <input type="submit"> inside it. However, the SubmitEvent which is sent to indicate the form's submit action has been triggered includes a submitter property, which is the button that was invoked to trigger the submit request.

So what you need to do is to watch for the submit event on the form. Assuming your form has an id of "myForm," you can do something like this in jquery:

  1. $(&quot;#myForm&quot;).on(&#39;submit&#39;, function() {
  2. $(&quot;.message-hide&quot;).addClass(&quot;message-show&quot;);
  3. $(&quot;.message-hide&quot;).removeClass(&quot;message-hide&quot;);
  4. });

答案4

得分: 0

我知道我来晚了,但你可以像这样使用jQuery代码,使用.toggle()

  1. <!-- begin snippet: js hide: false console: true babel: false -->
  2. <!-- language: lang-js -->
  3. $(&#39;#btnSubmit&#39;).click(function(e){
  4. e.preventDefault();
  5. $(&#39;div.message&#39;).toggle();
  6. });
  7. <!-- language: lang-html -->
  8. <script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
  9. <div class="message" style="display:none;">Message</div>
  10. <input type="submit" id="btnSubmit" value="Send the request" />
  11. <!-- end snippet -->

注意:这是您提供的原始代码的翻译,没有其他附加内容。

英文:

I know I am late but you can use jQuery code like this using .toggle():

<!-- begin snippet: js hide: false console: true babel: false -->

<!-- language: lang-js -->

  1. $(&#39;#btnSubmit&#39;).click(function(e){
  2. e.preventDefault();
  3. $(&#39;div.message&#39;).toggle();
  4. });

<!-- language: lang-html -->

  1. &lt;script src=&quot;https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js&quot;&gt;&lt;/script&gt;
  2. &lt;div class=&quot;message&quot; style=&quot;display:none;&quot;&gt;Message&lt;/div&gt;
  3. &lt;input type=&quot;submit&quot; id=&quot;btnSubmit&quot; value=&quot;Send the request&quot; /&gt;

<!-- end snippet -->

huangapple
  • 本文由 发表于 2023年8月11日 05:18:10
  • 转载请务必保留本文链接:https://go.coder-hub.com/76879358.html
匿名

发表评论

匿名网友

:?: :razz: :sad: :evil: :!: :smile: :oops: :grin: :eek: :shock: :???: :cool: :lol: :mad: :twisted: :roll: :wink: :idea: :arrow: :neutral: :cry: :mrgreen:

确定