首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >找到更好的方法- jquery

找到更好的方法- jquery
EN

Stack Overflow用户
提问于 2013-10-09 14:17:46
回答 3查看 42关注 0票数 1

我知道我的选择器会有1级,2级,3级。

我想在此基础上设定水平,但我的方式有点笨重?有更整洁的方法吗?

代码语言:javascript
复制
if ( $level.hasClass('level-2')) {
    $levelValue= "level2";
}
if( $level.hasClass('level-3')) {
    $levelValue = "level3";
}

if ( $level.hasClass('level-4')) {
    $levelValue= "level4";
}

编辑:对不起,我错了,

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2013-10-09 14:20:00

用这个:

代码语言:javascript
复制
if($level.is('.level-2, .level-3, .level-4')){
    $level = "level2";
}

它使用jQuery的.is()函数并检查$level是否有任何类。

更新:尝试使用以下内容:

代码语言:javascript
复制
if($level.is('[class^="level"]')){
    $levelValue = $level.attr('class').match(/level-[0-9]*/); // e.g. 'level-2'
}

在这里,它正在工作:http://jsfiddle.net/rE3bL/1/

票数 2
EN

Stack Overflow用户

发布于 2013-10-09 14:21:55

是否有与每个级别相关联的样式规则?如果只是数据,我会使用像data-level='2'这样的数据属性,那么您可以通过使用jQuery函数:$level.data('level')来访问它

票数 0
EN

Stack Overflow用户

发布于 2013-10-09 14:31:28

$level是什么?迪夫?如果您希望将$level设置为"level1“、"level2”和"level3“(而不是每次使用代码中的"level2”),则可以使用数据attr:

代码语言:javascript
复制
<div class="level1" data-level="1">
<div class="level2" data-level="2">
<div class="level3" data-level="3">

你的js就像:

代码语言:javascript
复制
$level = $level.data("level") //will return "1","2" or "3"
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/19274613

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档