学写网页 #05# CSS Mastery 笔记 1~3

把所有细节都记在脑子里是不现实且不必要的,《精通CSS》既是一本可以随手翻阅的"放在电脑边的书", 也是一本非常好的 CSS 入门书,它用非常浅显的语言和例子告诉了你哪些是坏的行为,哪些是好的行为,很适合当参考书,并且颇具权威性 ... (读后感/个人观点)

第一章

conventions

validator 

DOCTYPE switching

The browser chooses which rendering method to use based on the existence of a DOCTYPE declaration and the DTD being used.

Despite writing valid CSS, if you choose the wrong DOCTYPE,
your pages will be rendered in quirks mode and behave in a buggy and unpredictable way.

第二章

Selectors

The cascade and specificity

Inheritance: inherited styles have a null specificity

Structural comments

配合 Ctrl + F 使用。

第三章

Box model

Positioning: normal flow(+relative), floats, absolute(+fixed)

尝试一:增大 padding borders margins 不会影响 content 的区域,而是增加盒子的整体大小。

#box1 p {
    background-color: pink;
    border-width: 0px; /* 只是为了说明 border 也是可以设置“粗细”的 */
}

#box1 #p1 {
    padding: 5px;
    border: dashed;
    margin: 10px;
}

#box1 #p2 {
}

     

/

尝试二: Margin collapsing

#box1 #p1 {
    margin: 30px;
}

#box1 #p2 {
    margin: 20px;
}

/

尝试三:Collapse on themselves

        <div id="box1">
            <p id="p1"></p>
            <p id="p2">你</p>
        </div>
#box1 #p1 {
    margin: 30px;
}

#box1 #p2 {
    margin: 20px;
}

在“你”的上面还有 30px 空间。

/

尝试四:Margin collapsing 之包含关系

#branding {
    width: 15em;
    height: 15em;
    margin: 30px;
    background-color: darkorchid;
}

#branding .tel {
    width: 10em;
    height: 10em;
    margin: 20px;
    background-color: white;
}

可以观察到左边是不会层叠的,上面和下面会,具体的实际数值取决于更大那个(可以是里面的!)。

/

尝试五:改变盒子的类型

        <div id="box1">
            <div id="p1">白日依山尽</div>
            <div id="p2">黄河入海流</div>
            <div id="p3">欲穷千里目</div>
        </div>
#box1 #p1 {
    display: block;
    /* 对 div 来说这是默认的 */
}

#box1 #p2 {
    display: inline;
}

#box1 #p3 {
    display: none;
}

 欲穷千里目不占空间! (彻底消失)

/

尝试六:inline block

    <body>
        <div id="block1"></div>
        <span id="inline1">我不行了</span>
        <span id="inline1">躺在担架上</span>
        <div id="block1"></div>
    </body>
#block1 {
    width: 10em;
    height: 10em;
    background-color: pink;
}

#inline1 {
    height: 10em;
    width: 10em;
    /* 在行内框里显示的设置长度高度是没有用的 哦 */
    background-color: royalblue;
}

#block1 {
    width: 10em;
    height: 10em;
    background-color: pink;
}

#inline1 {
    margin: 1em;
    padding: 1em;
    border: dashed 1em;
    /* 可以通过改变 margin padding border 来改变行间距*/
    /* 注意仅仅是行间距,垂直间距不会变化 */
    background-color: royalblue;
}

可以通过改变行高改变垂直间距:

#inline1 {
    margin: 1em;
    padding: 1em;
    border: dashed 1em;
    line-height: 3em;
    background-color: royalblue;
}

或者直接改成 display: inline-block;

匿名块框(奇怪怎么没有border?):

    <body>
        <div id="block1">
            如果我在这里打一行字
            <span id="inline1">我不行了</span>
            <span id="inline1">躺在担架上</span>
        </div>

        <div id="block1"></div>
    </body>
#inline1, div:first-line {
    margin: 1em;
    border: dashed 1em;
    background-color: royalblue;
}

/

尝试七:Relative positioning

