默认值:带CSS的目标

16 html css css-selectors css3

我有这个CSS:

<style type="text/css">
.tab {
  display: none;
}
.tab:target {
  display: block;
}
</style>
Run Code Online (Sandbox Code Playgroud)

这个HTML:

<div class="tab_container">

  <ul class="tabs">
    <li><a href="#updates-list">List</a></li>
    <li><a href="#updates-map">Map</a></li>
  </ul>

  <ul class="tab list" id="updates-list">
    Eh.. Hello!
  </ul>
  <div class="tab map" id="updates-map"></div>
</div>
Run Code Online (Sandbox Code Playgroud)

但是,如果未#指定目标(在URL中)并且尚未单击任何选项卡,则我的页面为空.我想ul#updates-list默认显示.

我怎样才能做到这一点?谢谢.


更新:在此旁边,如果Google地图不是初始目标,我的Google地图就会被破坏.有谁知道修复?

RoT*_*oRa 21

我不得不说,我能想到的唯一解决方案是使用JavaScript.就像是:

<script type="text/javascript">
  if (document.location.hash == "" || document.location.hash == "#")
    document.location.hash = "#updates-list";
</script>
Run Code Online (Sandbox Code Playgroud)

编辑:

好的,有一个CSS解决方案.但是,这需要将默认条目#updates-list放在最后(#updates-map您可以添加之后和任何其他选项卡):

.tab, .tab:target ~ #updates-list  {
  display: none;
}
#updates-list, .tab:target {
  display: block;
}
Run Code Online (Sandbox Code Playgroud)

  • `#updates-list`是默认值,因为这是我在规则`#updates-list,.tab:target {...}`中指定的内容.`.tab`是选项卡内容的类而不是选项卡本身 - 将我的CSS与问题中的CSS进行比较. (2认同)
  • 以上我的解决方案基于与其内容分开的选项卡.首先是标签,然后是内容.你的代码有标签和内容混淆,所以它不能应用,你需要一个完全不同的解决方案,没有时间考虑现在...... (2认同)

qco*_*ter 5

我知道这是一个老问题,但它仍然相关,我还有另一个建议:

<a href="#tab1">Tab 1</a>
<a href="#tab2">Tab 2</a>

<a id="tab1"></a>
<a id="tab2"></a>

<div class="tab tab1 default-tab">Some content</div>
<div class="tab tab2">Some other content</div>
Run Code Online (Sandbox Code Playgroud)

和CSS:

.tab {display:none}

.default-tab {display:block}

:target ~ .default-tab {display:none}

#tab1:target ~ .tab1,
#tab2:target ~ .tab2 {
  display: block
}
Run Code Online (Sandbox Code Playgroud)

这使您可以根据需要对选项卡进行排序,但是如果您动态生成 html,则需要动态生成 css。或者在编写 css 时选择要支持的最大标签数。