【转载】使用VML技术实现圆角表格的绘制

前两天论坛看到有人问关于圆角表格的制作,这已经是老生常谈了,CSS、图片都可以,其实如果只是 IE 浏览有更好的方法,就是 VML,中午有空,把东西整理了一下。
引用
首发 http://blog.eliuzd.com/ 网络转载请保留出处,传统媒体与本站联系。
先看效果图:

uploads/200603/29_135850_1.png


代码:
<html xmlns:v="urn:schemas-microsoft-com:vml">

<head>
<style>
v/:* {behavior: url(#default#VML);}
</style>
</head>

<body>
<v:RoundRect style="width:200;height:100px">
<v:shadow on="true" type="single" color="#b3b3b3" offset="5px,5px"/>
<v:textbox style="font-size:12px">

<div>圆角表格显示效果<br /><br /><a href="http://blog.eliuzd.com/">http://blog.eliuzd.com/</a></div>

</v:textbox>
</v:RoundRect>
</body>

</html>

实现代码很简单,主要就是用到了微软的VML技术(代码里的 xmlns:v 相关部分):

首先我们解释以下什么是VML?

VML的全称是Vector Markup Language( 矢量可标记语言
VML可以理解为是IE里面的画笔工具,可以通过它来实现你所想要画出的图形,而且结合脚本,可以让图形产生动态的效果。VML是微软1999年9月随 IE5.0 一起发布的,也就是说,在 IE5.0+ 里都支持。

在VML里面,使用的是XML扩展标记,需要一个namespace(命名空间),在上面的程序里就是那个“v”
<html xmlns:v="urn:schemas-microsoft-com:vml">

<head>
<style>
v/:* {behavior: url(#default#VML);}
</style>
</head>

这部分代码其实就是把命名空间“v”和系统预定义的行为VML连接。这样定义以后,我们就可以使用下面的标记了,和普通的HTML标记有所区别,每个标记都增加了一个命名空间:

如:<v:shape></v:shape>

“v” 是我们定义的VML,“:” 后面就是VML的对象(shape 是VML最基本的对象,利用它可以画出所有你想要的图形),每个VML对象都有许多属性,这些大家可以查 VML教程 细看,我这里不多说了。

我们看前面的代码:
<body>
<v:RoundRect style="width:200;height:100px">
<v:shadow on="true" type="single" color="#b3b3b3" offset="5px,5px"/>
<v:textbox style="font-size:12px">

<div>圆角表格显示效果<br /><br /><a href="http://blog.eliuzd.com/">http://blog.eliuzd.com/</a></div>

</v:textbox>
</v:RoundRect>
</body>

body 中的内容就是在使用VML对象画图了。

RoundRect:从名字就可以看出,是画个圆角矩形
style=" width:200;height:100px" 设置矩形的长宽

shadow:阴影

uploads/200603/29_140020_2.png


textbox:内容
style=" font-size:12px" 就是设置字体大小,它还有个属性是 print (true/false) 是否被打印机打印。

VML 对象除了自己的属性外,基本支持CSS2样式表的所有样式属性。

我这里只是对就圆角表格对 VML 技术中相关的几个对象做了点介绍,如果有兴趣可以自己查阅相关资料。

但需要注意的是,由于这是微软的技术,除了 IE 之外目前许多浏览器都不支持,比如 Firefox,浏览上面的代码就看不到表格。  
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值