#box1 #p1 {
}

#box1 #p2 {
    position: relative;
    left: 20px;
    top: 20px;
}

#box1 #p3 {
}

 本质上还是 normal flow

/

尝试八:Absolute positioning

绝对定位令对象元素从原来的“文档流”中脱离。

#box1 #p2 {
    position: absolute;
    left: 20px;
    top: 20px;
}

/

尝试九:Absolute positioning 之二

w3school:绝对定位的元素的位置相对于最近的已定位祖先元素,如果元素没有已定位的祖先元素,那么它的位置相对于最初的包含块。(这取决于user agent)

    <body>
        <div id="branding">
            <p class="tel">Tel: 3123 2312 0981</p>
        </div>
    </body>

注意是最近的已定位的祖先元素哦!!下面两个效过是不一样的:

#branding {
    width: 70em;
    height: 10em;
    position: relative; /* 这样才算已定位,虽然其实并没有做相对偏移 */
    background-color: darkorchid;
}

#branding .tel {
    position: absolute;
    right: 1em;
    bottom: 1em;
    text-align: left;
}

tel 相对于 branding ↓

tel 相对于 body(或者是用户视图,不管放大缩小总是在可以看到的那块区域的那个绝对位置,视觉上会变大就是了) ↓

#branding {
    width: 70em;
    height: 10em;
    background-color: darkorchid;
}

#branding .tel {
    position: absolute;
    right: 1em;
    bottom: 1em;
    text-align: left;
}

/

尝试十:fixed

效果和上面那个 去掉 relative 一样,相对 viewport 的绝对定位

#branding {
    width: 70em;
    height: 10em;
    background-color: darkorchid;
}

#branding .tel {
    position: fixed;
    right: 1em;
    bottom: 1em;
    text-align: left;
}

/

尝试十一:float: left;

   <body>
        <div id="box1"></div><div id="box2"></div>
        <div id="box3"></div>
    </body>
div {
    width: 10em;
    height: 10em;
    background-color: crimson;
    display: inline-block;
    /*float: left;*/
}

无 float: left;

float: left;

如果没有足够的水平空间,浮动元素将向下移动,直到有足够的空间:

#box2 {
    height: 5em;
    width: 24em;
    background-color: aquamarine;
}

#box3 {
    width: 40em;
    height: 7em;
    background-color: chartreuse;
}

放大 ↓

再放大 ↓

继续放大 ↓

/

尝试十二:clear

   <body>
        <div class="box"></div>
        <span>我与父亲不相见已二年余了,我最不能忘记的是他的背影。
