需要有关圆角的jquery插件的建议

时间:2009-06-20 01:11:11

标签: jquery css jquery-plugins

我想学习jquery插件,所以我决定尝试制作一个简单的圆角盒。我知道那里已经有一些圆角插件,但这对我来说比工作要求更像是一种学习练习。

我从here获得的圆角。我喜欢这个样本,因为它不使用图像,很容易改变盒子的颜色。

我想我无法绕着最好的方式缠绕我的大脑。我有一个非常粗略的样本,它有点工作,但它感觉不对。让我兴奋的部分是在内容区域周围构建圆角。现在它需要“内容”框并附加它周围的角落。有什么更好的方法呢?

这是打电话的方式 - $('#content')。roundbox();

如果这还不够,请告诉我。

//
(function($)
{
jQuery.fn.roundbox = function(options)
{

    var opts = $.extend({}, $.fn.roundbox.defaults, options);

    var outer = $("<div>");
    var topBorder = $("<b class='xtop'><b class='xb1'></b><b class='xb2'></b><b class='xb3'></b><b class='xb4'></b></b>");
    var bottomBorder = $("<b class='xbottom'><b class='xb4'></b><b class='xb3'></b><b class='xb2'></b><b class='xb1'></b></b>");
    var title = $("<h1>Select Funding</h1>");
    var separator = $("<div></div>");

    $(this).append(title);
    $(this).append(separator);

    var firstElement = $(this).children()[0];
    if (firstElement != null)
    {
        title.insertBefore(firstElement);
        separator.insertBefore(firstElement);
    }

    outer.append(topBorder);
    outer.append($(this));
    outer.append(bottomBorder);

    $("#fundingAdminContainer").append(outer);


    //Add classes
    outer.addClass(opts.outerClass); //outer container
    $(this).addClass(opts.contentClass); //inner content
    title.addClass(opts.titleClass); //roundbox title
    separator.addClass(opts.lineClass); //line below title
};

$.fn.roundbox.defaults =
{
    outerClass: 'roundbox',
    contentClass: 'roundboxContent',
    titleClass: 'roundboxTitle',
    lineClass: 'roundboxLine'
};


})(jQuery);


//CSS
.roundbox
{
float:left;
width:400px;
margin-right:20px;
}

.roundboxContent
{
display:block;
background:#ffffff;
border:0 solid #D4E2FE;
border-width:0 1px;
height:180px;
padding:10px;
}

.roundboxLine
{
background: url(../images/fundingAdmin_line.gif);
background-repeat:no-repeat;
height:5px;
}

.roundboxTitle
{
font-size:1.3em; color:#17A2D3;
}

.xtop, .xbottom {display:block; background:transparent; font-size:1px;}
.xb1, .xb2, .xb3, .xb4 {display:block; overflow:hidden;}
.xb1, .xb2, .xb3 {height:1px;}
.xb2, .xb3, .xb4 {background:#ffffff; border-left:1px solid #D4E2FE; border-right:1px solid #D4E2FE;}
.xb1 {margin:0 5px; background:#D4E2FE;}
.xb2 {margin:0 3px; border-width:0 2px;}
.xb3 {margin:0 2px;}
.xb4 {height:2px; margin:0 1px;}

框的最终结构应为:

<div id="fundingAdminContainer"><!-- Not part of rounded box, just serves as a container. -->
    <div class="roundbox">
        <b class="xtop"><b class="xb1"></b><b class="xb2"></b><b class="xb3"></b><b class="xb4"></b></b>
        <div id="content" class="roundboxContent">
            <h1 class="roundboxTitle">Title</h1>
            <div class="roundboxLine"></div>
                //CONTENT
        </div>
        <b class="xbottom"><b class="xb4"></b><b class="xb3"></b><b class="xb2"></b><b class="xb1"></b></b>
    </div>
</div>

5 个答案:

答案 0 :(得分:2)

http://www.curvycorners.net/ http://www.curvycorners.net/

javascript库,不是jQuery插件,但似乎有效:D

答案 1 :(得分:1)

你这样做的方式对我来说似乎很好。我不会硬编码资金。

您可以将标题和分隔符设置为该功能的选项,而不是附加到#fundingAdminContainer,您可以

outer.insertBefore($(this));

在将$(this)附加到外部之前。

编辑:这个答案现在很老了,我说过时了。大多数浏览器现在通过CSS border-radius属性或至少是特定于浏览器的替代方案支持圆角。我也说在大多数情况下,对于不支持CSS的旧浏览器(当然是那种观点),对于填充四舍五入角所需的额外j值是不值得的。所以,如果我要给出一个完整的答案,我会说只需使用this并按照它告诉你的那样做:)。

但是如果你真的想在&lt; IE9中使用圆角,我会建议像this这样的东西,这样你仍然可以在大多数浏览器中单独使用CSS,并且只有IE必须做任何额外的工作(在一个htc文件)绕过角落。

唯一的问题是htc文件也已过时,应该修改以使用类似this的内容检查border-radius是否存在。 HTC只是JS。这将减轻IE9必须进行JS DOM操作。

答案 2 :(得分:1)

这是另一种jquery弯角插件

http://labs.parkerfox.co.uk/cornerz/

答案 3 :(得分:1)

这个很棒:

http://jrc.rctonline.nl/

它使用Canvas,因此它非常灵活。

答案 4 :(得分:0)

这个 jQuery Corner插件可能会有所帮助。易于使用且令人惊叹。

http://jquery.malsup.com/corner/

用法

$('#myDiv').corner();