• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    脚本动态生成VML
    我们编写 VML 很重要的就是要和 数据库结合,如果和数据库结合了,读数据和把数据转换成 VML 变成了两部分。如果直接使用 ASP 生成 包含很多 VML 的页面,一旦数据量多了,整个页面就变得很庞大,下载速度慢了,IE解释代码的速度也慢了,所以用脚本动态生成 VML 变得非常重要了。

        用 VML 画一个示意图,可以更明确上面的意义:


        前面的图文简单的说就是:使用一个 Iframe 做后台,前台用脚本生成。也许担心,后台已经完成了,但前台还没有初始化的情况,你可以放心,因为读数据的过程肯定相对要慢,如果担心数据量少,只要你把脚本放在 Body 前面,Iframe 放在 Body 的最后面,就不会产生同步错误的问题了。
        现在来具体讲讲如何用脚本动态产生 VML 。其实这和用脚本动态产生 HTML 是一样的过程。

    html xmlns:v="urn:schemas-microsoft-com:vml">
    head>
      title>动态创建VML/title>
    /head>
    STYLE>
     v\:* { BEHAVIOR: url(#default#VML) }
    /STYLE>
    script language="JavaScript">
    function createPoint(x,y,v)
    {
    var strElement="v:rect title='"+v+"' style='top:"+x+";left:"+y+"width:100;height:100'>/v:rect>";
    var newPoint = document.createElement(strElemnt);
    group1.insertBefore(newPoint);
    }
    /script>
    body>
    v:group ID="group1" style="WIDTH:200px;HEIGHT:200px;" coordsize = "200,200">
    /v:group>
    iframe src="readData.asp" name="data" style="display:none">/iframe>
    /body>
    /html>


    相应的在 readData.asp 里面:

    script>
    %
    '数据库连接部分
    '读数据部分
    Do Until rs.EOF
    %>

      parent.createPoint(%=x%>,%=y%>,%=value%>);
    %
    Loop
    '数据库关闭部分
    %>

    /script>

    上面的颜色采用 HomeSite 4.5.2风格

        看完上面的,是否对这种模式有所理解呢?下面谈谈动态生成 VML 所要注意的一些问题,先说说 document 的 createElement 方法。IE版本不同, createElement 的使用也有所区别,在早期版本的IE, createElement 只能创建 Select 里面 OPTION ,比如说 var newOption=document.createElement("OPTION"); 但在 IE5.0 以后,createElement 可以创建所有的对象,使用的方式是 var newElement=document.createElement("div id='oDIV'>/div>"); 注意到没有,这里的参数必须是个完成的 HTML 标记,而不是 DIV,用这个方法的好处就是,可以用一个语句把新创建的对象描述清楚。insertBefore 方法很好用,它把新创建的对象插入到 最后。
        我们一开始就有了 Group1 ,所有以后动态生成的 VML 直接插入到 Group1 的后面就可以了。曾经做了三个实验,第一个是普通的,用ASP生成 VML 代码;第二个是不用Iframe,在同一个页面生成脚本;第三个就是上面的例子,使用Iframe 产生脚本。结果在大数据量的条件下,效率最高的是第三个,其次是第二个,第一个有明显的慢的感觉。
        接下来的一节,将讲述VML最激动人心的功能,放大缩小!
    上一篇:ShapeType给VML制作模版
    下一篇:放大缩小VML
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

    脚本动态生成VML 脚本,动态,生成,VML,脚本,