那年冬天,祖母死了,父亲的差使1也交卸了,正是祸不单行的日子。我从北京到徐州,打算跟着父亲奔丧2回家。到徐州见着父亲,看见满院狼藉3的东西,又想起祖母,不禁簌簌地流下眼泪。父亲说:“事已如此,不必难过,好在天无绝人之路!”
回家变卖典质4,父亲还了亏空;又借钱办了丧事。这些日子,家中光景5很是惨澹,一半为了丧事,一半为了父亲赋闲6。丧事完毕,父亲要到南京谋事,我也要回北京念书,我们便同行。
到南京时,有朋友约去游逛,勾留7了一日;第二日上午便须渡江到浦口,下午上车北去。父亲因为事忙,本已说定不送我,叫旅馆里一个熟识的茶房8陪我同去。他再三嘱咐茶房,甚是仔细。但他终于不放心,怕茶房不妥帖9;颇踌躇10了一会。其实我那年已二十岁,北京已来往过两三次,是没有什么要紧的了。他踌躇了一会,终于决定还是自己送我去。我再三劝他不必去;他只说:“不要紧,他们去不好!”
我们过了江,进了车站。我买票,他忙着照看行李。行李太多,得向脚夫11行些小费才可过去。他便又忙着和他们讲价钱。我那时真是聪明过分,总觉他说话不大漂亮,非自己插嘴不可,但他终于讲定了价钱;就送我上车。他给我拣定了靠车门的一张椅子;我将他给我做的紫毛大衣铺好座位。他嘱我路上小心,夜里要警醒些,不要受凉。又嘱托茶房好好照应我。我心里暗笑他的迂;他们只认得钱,托他们只是白托!而且我这样大年纪的人,难道还不能料理自己么?我现在想想,我那时真是太聪明了。
        </span>
        <div id="context">我说道:“爸爸,你走吧。”他望车外看了看,说:“我买几个橘子去。你就在此地,不要走动。”我看那边月台的栅栏外有几个卖东西的等着顾客。走到那边月台,须穿过铁道,须跳下去又爬上去。父亲是一个胖子,走过去自然要费事些。我本来要去的,他不肯,只好让他去。我看见他戴着黑布小帽,穿着黑布大马褂12,深青布棉袍,蹒跚13地走到铁道边,慢慢探身下去,尚不大难。可是他穿过铁道,要爬上那边月台,就不容易了。他用两手攀着上面,两脚再向上缩;他肥胖的身子向左微倾,显出努力的样子。这时我看见他的背影,我的泪很快地流下来了。我赶紧拭干了泪。怕他看见,也怕别人看见。我再向外看时,他已抱了朱红的橘子往回走了。过铁道时,他先将橘子散放在地上,自己慢慢爬下,再抱起橘子走。到这边时,我赶紧去搀他。他和我走到车上,将橘子一股脑儿放在我的皮大衣上。于是扑扑衣上的泥土,心里很轻松似的。过一会儿说:“我走了,到那边来信!”我望着他走出去。他走了几步,回过头看见我,说:“进去吧,里边没人。”等他的背影混入来来往往的人里,再找不着了,我便进来坐下,我的眼泪又来了。
近几年来,父亲和我都是东奔西走,家中光景是一日不如一日。他少年出外谋生,独力支持,做了许多大事。哪知老境却如此颓唐!他触目伤怀,自然情不能自已。情郁于中,自然要发之于外;家庭琐屑便往往触他之怒。他待我渐渐不同往日。但最近两年不见,他终于忘却我的不好,只是惦记着我,惦记着他的儿子。我北来后,他写了一信给我,信中说道:“我身体平安,惟膀子疼痛厉害,举箸14提笔,诸多不便,大约大去之期15不远矣。”我读到此处,在晶莹的泪光中,又看见那肥胖的、青布棉袍黑布马褂的背影。唉!我不知何时再能与他相见![2]
        </div>
    </body>

原始状态,浮动状态 ↓

clear: left (它表示框的左边不应该挨着 浮动框)

span {
    display: inline-block;
    clear: left;
}

#context {
    clear: left;
}

CSS浮动(float,clear)通俗讲解  这篇写得挺通俗

What does the CSS rule “clear: both” do? 其实是在讲为什么需要 clear.both ,和书上的内容有点相似

原文地址:https://www.cnblogs.com/xkxf/p/8628871.html

时间: 2024-10-16 17:52:21

学写网页 #05# CSS Mastery 笔记 1~3的相关文章

学写网页 #04# w3school

索引: HTML 输入类型 XHTML HTML5 HTML5 样式指南和代码约定 WHO 成立于 1948 年. 对缩写进行标记能够为浏览器.翻译系统以及搜索引擎提供有用的信息. code 元素不保留多余的空格和折行: 如需解决该问题,您必须在 pre 元素中包围代码: var person = { firstName:"Bill", lastName:"Gates", age:50, eyeColor:"blue" } 爱因斯坦的公式: E

学写网页 #02# 无题

参照物 v1 <!DOCTYPE html> <html> <head> <meta charset="utf-8" /> <title>My Picture List</title> <link rel="stylesheet" href="css/hello.css" /> </head> <body> <main> <

css实战笔记(一):写网页前的reset工作

reset.css是每个html必备的样式,其中有各种元素属性清零的代码. 为什么要有reset.css 让各个浏览器的CSS样式有一个统一的基准,比如清除各个浏览器为元素自带的margin.padding等.reset必要性的例子: 随便写一个div,发现它的左边与上边都与浏览器边框有白色空隙:    在css中加入margin.padding清零的代码后,div的边缘与浏览器完全贴合:              所有类似红线画出的用作元素初始化(标准化)操作的代码的集合,写在reset.cs

