{"id":4952,"date":"2022-01-14T01:00:00","date_gmt":"2022-01-14T00:00:00","guid":{"rendered":"https:\/\/alvarotrigo.com\/epa\/disable-button-javascript\/"},"modified":"2024-07-16T20:22:08","modified_gmt":"2024-07-16T18:22:08","slug":"disable-button-javascript","status":"publish","type":"post","link":"https:\/\/alvarotrigo.com\/blog\/disable-button-javascript\/","title":{"rendered":"Disable a HTML Button in JavaScript [With Examples]"},"content":{"rendered":"\n<p>To disable a button using <strong>only JavaScript<\/strong> you need to set the <code>disabled<\/code> property to <code>true<\/code>. For example: <code>element.disabled = true<\/code>.<\/p>\n\n\n\n<p>And to enable a button, you need do the opposite by setting the <code>disabled<\/code> JavaScript property to <code>false<\/code>.<\/p>\n\n\n\n<p>Here is a more complete example where we select the button and then change its disabled property:<\/p>\n\n\n<pre class=\"wp-block-code\" aria-describedby=\"shcb-language-1\" data-shcb-language-name=\"JavaScript\" data-shcb-language-slug=\"javascript\"><span><code class=\"hljs language-javascript\"><span class=\"hljs-comment\">\/\/ Disabling a button using JavaScript<\/span>\n<span class=\"hljs-built_in\">document<\/span>.querySelector(<span class=\"hljs-string\">'#button'<\/span>).disabled = <span class=\"hljs-literal\">true<\/span>;\n<\/code><\/span><small class=\"shcb-language\" id=\"shcb-language-1\"><span class=\"shcb-language__label\">Code language:<\/span> <span class=\"shcb-language__name\">JavaScript<\/span> <span class=\"shcb-language__paren\">(<\/span><span class=\"shcb-language__slug\">javascript<\/span><span class=\"shcb-language__paren\">)<\/span><\/small><\/pre>\n\n<pre class=\"wp-block-code\" aria-describedby=\"shcb-language-2\" data-shcb-language-name=\"JavaScript\" data-shcb-language-slug=\"javascript\"><span><code class=\"hljs language-javascript\"><span class=\"hljs-comment\">\/\/ Enabling a disabled button<\/span>\n<span class=\"hljs-built_in\">document<\/span>.querySelector(<span class=\"hljs-string\">'#button'<\/span>).disabled = <span class=\"hljs-literal\">false<\/span>;\n<\/code><\/span><small class=\"shcb-language\" id=\"shcb-language-2\"><span class=\"shcb-language__label\">Code language:<\/span> <span class=\"shcb-language__name\">JavaScript<\/span> <span class=\"shcb-language__paren\">(<\/span><span class=\"shcb-language__slug\">javascript<\/span><span class=\"shcb-language__paren\">)<\/span><\/small><\/pre>\n\n\n<p>These are the steps we have to follow:<\/p>\n\n\n\n<ol class=\"wp-block-list\">\n<li>Select the button element you want to disable.<\/li>\n\n\n\n<li>Set the <code>disabled<\/code> property to <code>false<\/code>.<\/li>\n<\/ol>\n\n\n\n<blockquote class=\"wp-block-quote is-layout-flow wp-block-quote-is-layout-flow\">\n<p>The <a href=\"https:\/\/developer.mozilla.org\/en-US\/docs\/Web\/API\/HTMLSelectElement\/disabled\" target=\"_blank\" rel=\"noopener nofollow\"><code>disabled<\/code> property<\/a> reflects the HTML attribute <code>disabled<\/code> and provide a way to change this property dynamically with JavaScript.<\/p>\n<\/blockquote>\n\n\n\n<h2 class=\"wp-block-heading\" id=\"disable-button-example\">Disable Button JS Example<\/h2>\n\n\n\n<p>For demo purposes and to keep it as simple as possible, we&#8217;ll be disabling the button when clicking on itself:<\/p>\n\n\n<pre class=\"wp-block-code\" aria-describedby=\"shcb-language-3\" data-shcb-language-name=\"JavaScript\" data-shcb-language-slug=\"javascript\"><span><code class=\"hljs language-javascript\"><span class=\"hljs-keyword\">const<\/span> button = <span class=\"hljs-built_in\">document<\/span>.querySelector(<span class=\"hljs-string\">'#button'<\/span>);\n\n<span class=\"hljs-keyword\">const<\/span> disableButton = <span class=\"hljs-function\"><span class=\"hljs-params\">()<\/span> =&gt;<\/span> {\n    button.disabled = <span class=\"hljs-literal\">true<\/span>;\n};\n\nbutton.addEventListener(<span class=\"hljs-string\">'click'<\/span>, disableButton);\n<\/code><\/span><small class=\"shcb-language\" id=\"shcb-language-3\"><span class=\"shcb-language__label\">Code language:<\/span> <span class=\"shcb-language__name\">JavaScript<\/span> <span class=\"shcb-language__paren\">(<\/span><span class=\"shcb-language__slug\">javascript<\/span><span class=\"shcb-language__paren\">)<\/span><\/small><\/pre>\n\n\n<p>Here&#8217;s <a href=\"https:\/\/codepen.io\/alvarotrigo\/pen\/xxXmYbG\" rel=\"nofollow noopener\" target=\"_blank\">the Codepen<\/a> so you can test it out yourself and play a bit more with it by changing the code:<\/p>\n\n\n\n<div class=\"wp-block-cp-codepen-gutenberg-embed-block cp_embed_wrapper\"><iframe id=\"cp_embed_xxXmYbG\" data-src=\"\/\/codepen.io\/anon\/embed\/xxXmYbG?height=450&amp;theme-id=1&amp;slug-hash=xxXmYbG&amp;default-tab=js,result\" height=\"450\" scrolling=\"no\" frameborder=\"0\" allowfullscreen allowpaymentrequest name=\"CodePen Embed xxXmYbG\" title=\"CodePen Embed xxXmYbG\" class=\"cp_embed_iframe lazyload\" style=\"width:100%;overflow:hidden\" src=\"data:image\/svg+xml;base64,PHN2ZyB3aWR0aD0iMSIgaGVpZ2h0PSIxIiB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciPjwvc3ZnPg==\" data-load-mode=\"1\">CodePen Embed Fallback<\/iframe><\/div>\n\n\n\n<blockquote class=\"wp-block-quote is-layout-flow wp-block-quote-is-layout-flow\">\n<p>If you are using jQuery, check out our article on <a href=\"https:\/\/alvarotrigo.com\/blog\/disable-button-jquery\/\">how to disable a button using jQuery<\/a>. The process is pretty similar.<\/p>\n<\/blockquote>\n\n\n\n<h2 id=\"disable-button-changing-the-disabled-html-attribute\" class=\"wp-block-heading\">Disable Button Changing the &#8220;disabled&#8221; HTML Attribute<\/h2>\n\n\n\n<p>Because the <code>disabled<\/code>\u00a0property is also available on the DOM, and you can change the state of a button by changing the HTML attribute.<\/p>\n\n\n\n<p>This is how a disabled button would look on HTML markup:<\/p>\n\n\n<pre class=\"wp-block-code\" aria-describedby=\"shcb-language-4\" data-shcb-language-name=\"HTML, XML\" data-shcb-language-slug=\"xml\"><span><code class=\"hljs language-xml\"><span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">button<\/span> <span class=\"hljs-attr\">id<\/span>=<span class=\"hljs-string\">\"button\"<\/span> <span class=\"hljs-attr\">disabled<\/span>&gt;<\/span>Save<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">button<\/span>&gt;<\/span><\/code><\/span><small class=\"shcb-language\" id=\"shcb-language-4\"><span class=\"shcb-language__label\">Code language:<\/span> <span class=\"shcb-language__name\">HTML, XML<\/span> <span class=\"shcb-language__paren\">(<\/span><span class=\"shcb-language__slug\">xml<\/span><span class=\"shcb-language__paren\">)<\/span><\/small><\/pre>\n\n\n<p>So, to change the HTML attribute <code>disabled<\/code> you have to use the property <code>setAttribute<\/code>, then use <code>removeAttribute<\/code>\u00a0to re-enable the button.<\/p>\n\n\n<pre class=\"wp-block-code\" aria-describedby=\"shcb-language-5\" data-shcb-language-name=\"JavaScript\" data-shcb-language-slug=\"javascript\"><span><code class=\"hljs language-javascript\"><span class=\"hljs-comment\">\/\/ Disabling a button using setAttribute<\/span>\nbutton.setAttribute(<span class=\"hljs-string\">\"disabled\"<\/span>, <span class=\"hljs-string\">\"\"<\/span>);\n\n<span class=\"hljs-comment\">\/\/ Re-enabling a disabled button by removing the \"disabled\" property<\/span>\nbutton.removeAttribute(<span class=\"hljs-string\">\"disabled\"<\/span>);<\/code><\/span><small class=\"shcb-language\" id=\"shcb-language-5\"><span class=\"shcb-language__label\">Code language:<\/span> <span class=\"shcb-language__name\">JavaScript<\/span> <span class=\"shcb-language__paren\">(<\/span><span class=\"shcb-language__slug\">javascript<\/span><span class=\"shcb-language__paren\">)<\/span><\/small><\/pre>\n\n\n<h2 class=\"wp-block-heading\" id=\"references\">References<\/h2>\n\n\n\n<ul class=\"wp-block-list\">\n<li><a href=\"https:\/\/developer.mozilla.org\/en-US\/docs\/Web\/API\/HTMLSelectElement\/disabled\" rel=\"nofollow noopener\" target=\"_blank\"><code>disabled<\/code> JavaScript property<\/a><\/li>\n\n\n\n<li><a href=\"https:\/\/developer.mozilla.org\/en-US\/docs\/Web\/HTML\/Attributes\/disabled\" rel=\"nofollow noopener\" target=\"_blank\">Disabled HTML attribute (MDN Web Docs)<\/a><\/li>\n<\/ul>\n\n\n\n<h2 class=\"wp-block-heading\" id=\"related-articles\">Related articles<\/h2>\n\n\n\n<ul class=\"wp-block-list\">\n<li><a href=\"https:\/\/alvarotrigo.com\/blog\/javascript-alert\/\">JavaScript Alert (Examples and Usage)<\/a><\/li>\n\n\n\n<li><a href=\"https:\/\/alvarotrigo.com\/blog\/best-way-learn-javascript\/\">The Best Way to Learn JavaScript<\/a><\/li>\n\n\n\n<li><a href=\"https:\/\/alvarotrigo.com\/blog\/learn-javascript\/\">How long does it take to learn JavaScript?<\/a><\/li>\n<\/ul>\n","protected":false},"excerpt":{"rendered":"<p>How to disable a button using only JavaScript. Tutorial for beginners. Examples included<\/p>\n","protected":false},"author":1,"featured_media":4951,"comment_status":"open","ping_status":"closed","sticky":false,"template":"","format":"standard","meta":{"_acf_changed":false,"footnotes":""},"categories":[107],"tags":[16,25,10,17],"class_list":["post-4952","post","type-post","status-publish","format-standard","has-post-thumbnail","hentry","category-javascript","tag-design","tag-html","tag-javascript","tag-web"],"acf":[],"_links":{"self":[{"href":"https:\/\/alvarotrigo.com\/blog\/wp-json\/wp\/v2\/posts\/4952","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/alvarotrigo.com\/blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/alvarotrigo.com\/blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/alvarotrigo.com\/blog\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/alvarotrigo.com\/blog\/wp-json\/wp\/v2\/comments?post=4952"}],"version-history":[{"count":7,"href":"https:\/\/alvarotrigo.com\/blog\/wp-json\/wp\/v2\/posts\/4952\/revisions"}],"predecessor-version":[{"id":14941,"href":"https:\/\/alvarotrigo.com\/blog\/wp-json\/wp\/v2\/posts\/4952\/revisions\/14941"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/alvarotrigo.com\/blog\/wp-json\/wp\/v2\/media\/4951"}],"wp:attachment":[{"href":"https:\/\/alvarotrigo.com\/blog\/wp-json\/wp\/v2\/media?parent=4952"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/alvarotrigo.com\/blog\/wp-json\/wp\/v2\/categories?post=4952"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/alvarotrigo.com\/blog\/wp-json\/wp\/v2\/tags?post=4952"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}