转至繁体中文版     | 网站首页 | 图文教程 | 资源下载 | 站长博客 | 图片素材 | 武汉seo | 武汉网站优化 | 
最新公告:     敏韬网|教学资源学习资料永久免费分享站!  [mintao  2008年9月2日]        
您现在的位置: 学习笔记 >> 图文教程 >> 站长学院 >> Web开发 >> 正文
HTML组件(HTML COMPONENTS)之三         ★★★★

HTML组件(HTML COMPONENTS)之三

作者:闵涛 文章来源:闵涛的学习笔记 点击数:847 更新时间:2009/4/23 11:15:59

 ===最顶级页面===

  现在我们将我们注视的焦点转向我们的日历应用例子,该应用包括4个不同页面,canlendar.html为最顶级HTML文档,该页包含了calendar.htc HTC,而canlendar.htc有反过来包含两个别的HTC:day.htc和today.htc,calendar.html
内容如下:


Click a day in the calendar to add or modify your schedule.

  有几个要点您必须重点注意:第一、命名空间定义在〈HTML〉标记中,我们需要使用在我们要调用的HTC中定义的命名空间,在canlendar.htc中的命名空间是MYCAL,所以在标记中必须出现XMLNS标识。
  标记以问号开始以和别的正常标记区别开,该标记要求浏览器导入指定的HTC:calendar.htc,HTC可以有多个命名空间,故在导入时需要指明要使用的命名空间(MYCAL):


  HTC的主要优点之一就是:浏览器将一直挂起页面解析直到输入文件全部被导入为止。页面处理的异步机制将导致许多问题,浏览器并不等元素已经完全显示才开始解析页面,作为例子,你可以建立一个对象,并且在文挡的顶部访问一个在页面底部的方法,如果对象因为某些原因为准备好,你将会得到一个错误指示没有该对象不存在或该对象不支持你要访问的方法,相信您已经碰到过此类事情了吧!不管这样,IMPORT 是同步的,并且浏览器会一直等待页面导入完毕并且内容准备好。

  页面唯一而且重要的一行是调用自定义标记MYCALCALENDAR


  因为页面已经导入,故该调用将会象在calendar.htc所指定的那样建立一个日历。

  您可能已经注意到HTC可以包含别的HTC,calendar.htc包括两个别的HTML组件,每个月的所有日期day.htc和与当前日期一致的today.htc,以下是canlendar.htc的顶部15行:

HTML XMLNSMYCAL XMLNSTODAY XMLNSANYDAY
HEAD
IMPORT NAMESPACE=ANYDAY IMPLEMENTATION=day.htc
IMPORT NAMESPACE=TODAY IMPLEMENTATION=today.htc

PUBLICCOMPONENT tagName=CALENDAR
ATTACH EVENT=oncontentready ONEVENT=fnInit()
PUBLICCOMPONENT
SCRIPT LANGUAGE=javascript
!--
function fnInit()
{
defaults.viewLink = document;
}
 --
SCRIPT

  第一行在这些HTC会用到的XML命名空间。这些命名空间即包括本页自己要用到的,也包括页面需调用的命名空间(ANYDAY 和 TODAY ),注意命名空间并不一定要和HTC文件文件名一致。接着,我们导入这些HTC:

IMPORT NAMESPACE=ANYDAY IMPLEMENTATION=day.htc
IMPORT NAMESPACE=TODAY IMPLEMENTATION=today.htc

  当我们解析到这些行,浏览器将一直等到要导入的文件被导入才继续页面解析(同步导入)。

然后我们定义CALENDAR自定义标记:

PUBLICCOMPONENT tagName=CALENDAR
ATTACH EVENT=oncontentready ONEVENT=fnInit()
PUBLICCOMPONENT

  PUBLICCOMPONENT用来描述CALENDAR标记,在开始和结束标记之间,您可以将事件附加到CALENDAR标记上,事件oncontentready将在calendar.htc文件全部被导入,并被解析时,指定处理时间的是定义在javascript的函数:fnInit():

SCRIPT LANGUAGE=javascript
!--
function fnInit()
{
defaults.viewLink = document;
}
 --
SCRIPT

  viewLink指定的值非常重要,它是HTML组件的基础,它连接了HTML组件和调用该HTML组件的页面,defaults对象有别的属性并且会在别的地方被覆盖,我们给viewLink属性赋的是HTML文档对象,正因为该连接,我们才可以建立HTC组件和包含页面互访。
  我们将在后面解释日历的层。注意,尽管在日历中当月的当天框和其他天框、空框的样式不一样,但是我们通过优先级法则来实现在包含页中,HTML组件忽略任何相互冲突的样式定义。calendar.htc的样式定义如下:

STYLE
TD {
background-colortan;
width50;
height50;
}
STYLE

  现在将该定义和日历比较,只有空框是的颜色是黄褐色的,我们调用的HTC忽略了这些定义,被调用的页面都嵌入了页面定制。以下调用TODAYDAY HTML组件:

TODAYDAY value=' + dayOfMonth + 'TODAYDAY

  我们只是简单的传入了当月中的第几天,同样的调用ANYDAYDAY 也是简单的传入当月中的第几天:

ANYDAYDAY value=' + dayOfMonth + 'ANYDAYDAY
 
 
作者:feiy     : 

 


[网页制作]HTML组件(HTML COMPONENTS)之六日历主页面  [网页制作]HTML组件(HTML COMPONENTS)之四编写日历(3)
[网页制作]HTML组件(HTML COMPONENTS)之四编写日历(2)  [网页制作]HTML组件(HTML COMPONENTS)之四编写日历(1)
[Web开发]HTML组件(HTML COMPONENTS)之二  [Web开发]HTML组件(HTML COMPONENTS)之一
[Web开发]HTML组件(HTML COMPONENTS)之五  [Web开发]HTML组件(HTML COMPONENTS)之四
[Web开发]HTML组件(HTML COMPONENTS)之八  [Web开发]HTML组件(HTML COMPONENTS)之七
教程录入:mintao    责任编辑:mintao 
  • 上一篇教程:

  • 下一篇教程:
  • 【字体: 】【发表评论】【加入收藏】【告诉好友】【打印此文】【关闭窗口
      注:本站部分文章源于互联网,版权归原作者所有!如有侵权,请原作者与本站联系,本站将立即删除! 本站文章除特别注明外均可转载,但需注明出处! [MinTao学以致用网]
      网友评论:(只显示最新10条。评论内容只代表网友观点,与本站立场无关!)

    同类栏目
    · Web开发  · 网页制作
    · 平面设计  · 网站运营
    · 网站推广  · 搜索优化
    · 建站心得  · 站长故事
    · 互联动态
    更多内容
    热门推荐 更多内容
  • 没有教程
  • 赞助链接
    更多内容
    闵涛博文 更多关于武汉SEO的内容
    500 - 内部服务器错误。

    500 - 内部服务器错误。

    您查找的资源存在问题,因而无法显示。

    | 设为首页 |加入收藏 | 联系站长 | 友情链接 | 版权申明 | 广告服务
    MinTao学以致用网

    Copyright @ 2007-2012 敏韬网(敏而好学,文韬武略--MinTao.Net)(学习笔记) Inc All Rights Reserved.
    闵涛 投放广告、内容合作请Q我! E_mail:admin@mintao.net(欢迎提供学习资源)

    站长:MinTao ICP备案号:鄂ICP备11006601号-18

    闵涛站盟:医药大全-武穴网A打造BCD……
    咸宁网络警察报警平台