《CSS mastery》 读书笔记

又翻了一下之前的读书笔记,再重温了忘掉的细节.最近一年的工作,由于有重构岗位的同学负责CSS的编写,虽说还是接触到,但毕竟不写好久了,有些东西还是忘记了,例如选择器的权重计算细节.这个笔记只是部分,后半部分快速浏览了,没写笔记. 1.元素命名规则 类名或者ID以元素是做什么的来命名,不要以元素的外观表现来命名. 类名或者ID全部小写,并用连字符号或许下划线分隔.(.add-class)2.伪类 链接伪类: :link和:visited 动态为例: :hover :active :focus 设置

初学者用div+css结构写网页的几个误区

1.用div+css结构制作静态html网页不等于彻底抛弃古老的table写法.之所以不建议用table来布局网页是因为在网页加载很慢的时候要等table结构加载完成才能看到网页,其次是table的布局没有一定的语义,网页代码修改起来比较麻烦. 在写一些栏目块时,特别是数据分类较多,比如“求购信息”的栏目块,顶部可能出现“发布人.发布时间.信息标题.联系方式”等项目,像这样的地方建议还是要用table来写,因为table是专门用来写数据表格的,控制起来很方便,而且符合语义要求,还有页面中出现类似

【转】CSS选择器笔记

作者: 阮一峰 日期: 2009年3月12日 来源:http://www.ruanyifeng.com/blog/2009/03/css_selectors.html 去年我学jQuery的时候,曾经做过一点选择器(selector)的笔记. 这几天拿出来看了一下,发现很多都忘记了.所以,我决定把它们贴在这里,方便以后查看.这对其他朋友应该也是有用的,毕竟选择器是制作网页效果的第一步. 笔记分为两个部分,今天是CSS的选择器,以后还有一部分xPath的选择器.今天的笔记中包括44个选择器,基本涵

css学习笔记四

广州天气变冷了,css学习笔记还是要总结. 总结: 1:几米页面静态页面主要是一列结构头部banner图,mainbody部分放文字内容和图书图片,底部是页面的版权信息 2:腾讯软件中心静态页面制作(二列浮动布局) 3:w3cschool静态页面制作 4:垂直菜单,水平菜单(li设置float),圆角菜单(利用背景图片), 鼠标移上去菜单高度变化(margin-top以及line-height), 鼠标移上去菜单宽度变化 (用jq写是利用hover和hide,用原生js写是文档加载完,遍历li里

妙味课堂——HTML+CSS基础笔记

妙味课堂的课程讲得非常的清楚,受益匪浅.先把HTML和CSS基础课程部分视频的学习笔记记录如下: padding #PS基础 ##前端需要的PS技能 - PS技能(前端需要):切图.修图.测量 - PS工具: - 移动工具 - 矩形选框工具 - 裁切工具 - 吸管工具 - 横排文字工具 - 手抓(快捷键:空格) - 缩放(快捷键:Ctrl + 和 Ctrl -) - 标尺(快捷键:Ctrl R,主要是拖出参考线.矩形区域选择的时候,按住Ctrl,就能贴合参考线) - 自由变换(快捷键 Ctrl

CSS学习笔记08 浮动

从CSS学习笔记05 display属性一文中,我们知道div是块元素,会独占一行,即使div的宽度很小,像下面这样 应用display属性的inline属性可以让div与div共享一行,除了这种方法外,还有没有其他方法可以实现这种效果呢,答案是肯定的,那就是下面要介绍的CSS的浮动特性,浮动从字面意思上来看,就是浮起来,动起来,那么是谁浮起来,又是谁动起来呢?往下看,很快就会知道答案了. 元素的浮动是指设置了浮动属性的元素会脱离标准文档流的控制,漂浮在标准流之上.元素浮动后,虽然脱离标准流,但