面向对象的XHTML与CSS编程

作者:嗷嗷 来源:样式之美 时间:2008-01-11 13:37:00 

要是XHTML与CSS能面向对象。。太阳应该从北边升起了。但是,凡事都应该带着OO的思想来看问题,也勉强可以凑数拉。其实,早在零几年就有人提出了OO-style,不过已找不到。

那要怎样OO呢?现在大家都知道CSS是可以介样写滴:

.G_G { /* xxxxxx */ }

我们可以把它大约看一个原型,或者说成,-__-b 好像本来就是类的样子,然后要在HTML里“实例化”一个对象,例如:

<div class="G_G">笨蛋嗷嗷</div>

该元素会使用上CSS相应的定义,但仅仅对应的class还是不够的,因为我们页面可能会多处应用到这个class,为了处理好“私有”的关系,把刚才的代码改成:

<div id="aoao" class="G_G">笨蛋嗷嗷</div>

这样的话,这个ID为aoao的元素就会应用.G_G这个类的定义,而且可以用#aoao{}这样的选择符来进去私有效果的定义,这样也不会影响到公共用的.G_G这个类,同时,#aoao定义的优先权会比.G_G高,符合私有定义比公共定义优先高的常理^^。

由于我使用了ID这个具有唯一性的东东,对这种私有定义后的东西复用就成了问题(一个ID只能在一个页面上出现一次,不知道谁说的,反正是真理)。如果我们要实现多相同私有化的东东怎办呢?那我们就必须来实现“多态”。挖哈哈。再改一下代码:

<div class="G_G o_O">笨蛋嗷嗷</div>

一个是“G_G”,另一个是“o_O”,但是我们如果使用上.o_O{}也是可以定义到元素,假如CSS是这样的话:

.G_G {width:100%}
.o_O {color:#123456}

元素将都被定义到,而且由于定义不层叠,都会给应用。再假如代码是这样的话,不知道会不会更好理解。

<div class="layout color">不是笨蛋嗷嗷鸟</div>
.layout{width:100%}
.color{color:#123456}

接着,要来实现“封装”。子级选择符大家应该常常用吧,换代码:

<div class="G_G"><span class="bendan">笨蛋</span>嗷嗷</div>

虽然.bendan{}跟.G_G .bendan{}都可以定义,但是后者只能应用在class为“G_G”的元素,我们可以简单把.bendan{}理解成全局定义,把.G_G .bendan{}理解成局部定义,这样的话就有利于我们XHTML与CSS的模块化。^^传说中的“封装”出现了,再接着。

<div id="aoao" class="G_G o_O"><span class="bendan">笨蛋</span>嗷嗷</div>

这样的代码就可以产生无数的变化了,还不明白的从头看起。^^

其实,这些跟真正的面向对象还有很大一段距离,我只是在学标题党,不过可以用它来理解ID与class的应用。

标签:XHTML,css,样式,面向对象
0
投稿

猜你喜欢

  • 注册表单之死

    2008-08-07 13:02:00
  • PHP设计模式之中介者模式浅析

    2023-05-25 04:07:16
  • 网页中插入视频播放代码全集

    2007-10-22 17:48:00
  • 模拟实现 Range 的 insertNode() 方法

    2010-11-30 21:39:00
  • MySQL中InnoDB和MyISAM类型的差别

    2008-11-05 13:32:00
  • Oracle9iPL/SQL编程的经验小结

    2010-07-23 12:49:00
  • 心理模型

    2009-05-17 13:45:00
  • ASP六大对象介绍

    2007-09-08 12:28:00
  • 如何避免asp的SQL的执行效率低

    2009-01-08 18:18:00
  • SQL学习笔记一SQL基础知识

    2011-09-30 11:24:33
  • 6款jQuery图表插件[译]

    2009-06-01 10:34:00
  • ASP中使用SQL语句教程

    2008-09-03 12:17:00
  • 新书:《精通CSS网页布局》

    2009-01-08 11:57:00
  • 如何使数据库中取出的数据保持原有格式

    2008-11-27 16:16:00
  • asp如何设定程序的执行次数?

    2010-05-18 18:31:00
  • 在ASP中使用SQL语句之12:连接

    2009-04-23 18:27:00
  • 保护你的ASP页面的两种办法

    2008-06-10 16:53:00
  • sqlserver bcp(数据导入导出工具)一般用法与命令详解

    2012-07-11 15:56:39
  • FCKeditor 编辑器实战技巧 Ⅰ

    2008-10-08 10:22:00
  • 将有安全问题的SQL过程删除,比较全面

    2007-08-06 14:46:00
  • asp之家 网络编程 m.aspxhome.com