JavaScript 动态创建VML的方法


Posted in Javascript onOctober 14, 2009

要使用VML,我们首先要开辟一个命名空间。以前动态创建比较麻烦
document.namespaces.add('vml', 'urn:schemas-microsoft-com:vml', "#default#VML");
ie8出现后,微软一口气升级了IE6,IE7。创建方法更简单。
document.namespaces.add('vml', 'urn:schemas-microsoft-com:vml');
它们的作用相当于把HTML标签搞成下面这个样子:
<html xmlns:vml="urn:schemas-microsoft-com:vml">
接着就是在样式中调用对应的CSS hehavior。静态代码应该是这个样子:
<style type="text/css">
vml\:* { behavior: url(#default#VML) }
</style>
网上风传IE8对VML支持不友好,要放弃VML云云,主要原因在于“vml\:*”这个选择器被IE8认为不合法(反面证明IE在努力修正其 CSS bug)。由此,人们被迫利用v\:line, v\:rect, v\:roundrect, v\:oval这样子的联合选择器来调用相关的CSS hehavior。不过只要是合法选择器就可以调用CSS hehavior,因此这里用联合选择器实在太累赘了。我想换类选择器是否更合适点呢?试验一下,是无问题的。但仅仅是这样是渲染不出来的,由于IE8已 经重写了内核,因此此bug不是hasLayout可以解决的。官方给出答案是使用display:inline-block,这样就可以强逼它继续渲染了。后来我又发现display:block也有此功效,但考虑到内联元素的问题,还是用官方的补丁吧 。至此,开辟命名空与与渲染VML元素的问题就告一段落。
再来看如何动态创建VML元素,由于是非标准,我们就用非标准的createElement方式来创建它。我们需要拼接一个字符串,作为createElement 的参数,它应该包含命名空间与类名。
var createVML = function (tagName) {
return doc.createElement('<vml:' + tagName + ' class="vml">');
};
随便做了一个小工具,看看后果如何:

function(){ 
if(!window.vml){ 
window.vml = {}; 
document.createStyleSheet().addRule(".vml", "behavior:url(#default#VML);display:inline-block;"); 
if (!document.namespaces.vml && !+"\v1"){ 
document.namespaces.add("vml", "urn:schemas-microsoft-com:vml"); 
} 
} 
var vml = window.vml = function(name){ 
return vml.fn.create(name || "rect"); 
} 
vml.fn = vml.prototype = { 
create : function(name){ 
this.node = document.createElement('<vml:' + name + ' class="vml">'); 
return this; 
}, 
appendTo: function(parent){ 
if(typeof this.node !== "undefined" && parent.nodeType == 1){ 
parent.appendChild(this.node); 
} 
return this; 
}, 
attr : function(bag){ 
for(var i in bag){ 
if(bag.hasOwnProperty(i)){ 
this.node.setAttribute(i,bag[i]) 
} 
} 
return this; 
}, 
css: function(bag){ 
var str = ";" 
for(var i in bag){ 
if(bag.hasOwnProperty(i)) 
str += i == "opacity" ? ("filter:alpha(opacity="+ bag[i] * 100+");"):(i+":"+bag[i]+";") 
} 
this.node.style.cssText = str; 
return this; 
} 
} 
})()

最后附上三种创建VML元素的方法:
var VmlElement = document.createElement('<vml:' + tagName + ' class="vml">'); 
var VmlElement = document.createElement('<' + tagName + ' 
xmlns="urn:schemas-microsoft.com:vml" class="vml">') 
var VmlElement = document.createElement('vml:' + tagName ); 
VmlElement.className = "vml";//最后必须把命名空间当作类名加上

//最后必须把命名空间当作类名加上
Javascript 相关文章推荐
JS 树形递归实例代码
May 18 Javascript
js动态删除div元素基本思路及实现代码
May 08 Javascript
node.js中的fs.symlinkSync方法使用说明
Dec 15 Javascript
JS实现的网页背景闪电闪烁效果代码
Oct 17 Javascript
每天一篇javascript学习小结(Function对象)
Nov 16 Javascript
JS禁用页面上所有控件的实现方法(附demo源码下载)
Dec 17 Javascript
在vue项目中使用sass的配置方法
Mar 20 Javascript
vue2.0 自定义组件的方法(vue组件的封装)
Jun 05 Javascript
浅谈vux之x-input使用以及源码解读
Nov 04 Javascript
vue实现直播间点赞飘心效果的示例代码
Sep 20 Javascript
ES6函数和数组用法实例分析
May 23 Javascript
Vue router安装及使用方法解析
Dec 02 Vue.js
JavaScript读取中文cookie时的乱码问题的解决方法
Oct 14 #Javascript
jQuery 标题的自动翻转实现代码
Oct 14 #Javascript
JavaScript 替换Html标签实现代码
Oct 14 #Javascript
JavaScript null和undefined区别分析
Oct 14 #Javascript
JavaScript iframe的相互操作浅析
Oct 14 #Javascript
使用jQuery简化Ajax开发 Ajax开发入门
Oct 14 #Javascript
jQuery技巧大放送 学习jquery的朋友可以看下
Oct 14 #Javascript
You might like
德劲1104的电路分析与改良
2021/03/01 无线电
用PHP实现的随机广告显示代码
2007/06/14 PHP
PHP 裁剪图片成固定大小代码方法
2009/09/09 PHP
JS关闭窗口与JS关闭页面的几种方法小结
2013/12/17 Javascript
JS获取单击按钮单元格所在行的信息
2014/06/17 Javascript
JS插件overlib用法实例详解
2015/12/26 Javascript
轻松实现jquery手风琴效果
2016/01/14 Javascript
避免jQuery名字冲突 noConflict()方法
2016/07/30 Javascript
最通俗易懂的javascript变量提升详解
2017/08/05 Javascript
JS实现电商放大镜效果
2017/08/24 Javascript
解决iview多表头动态更改列元素发生的错误的方法
2018/11/02 Javascript
在Vue项目中使用snapshot测试的具体使用
2019/04/16 Javascript
微信小程序整合使用富文本编辑器的方法详解
2019/04/25 Javascript
js实现的在本地预览图片功能示例
2019/11/09 Javascript
详解datagrid使用方法(重要)
2020/11/06 Javascript
[51:00]Secret vs VGJ.S 2018国际邀请赛淘汰赛BO3 第一场 8.24
2018/08/25 DOTA
python实现的二叉树算法和kmp算法实例
2014/04/25 Python
将Django使用的数据库从MySQL迁移到PostgreSQL的教程
2015/04/11 Python
全面了解Python的getattr(),setattr(),delattr(),hasattr()
2016/06/14 Python
浅析Python中else语句块的使用技巧
2016/06/16 Python
Python中摘要算法MD5,SHA1简介及应用实例代码
2018/01/09 Python
pandas创建新Dataframe并添加多行的实例
2018/04/08 Python
使用python脚本实现查询火车票工具
2018/07/19 Python
python文件拆分与重组实例
2018/12/10 Python
python列表每个元素同增同减和列表元素去空格的实例
2019/07/20 Python
手把手教你用纯css3实现轮播图效果实例
2017/05/04 HTML / CSS
澳洲CFL商城:CHEMIST FOR LESS(中文)
2021/02/28 全球购物
新员工培训个人的自我评价
2013/10/09 职场文书
四年级数学教学反思
2014/02/02 职场文书
入党积极分子学习优秀共产党员先进事迹思想汇报
2014/09/13 职场文书
2014年扶贫工作总结
2014/11/18 职场文书
员工家属慰问信
2015/03/24 职场文书
2015年实习单位评语
2015/03/25 职场文书
学校青年志愿者活动总结
2015/05/06 职场文书
结婚幸福感言
2015/08/01 职场文书
小学生法制教育心得体会
2016/01/14 职场文书