XHTML与CSS的面向对象编程

2016-02-19 18:00 3 1 收藏

关注图老师设计创意栏目可以让大家能更好的了解电脑,知道有关于电脑的更多有趣教程,今天给大家分享XHTML与CSS的面向对象编程教程,希望对大家能有一点小小的帮助。

【 tulaoshi.com - Web开发 】

要是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只能在一个页面上出现一次,不知道谁说的,反正是真理)。如果我们要实现多相同私有化的东东怎办呢?那我们就必须来实现“多态”。挖哈哈。再改一下代码:

(本文来源于图老师网站,更多请访问http://www.tulaoshi.com/webkaifa/)

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}  接着,要来实现“封装”。子级选择符大家应该常常用吧,换代码:

(本文来源于图老师网站,更多请访问http://www.tulaoshi.com/webkaifa/)

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的应用。

来源:http://www.tulaoshi.com/n/20160219/1616586.html

延伸阅读
标签: Web开发
一直以来,我都主要是做winform方面的编程,最近做了点web方面的,所以也研究了几天的javascript。偶有心得故记之: 应用面向对象的思想在javascript中同样适用,关键的是你敢不敢用,想不想用。 我曾使用vs2005编写了一个vs2003工具箱完全类似的导航工具条,我比较喜欢在winform中通过这种方式向用户提供应用程序功能的导航。所...
标签: Delphi
  2.1.10.7 将库单元加入工程         将库单元加入工程是比较简单的。无论是您自己建立的库单元还是 Delphi 建立的与窗体有关的库单元,如果已经完成,则先打开您想加入库单元的工程 ( 可以用 Open Project打开工程 ) ;再选用 File|Open File ,然后选择您想加入的源程序 (.PAS 文件 ) ,并...
标签: PHP
出自:http://www.cncsk.com/Document/WebDev/PHP/200512291759.htm 这篇文章介绍在PHP的面向对象编程(OOP)。我将演示如何用面向对象的概念编出较少的代码但更好的程序。祝大家好运。 面向对象编程的概念对每一个作者来说都有不同的看法,我提醒一下一个面向对象语言应有的东西: - 数据抽象和信息隐藏 ...
标签: Delphi
  2.1.4 跳转语句 Object Pascal的跳转语句有 if 和 case两个。 2.1.4.1 if语句         if语句会计算一个表达式,并根据计算结果决定程序流程。在上文的例程中,根据 ColorDialog.Execute 的返回值,决定窗体的背景颜色。 if 保留字后跟随一个生成 Boolean 值 True或 False 的表达式...
标签: Web开发
你如何为成千上万的用户和页面提供CSS? 这是Nicole Sullivan在她的在丹佛的Web Directions North 大会上的幻灯片中尝试回答的问题。得益于面向对象的CSS (OOCSS),这个想法从社区收集到了大量的反馈。 OOCSS显然已经不仅仅是一个工具了,它还是一种思考的方式。根据这个观念可以有很多优势,主要来说有: 它可以让你写更快的、可维护的...

经验教程

740

收藏

45
微博分享 QQ分享 QQ空间 手机页面 收藏网站 回到头部