Jquery 代码简化
我对 jQuery 相当陌生,我正在尝试找出一种简化/优化我的代码的方法,因为现在它可以工作,但我只知道有一种更有效的方法可以做到这一点。
$(".th_s3studios_layout").click(function(){
$("#portfolio_home").fadeOut(500);
// Fading in the project page
$("#th_s3studios_layout").delay(1000).fadeIn(500);
});
$(".th_mangafan_layout").click(function(){
$("#portfolio_home").fadeOut(500);
// Fading in the project page
$("#th_mangafan_layout").delay(1000).fadeIn(500);
});
$(".th_356_P3").click(function(){
$("#portfolio_home").fadeOut(500);
// Fading in the project page
$("#th_356_P3").delay(1000).fadeIn(500);
});
$(".th_hrycyna_layout").click(function(){
$("#portfolio_home").fadeOut(500);
// Fading in the project page
$("#th_hrycyna_layout").delay(1000).fadeIn(500);
});
下面是一些与之配套的相应 HTML 标记。
<div class="col_16" id="portfolio_home">
<div class="col_04 folio"><div class="th_s3studios_layout">Content 1</div></div>
<div class="col_04 folio"><div class="th_mangafan_layout">Content 2</div>
</div>
<div class="col_16" id="th_s3studios_layout"
<div class="col_04 folio"><div class="preview1">Pop up stuff for content 1</div></div>
<div class="col_04 folio"><div class="preview2">Pop up stuff for content 1</div></div>
</div
<div class="col_16" id="th_mangafan_layout"
<div class="col_04 folio"><div class="preview1">Pop up stuff for content 2</div></div>
<div class="col_04 folio"><div class="preview2">Pop up stuff for content 2</div></div>
</div
您可以看到该函数基本上淡出一个框并淡入另一个框。您可以看到它淡入的框始终与 .click 函数同名,只是它是一个单独的 CSS id 容器而不是一个类。我认为必须有一种方法为每个函数创建一个共享函数,以某种方式将类的名称更改为与函数的相同名称匹配的 id,并重新使用其余的代码。谁能帮我解释一下吗?
I'm rather new to jQuery and I'm trying to figure out a way to simplify/optimize my code, because right now it works but I just know there is a more efficient way of doing this.
$(".th_s3studios_layout").click(function(){
$("#portfolio_home").fadeOut(500);
// Fading in the project page
$("#th_s3studios_layout").delay(1000).fadeIn(500);
});
$(".th_mangafan_layout").click(function(){
$("#portfolio_home").fadeOut(500);
// Fading in the project page
$("#th_mangafan_layout").delay(1000).fadeIn(500);
});
$(".th_356_P3").click(function(){
$("#portfolio_home").fadeOut(500);
// Fading in the project page
$("#th_356_P3").delay(1000).fadeIn(500);
});
$(".th_hrycyna_layout").click(function(){
$("#portfolio_home").fadeOut(500);
// Fading in the project page
$("#th_hrycyna_layout").delay(1000).fadeIn(500);
});
Here is some corresponding HTML markup that goes with it.
<div class="col_16" id="portfolio_home">
<div class="col_04 folio"><div class="th_s3studios_layout">Content 1</div></div>
<div class="col_04 folio"><div class="th_mangafan_layout">Content 2</div>
</div>
<div class="col_16" id="th_s3studios_layout"
<div class="col_04 folio"><div class="preview1">Pop up stuff for content 1</div></div>
<div class="col_04 folio"><div class="preview2">Pop up stuff for content 1</div></div>
</div
<div class="col_16" id="th_mangafan_layout"
<div class="col_04 folio"><div class="preview1">Pop up stuff for content 2</div></div>
<div class="col_04 folio"><div class="preview2">Pop up stuff for content 2</div></div>
</div
You can see the function basically fades out one box and fades in another. You can see that the box it fades in is always the same name as the .click function, except it's a separate CSS id container and not a class. I figure there must be a way to create a shared function for each of these that somehow changes the the name of the class to an id matching the same name of the function, and re-uses the rest of the code. Can anyone help me shed some light on this?
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(4)
试试这个代码:
Try this code:
无需查看您的 HTML 或修改您的 HTML,这是一种有效的方法,即使您单击的项目上有多个类名:
如果我们可以查看您的 HTML 并向您的 HTML 添加类,那么就可以完成甚至更简单。
例如,如果单击的对象只有一个类,则可以这样做:
Without seeing your HTML or modifying your HTML, this is one way to do it that works even if your clicked on items have more than one class name on them:
If we could see your HTML and add classes to your HTML, it could be done even simpler.
For example, if you only have one class on the clicked objects, it could be done like this:
这个 JS 怎么样:
并向您的元素添加另一个类,例如
th_s3studios_layout
:How about this JS:
And add another class to your elements, for example for
th_s3studios_layout
:如果有多个类,并且您的元素(例如 div)是这样的:
无需使用与 id 相同的名称来命名类。
做类似的事情:
In case of multiple classes, and if your element (div for example) is like that :
No need to name the class with the same as the id.
Do something like that :