javascript - jQuery â Hide menu/sidebar when click in the body area -
I'm new to jQuery normally and am trying to work in this sidebar in general and coding in general. When you click on the INFO link, a sidebar opens just as you can just close the sidebar by clicking on the X in the corner, but whenever you click in the body area (but when you click in the sidebar area Do not) still want to be able to close the sidebar. I got to work this way, but then I was not able to open any of my links to see my projects (only another project, Frankenstein Ebook, now has a working link).
Also, why are you able to click on full width rather than X instead of X to close the sidebar?
I have seen a lot of problems here, but never enough to match it very well for mine.
And here's a JSFiddle:
My HTML: / p>
& lt; Div class = "wrap" & gt; & Lt; -! Sidebar - & gt; & Lt ;! - Info panel - & gt; & Lt; Div class = "infopanel" & gt; & Lt; Nav class = "closeBtn" & gt; & Lt; A href = "#" & gt; X & lt; / A & gt; & Lt; / Neo & gt; & Lt; Div class = "infoText" & gt; & Lt; H2 & gt; infoPanel & lt; / H2 & gt; & Lt; P & gt; Copy goes here. & Lt; / P & gt; & Lt; / Div & gt; & Lt; / Div & gt; & Lt; Section square = "sidebar" & gt; & Lt; Div class = "sidebarNav" & gt; & Lt; NAV & gt; & Lt; One class = "infoLink" href = "#" & gt; INFO & lt; / A & gt; & Lt; / Neo & gt; & Lt; / Div & gt; & Lt; Div class = "content" & gt; & Lt; Section class = "project" & gt; & Lt; Div class = "wrapper" & gt; & Lt; Ul square = "grid" & gt; & Lt; Li & gt; & Lt; A href = "prj.html" & gt; & Lt; Div class = "caption" & gt; & Lt; Span & gt; Image go here & lt; / Span & gt; & Lt; / Div & gt; & Lt; Img src = "http://educ.jmu.edu/~diazjr/portfolio_website/images/coming_soon.jpg" /> & Lt; / A & gt; & Lt; / li & gt; & Lt; Li & gt; & Lt; A href = "prj.html" & gt; & Lt; Div class = "caption" & gt; & Lt; Span & gt; Image go here & lt; / Span & gt; & Lt; / Div & gt; & Lt; Img src = "http://educ.jmu.edu/~diazjr/portfolio_website/images/coming_soon.jpg" /> & Lt; / A & gt; & Lt; / li & gt; & Lt; Li & gt; & Lt; A href = "prj.html" & gt; & Lt; Div class = "caption" & gt; & Lt; Span & gt; Images go here & lt; / Span & gt; & Lt; / Div & gt; & Lt; Img src = "http://educ.jmu.edu/~diazjr/portfolio_website/images/coming_soon.jpg" /> & Lt; / A & gt; & Lt; / li & gt; & Lt; Li & gt; & Lt; A href = "prj.html" & gt; & Lt; Div class = "caption" & gt; & Lt; Span & gt; Image go here & lt; / Span & gt; & Lt; / Div & gt; & Lt; Img src = "http://educ.jmu.edu/~diazjr/portfolio_website/images/coming_soon.jpg" /> & Lt; / A & gt; & Lt; / li & gt; & Lt; / Ul & gt; & Lt; / Div & gt; & Lt; / Section & gt; & Lt; / Div & gt; & Lt; / Section & gt;
My JS:
$ (document) .ready (function () {var menu = "close"; $ ('.infoLink') Click (function (if (menu == "close") {$ ('. InfoPanel'). css ('- webkit-conversion', 'translation (0,0)') ; Menu = "open";} and {$ ('. InfoPanel'). CSS ('- WebKit-conversion', 'translation (100%, 0)'); menu = "off";}}); $ ( '($ -' info.panel '). CSS (' webkit-conversion ',' translation (0,0) '); menu = "open";} and {$ ('. InfoPanel '). CSS (' - WebKit-Conversion ',' Translation (100%, 0) '); Menu = "Close";}});});
its Besides, why can you click on the full width to close the sidebar instead of X to X?
Because $ ('. CloseBtn') < Code> div is the code> and no links, instead use $ ('. CloseBtn a') . Anyway, a And need to repeat the quick and dirty way (a bit of refactoring), but the idea is. If you do this work, I will comment on it:
$ (document) .ready (function () {var menu = "close"; var $ infoLink = $ (". InfoLink "); Var $ infoPanel = $ (" InfoPanel "); var $ closeButton = $ (". CloseBtn one "); var $ document = $ (document); $ infoLink.on (" click.nav ", function ( E) Northeast Default (); e.stopPropagation (); Sidebar ("Open");}); closebutton.on ("click.nav", function (e) {e.preventDefault (); e.stopPropagation (); Sidebar ("close");}); $ document.on ("click.nav", function (e) {if (! $ InfoPanel.is (e.target) and $ infoPanel.has (E.target) .length === 0) {sidebar ("off")}}} function sidebar (verb) (Action == "Open") {$ ('InfoPanel'). CSS ('-WebKit-transform', 'translation (0,0)'); menu = "open";} and if (action == "Close") {console.log ("stuff"); $ ('. InfoPanel'). Css ('- webkit-conversion', 'translation (100%, 0)'); menu = "off";}} });
Comments
Post a Comment