超级好用的jQuery圆角插件 Corner速成


Posted in Javascript onAugust 31, 2014

jQuery Corner是一款jQuery的插件,最初由Dave Methvin开发,但后在Malsup同志的协助下,进行了一些重要的改进。现在项目放在github上,当然为了方便,本文会以附件的形式提供该插件,但要想得到最新版,请到项目的github上拿。
之所以会像变魔术一样地展现圆角及其他样式,是由于该插件为目标元素增加了一些小条块,这些小条块为背景色,所以人眼看上去出现了圆角而已,其实就是小东西遮盖了本来的直角。

看来我真不是干魔术师的料,一上来就先把老底给揭了出来。不急,我再补充一下,这个魔术的一些要求:

1、插件专为block元素编写,所以div、p等均适用;而inline的元素则没有那么幸运了,当然也不是说inline根本不能用,只是面对为span增加corner要多费点神。不过,正常人不会和span的圆角较劲吧,把span改成div得了。
2、对于插件新增的border-radius功能,IE<=8全体不支持,除了IE外全体浏览器都支持。娘的,再对自己国度IE6泛滥的现状深切鄙视一下。

OK,介绍完了基本要点。教大家如何使用,这是重点,但很简单。 第一步,构建基本HTML网页和DIV格局,并CSS。

<html>
<head>
<style type="text/css">
div{
width:350px;
height:200px;
background-color: #6af;
}
</style>
</head>
<body>
<div></div>
</body>
</html>

效果如下:

超级好用的jQuery圆角插件 Corner速成

第二步,引入jQuery,和jQuery Corner插件。

<html>
<head>
<script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1.4.2/jquery.min.js"></script>
<script type="text/javascript" src="js/jquery.corner.js"></script>

<style type="text/css">
div{
width:350px;
height:200px;
background-color: #6af;
}
</style>
</head>
<body>
<div>

</div>
</body>
</html>

此时,还是刚才图的效果,直角没变。
第三步,写js代码,让插件对DIV块起作用。

<html>
<head>
<script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1.4.2/jquery.min.js"></script>
<script type="text/javascript" src="js/jquery.corner.js"></script>
<script type="text/javascript">
$(function(){
$("div").corner();

});
</script>
<style type="text/css">
div{
width:350px;
height:200px;
background-color: #6af;
}
</style>
</head>
<body>
<div>

</div>
</body>
</html>

此时,圆角就出现了。

超级好用的jQuery圆角插件 Corner速成
至此,小功告成。开始拓展拔高啦。

********************************拓展************************************

一、有多种Corner可选超级好用的jQuery圆角插件 Corner速成

如果你喜欢凹状,那么上图第一排,第三列就是好选择。先认识个单词notch,就是凹槽的意思。只需把一处代码改成:

<script type="text/javascript">
$(function(){
$("div").corner("notch");

});
</script>

 就可以得到这个效果:

超级好用的jQuery圆角插件 Corner速成
这里出现了明显的问题,当前在chrome下只有一个角。在IE下也不正常。滴答滴答,时间经过了近半个小时。我终于发现:
应该给有角的Div加一个父Div,否则我自己做的例子中父级为body,而插件自己还要再增加一个Div,就弄乱套了。所以我修改了最初的代码:

<html>
<head>
<script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1.4.2/jquery.min.js"></script>
<script type="text/javascript" src="js/jquery.corner.js"></script>
<script type="text/javascript">
$(function(){
$("#mydiv").corner('bevel');
});
</script>
<style type="text/css">
#mydiv{
width:350px;
height:200px;
background-color: #6af;
}
</style>
</head>
<body>
<div>
<div id="mydiv"></div>
</div>
</body>
</html>

 看图吧:

超级好用的jQuery圆角插件 Corner速成 

但有两句话需要大家注意(原文):* Fold lines are not supported in Internet Explorer for pages rendered in quirksmode.* Fold lines are only supported on top corners in Internet Explorer, unless running in IE8 standards-mode. 所以,尽量老老实实地用Corner样式吧。 二、有多种位置可选 可以使用top/bottom/left/right/tl/tr/bl/br设置corner出现的具体位置。看图:超级好用的jQuery圆角插件 Corner速成

比如对于notch而言,想为mydiv的底部增加notch效果,则改写代码如下:

$("#mydiv").corner('bevel bottom');

于是,就只有底部产生notch角了。

超级好用的jQuery圆角插件 Corner速成

三、可自定义角度大小 这功能很好,填写个像素值,就能改变角度。试试吧:

$("#mydiv").corner('bevel bottom 50px');

惊奇的图像如下:

超级好用的jQuery圆角插件 Corner速成
神奇吧,呵呵,还有呢。

四、混搭 就刚才这个例子,把上边两个角变为圆角,而下方仍然不变。看代码:

$("#mydiv").corner('top 30px').corner('bevel bottom 50px');

没错,就是用两句corner。当然你可以完全使用四个corner把各个角都自定义。超级好用的jQuery圆角插件 Corner速成

五、边框装饰 这是亮点,感谢一个名叫Kevin Scholl的家伙提出的这个建议,不过这的确是一个非常棒的提议。看代码吧:

<html>
<head>
<script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1.4.2/jquery.min.js"></script>
<script type="text/javascript" src="js/jquery.corner.js"></script>
<script type="text/javascript">
$(function(){
$("#mydiv p").corner('round 8px').parent().css('padding','8px').corner('round 14px');
});
</script>
<style type="text/css">
#mydiv{
width:360px;
background-color: #600;
}
#mydiv p{
width:350px;
height:200px;
background-color: #6af;
}
</style>
</head>
<body>
<div>
<div id="mydiv"><P></p></div>
</div>
</body>
</html>

就会这样:

超级好用的jQuery圆角插件 Corner速成 

这图是chrome下的效果,IE下还不一样,夜色很晚了,没时间调试深入发现问题的原因。

写的不少了,其实还有些功能样式没说,剩下的也并不常用,用到的时候大家看英文自学吧。

Javascript 相关文章推荐
AutoSave/自动存储功能实现
Mar 24 Javascript
通过身份证号得到出生日期和性别的js代码
Nov 23 Javascript
JavaScript程序设计之JS调试
Dec 09 Javascript
BootStrap Validator使用注意事项(必看篇)
Sep 28 Javascript
Vue.js路由vue-router使用方法详解
Mar 20 Javascript
xmlplus组件设计系列之选项卡(Tabbar)(5)
May 03 Javascript
前端把html表格生成为excel表格的实例
Sep 19 Javascript
基于vue.js 2.x的虚拟滚动条的示例代码
Jan 23 Javascript
用WebStorm进行Angularjs 2开发(环境篇:Windows 10,Angular-cli方式)
Dec 05 Javascript
基于node+websocket+html实现腾讯课堂聊天室聊天功能
Mar 04 Javascript
vue点击标签切换选中及互相排斥操作
Jul 17 Javascript
浅谈vue 组件中的setInterval方法和window的不同
Jul 30 Javascript
Html5的placeholder属性(IE兼容)实现代码
Aug 30 #Javascript
通过js为元素添加多项样式,浏览器全兼容写法
Aug 30 #Javascript
原生js仿jq判断当前浏览器是否为ie,精确到ie6~8
Aug 30 #Javascript
原生js实现复制对象、扩展对象 类似jquery中的extend()方法
Aug 30 #Javascript
ZeroClipboard插件实现多浏览器复制功能(支持firefox、chrome、ie6)
Aug 30 #Javascript
仿百度联盟对联广告实现代码
Aug 30 #Javascript
jQuery针对各类元素操作基础教程
Aug 29 #Javascript
You might like
PHP安全防范技巧分享
2011/11/03 PHP
用PHP即时捕捉PHP中的错误并发送email通知的实现代码
2013/01/19 PHP
CodeIgniter配置之config.php用法实例分析
2016/01/19 PHP
PHP文件操作详解
2016/12/30 PHP
PHP实现UTF8二进制及明文字符串的转化功能示例
2017/11/20 PHP
PHP crypt()函数的用法讲解
2019/02/15 PHP
js 效率组装字符串 StringBuffer
2009/12/23 Javascript
JavaScript DOM学习第六章 表单实例
2010/02/19 Javascript
Js表格万条数据瞬间加载实现代码
2014/02/20 Javascript
AJAX实现瀑布流触发分页与分页触发瀑布流的方法
2016/05/23 Javascript
jquery模拟多级复选框效果的简单实例
2016/06/08 Javascript
jQuery中ScrollTo用法示例
2016/09/04 Javascript
Angular2 Service实现简单音乐播放器服务
2017/02/24 Javascript
AngularJS学习笔记之表单验证功能实例详解
2017/07/06 Javascript
ES6学习教程之对象字面量详解
2017/10/09 Javascript
vue 子组件向父组件传值方法
2018/02/26 Javascript
nodejs微信开发之自动回复的实现
2019/03/17 NodeJs
Javascript查看大图功能代码实现
2020/05/07 Javascript
[00:26]TI7不朽珍藏III——冥界亚龙不朽展示
2017/07/15 DOTA
Python异常处理知识点总结
2019/02/18 Python
基于python计算并显示日间、星期客流高峰
2020/05/07 Python
python利用蒙版抠图(使用PIL.Image和cv2)输出透明背景图
2020/08/04 Python
Python Pillow(PIL)库的用法详解
2020/09/19 Python
纯css3(无图片/js)制作的几个社交媒体网站的图标
2013/03/21 HTML / CSS
HTML5头部标签的一些常用信息小结
2016/10/23 HTML / CSS
AmazeUI在模态框中嵌入表单形成模态输入框
2020/08/20 HTML / CSS
美国农场鲜花速递:The Bouqs
2018/07/13 全球购物
AVI-8手表美国官方商店:AVI-8 USA
2019/04/10 全球购物
团员的自我评价
2013/12/01 职场文书
财务部副经理岗位职责
2014/03/14 职场文书
保护环境演讲稿
2014/05/10 职场文书
个人对照检查剖析材料
2014/10/13 职场文书
2014年宣传思想工作总结
2014/12/10 职场文书
教师党员承诺书2015
2015/01/21 职场文书
2019年国庆祝福语(70句)
2019/09/19 职场文书
golang连接MySQl使用sqlx库
2022/04/14 Golang