将 CSS 应用于具有 onclick 事件的类

发布于 2025-01-08 07:07:17 字数 1379 浏览 1 评论 0原文

我的页面左侧有一个由嵌套 ul 组成的菜单。在我的页面右侧,我有一系列内容 div,它们都有一个与左侧菜单链接相对应的类。当您单击左侧的菜单链接时,它需要隐藏我的所有内容 div,然后仅显示具有相应类的内容。因此,如果您单击“实现/系统开发”链接,页面将首先隐藏类“content”的所有 div,然后显示类“content5”的所有 div。

更复杂的是,菜单在 ul 上附加了一些 javascript,用于显示和隐藏嵌套菜单。我不想碰它或干扰它,因为它有效。另外,我认为它不能解决我的问题,因为它会监视所有菜单项,而且我不知道如何将一个菜单项操作与该一般功能联系起来。

我认为我需要的是添加一个 onclick 事件,将所有内容 div 的显示设置为无,并将子集设置为阻止。菜单是在服务器端生成的,因此我可以向其添加属性。

我的思考过程是菜单链接到的机会:

<a href="#" onclick="swap_content(content5)">Implementation/System development</a>

然后使用更改 css 的代码,例如:

swap_content([target]){
    div.content{ display:none;}
    div.[target]{ display:block;}
}

这样它会隐藏所有当前显示的内容,然后仅显示与该链接相关的内容。

<div class='content content26 content27 content28 content29 content30'></div>
  1. 使用 onclick 会干扰扩展/折叠吗 jquery?我认为开场和闭场取决于观看 ul 的类、ul.menu1、ul.menu2 等,因为没有 onclick 事件。
  2. 我想不出一种方法将链接与 它是服务器端的目标内容,而不是显式传递 它到 onclick 中的 swap_content 函数。

我对 javascript 完全陌生,所以这可能完全是愚蠢的,但任何帮助或指导将不胜感激。如果您想查看的话,测试页面位于此处。在示例中,内容 div 已设置为 display:none;

驱动菜单打开和关闭的代码位于 http://nwi.pdx .edu/jQueryScripts/pubs-search-script.js 但就像我说的,它有效,我真的不想太多地接触它。

I have a menu on the left of my page that is made of nested uls. On the right of my page I have a series of content div's that all have a class that corresponds with the menu link on the left. When you click a menu link on the left it needs to hide all of my content divs, then show only those that have the corresponding class. So if you click the link "Implementation/System development" the page will first hide all divs of class "content", then show all divs of class "content5".

As a complication to this the menu has some javascript attached to the ul's that show and hide the nested menues. I don't want to touch it or interfere with it because it works. Also I don't think it would be usable to solve my problem because it watches all menu li's and I don't know how to tie one menu items action to that general function.

What I think I need is to add an onclick event that sets the display of all my content divs to none, and sets a subset to block. The menu is generated server side, so I can add attributes to it.

My thought process is chance the menu links to:

<a href="#" onclick="swap_content(content5)">Implementation/System development</a>

Then have code that changes the css like:

swap_content([target]){
    div.content{ display:none;}
    div.[target]{ display:block;}
}

That way it hides all the currently displayed content then only shows the content tied to that link.

<div class='content content26 content27 content28 content29 content30'></div>
  1. Will using onclick interfere with the expanding/collapsing from
    jquery? I think that the opening and closing rely on watching the
    class of the ul's, ul.menu1, ul.menu2 and so on since there are no
    onclick events.
  2. I can't think of a way to associate the link with
    it's target content on the server side other than explicitly passing
    it to the swap_content function in the onclick.

I am completely new to javascript so this may be completely boneheaded, but any help or guidance would be appreciated. The test page is up here if you want to take a look. In the example the content divs are already set to display:none;.

The code driving the opening and closing of the menu is at http://nwi.pdx.edu/jQueryScripts/pubs-search-script.js but like I said, it works, I really don't want to touch it all that much.

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

奢望 2025-01-15 07:07:17

首先将 div 的显示属性及其中的所有内容设置为“继承”。

将它们全部放入容器中,例如 span 或 div 标签,然后在该 span 或 div 中添加以下代码:

onclick="style.display = 'none'"

这将隐藏该标签中的所有内容 您

更新:给包含所有要隐藏 id 的 div 的标签,例如 id =“thing”。

的隐藏函数应该类似于:

function hide ()
 {
  document.getElementById("thing").style.display = "none";
 }

然后在您想要的项目上。单击以实现添加

onclick="hide()"

更新 需要做的很多事情:您可以使用 JavaScript 的 JQuery 库通过执行以下操作来按类进行选择:

$(."hider").click(function(){$(".myClass").css("display","none");});

其中 myClass 是您的类的名称,hider 是您单击以使其发生的任何内容的类 另外,如果您这样做的话(。还有其他几种方法可以使用类选择器来完成此操作)从隐藏器中删除 onclick 函数。

First set the display propert of the divs and all content in them to "inherit.

From that put them all in a container such as a span or div tag then in that span or div add the following code:

onclick="style.display = 'none'"

That will hide everything in that tag that inherits the display property from it.

Update: give the tag that contains all the divs that you want to hide an id such as id = "thing".

Your hide function should look something like:

function hide ()
 {
  document.getElementById("thing").style.display = "none";
 }

then in your html on the item you want to click to make it happen add

onclick="hide()"

Update Numerou Dos: You can use JavaScript's JQuery library to select by class by doing something like:

$(."hider").click(function(){$(".myClass").css("display","none");});

Where myClass is the name of your class and hider is the class of whatever it is your clicking to make it happen. Also if you do it this way (there's a couple others ways to do it using class selectors) remove the onclick function from your hider.

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文