可以将文章内容翻译成中文,广告屏蔽插件可能会导致该功能失效(如失效,请关闭广告屏蔽插件后再试):
问题:
I would like to alternate list-style-type properties for ul lists, so that the outer is a disc, then one inner ul list is a circle, than one more inner is a disc, and so on.
Essentially, what I want is this:
<ul><!-- use disc -->
<li>Lorem ipsum</li>
<li>
<ul><!-- use circle -->
<li>Lorem ipsum</li>
<li>
<ul><!-- use disc -->
<li>Lorem ipsum</li>
</ul>
</li>
<li>Lorem ipsum</li>
</ul>
</li>
<li>Lorem ipsum</li>
</ul>
How would I accomplish this using CSS?
回答1:
Like this...
li { list-style: circle; }
li li { list-style: disc; }
li li li { list-style: square; }
And so on...
The first level of list items will have the "circle" type marker. The second (embedded) will use "discs". The third level will use squares.
Simply take the above CSS and change the list-style
to suit your needs. You can find a list of list-style
types here: http://www.w3schools.com/cssref/pr_list-style-type.asp
回答2:
You could use separate styles by adding class
or id
to the ul
tags:
<ul class="disk"><!-- use disk -->
<li>Lorem ipsum</li>
<li>
<ul class="circle"><!-- use circle -->
<li>Lorem ipsum</li>
<li>
<ul class="disk"><!-- use disk -->
<li>Lorem ipsum</li>
</ul>
</li>
</ul>
</li>
</ul>
.disk
{
list-style-type: disc;
}
.circle
{
list-style-type: circle;
}
Or you could add styles to ul
s depending on how they are nested:
ul
{
list-style-type:disc;
}
ul li ul
{
list-style-type:circle;
}
ul li ul li ul
{
list-style-type:disc;
}
Off the top of my head, so there might be some minor errors, but both these examples should basically work.
回答3:
It's best to give each element with different bullet type a class name.
<ul>
<li class="disk">test</li>
<li class="circle">test</li>
<li class="sq">test</li>
<li class="sq">test</li>
</ul>
.disk {
list-style-type: disc;
}
.circle {
list-style-type: circle;
}
.sq {
list-style-type: square;
}
Check working example at http://jsfiddle.net/LWQrh/
回答4:
I have found the reason why I get double bullets. My lists are not semantically correct, so they are creating multiple bullets.
This is the proper HTML:
<ul><!-- use disc -->
<li>Lorem ipsum
<ul><!-- use circle -->
<li>Lorem ipsum
<ul><!-- use disc -->
<li>Lorem ipsum</li>
</ul>
</li>
<li>Lorem ipsum</li>
</ul>
</li>
<li>Lorem ipsum</li>
</ul>
With the fixed code, the solutions above work.
回答5:
The simple answer to this one is no, it cannot be accomplished through CSS in a consistent manner.
You could write some javascript to parse through the page and basically maintain a stack of ULs, but it would be kind of sloppy and hackish. It'd have to be something like this.
function doStyle(htmlBlock, depth)
var returnHtml = '';
// While the HTML block presented has UL tags within it
while(htmlBlock.indexOf('<ul>') > 0) {
// Take all the content up to the next/first <UL>
returnHtml += htmlBlock.substring(0, htmlBlock.indexOf('<ul>'));
// Add a styled <UL>, alternating on depth
returnHtml += '<ul class="' + (depth % 2 == 0 ? 'square' : 'circle') + '">';
// Recurse on the content inside that UL, using depth + 1
returnHtml += doStyle(htmlBlock.substring(htmlBlock.indexOf('<ul>'), htmlBlock.indexOf('</ul>')), depth + 1);
// Close the <UL>
returnHtml += '</ul>';
// Pull the whole UL block out of the remaining string
htmlBlock = htmlBlock.substring(htmlBlock.indexOf('</ul>') + 5);
}
// Return the built up string,
// And whatever is left of the original HTML block
return returnHtml + htmlBlock;
}