zoukankan      html  css  js  c++  java
  • 前端开发之初探二

    Css(cascading style sheet)层叠样式表:修饰网页信息的显示样式。

    渐进增强(progressive enhancement):针对低版本浏览器进行构建页面,保证最基本的功能,然后在针对高级浏览器进行效果、交互等改进和追加功能达到更好的用户体验。

    优雅降级(graceful degradation):一开始就构建完整的功能,然后在针对低版本浏览器进行兼容。

    1、css 基本语法及引入方式

    基本语法:选择符{属性:属性值;}

    引入方式:

    (1)、内联样式:<标签    style=“属性:属性值;属性:属性值;”></标签>。

    (2)、内部样式:通过在 head 标签中添加<style type=“text/css”>css语句</style>

    (3)、外部样式:

    通过 <link rel=“stylesheet” type=“text/css” href=“目标文件路径及文件名全称”/>

    通过<style type=“text/csss”>@import url(目标文件路径及文件名全称);</style>

    link和import导入外部样式的区别:

    差别1:老祖宗的差别:link属于XHTML标签,而@import完全是CSS提供的一种方式。 link标签除了可以加载CSS外,还可以做很多其它的事情,比如定义RSS,定义rel连接属性等,@import就只能加载CSS。

    差别2:加载顺序的差别:当一个页面被加载的时候(就是被浏览者浏览的时候),link引用的CSS会同时被加载,而@import引用的CSS 会等到页面全部被下载完再被加载。所以有时候浏览@import加载CSS的页面时开始会没有样式。

    差别3:兼容性的差别。:@import是CSS2.1提出的,所以老的浏览器不支持,@import只在IE5以上的才能识别,而link标签无此问题。

    差别4:使用dom控制样式时的差别:当使用javascript控制dom去改变样式的时候,只能使用link标签,因为@import不是dom可以控制的。

    样式表的优先级:内联样式表的优先级别最高,内部样式表和外部样式表的优先级跟书写的顺序有关。 

    样式的优先级:!important(有兼容)比内联样式优先级高;优先级就近原则,样式定义最近者为准;以最后载入的样式为准;

    2、css 选择器及权重计算方法

    常用的选择符有十种左右:类型选择符,id选择符,class选择符,通配符,群组选择符,包含选择符,伪类选择符,伪对象选择符、字选择符、通配符。

    css中用四位数字表示权重,权重的表达方式如:0,0,0,0

    子选择符的权重为0000、继承样式的权重为0000、类型选择符的权重为0001

    class选择符的权重为0010、属性选择符的权重为0010、伪类选择符的权重为0010

    伪元素选择符的权重为0010、id选择符的权重为0100、内联样式的权重为1000

    包含选择符的权重:为包含选择符的权中之和、群组选择符的权重为它们各自本身的权重

    正常顺序为:a:link,a:visited,a:hover,a:active,错误的顺序有时会使超链接的样式失效;

    3、css 样式重置 reset

    由于个版本浏览器具有差异化,为了便于样式统一,采用 css reset。会对搜索引擎优化造成小影响。

    normalize.css保护了元素有价值的默认值,修复了常见的bug,未使用大段的继承链、模块化的、拥有详细的文档。

    normalize.css支持包括手机浏览器在内的超多浏览器,同时对HTML元素,排版,列表,嵌入的内容,表单和表格都进行了一般化。尽管这个项目进行了一般化的原则,但我们还是在合适的地方使用了更实用的默认值。

    4、css 盒模型  

    盒模型是css布局的基石,它规定了网页元素如何显示以及元素间相互关系。css定义所有的元素都可以拥有像盒子一样的外形和平面空间,即都包含边框、边界、补白、内容区,这就是盒模型。

    盒子的实际大小(标准盒模型):

    宽 =左右margin+左右border+左右padding+width

    高 =上下margin+上下border+上下padding+height

    盒子的实际大小(IE盒模型):

    宽 =左右margin+width

    高 =上下margin+height

    5、css 定位浮动

    position:static /absolute/relative/fixed

    float:right/left;

    绝对定位和相对定位的区别

    1、参照物不同绝对定位的参照物是包含块,相对定位的参照物是元素本身位置;

    2、绝对定位将对象从文档流中拖离出来因此不占据空间,相对定位不破坏正常的文档流顺序,无论是否进行移动,元素仍然占据原来的空间。

    6、css 背景

    插入图片:属于网页内容,也就是结构。

    背景图:属于网页的表现,背景图上可以显示文字、插入图片、表格等。

    背景图的固定

    语法:选择符{background-attachment:scroll(滚动)/fixed(固定);}

    背景属性的缩写语法:background:属性值1   属性值2   属性值3;

    背景缩写:background: url(背景图片的路径及全称) no-repeat center top;

    7、元素类型的转换

    盒子模型可通过display属性来改变默认的显示类型

    1)display属性与属性值 (18个属性值)

    属性值:block/inline/inline-block/none/list-item/table-header-group/table-footer-group

    作用:该属性设置或检索对象元素应该生成的盒模型的类型。

    说明:各属性值的作用

    1)block块状显示:类似在元素后面添加换行符,也就是说其他元素不能在其后面并列显示。

    2)inline内联显示:在元素后面删除换行符,多个元素可以在一行内并列显示。

    3)inline-block行内块元素显示:元素的内容以块状显示,与行内的其他元素显示在同一行。(只有这一个元素类型支持vertical-align属性)img,input。

    4)none 此元素不会被显示。

    5)list-item:将元素转换成列表。li的默认类型。

    说明:

    1、大部分块元素display属性值默认为block,其中列表的默认值为list-item。

    2、大部分内联元素的display属性值默认为inline,其中img,input,默认为inline-block。

    3、设置了float属性后,元素自动转换块元素,体积与内容同宽;

    8、css 文本,字体

    为了减小系统间的字体显示差异,IE Netscape Mozilla的浏览器制作商于1999年召开会议,共同确定16px/ppi为标准字体大小默认值,即1em.默认情况下,1em=16px,0.75em=12px;

    倾斜:font-style:italic(倾斜度小)/oblique(倾斜度大)/normal(取消倾斜,常规显示);

    说明:italic和oblique都表示倾斜,不过oblique的幅度要大一点,但一般浏览器对它们的区分不是很明显。

    水平对齐方式{text-align:left/right/center/justify(两端对齐中文不起作用);}

    垂直对齐方式{vertical-align:top/bottom/middle;}

    文本字体:{font-family:字体1,字体2,字体3;}

    当字体是中文字体时,需加双引号;"微软雅黑","宋体"

    当英文字体中有空格时,需加双引号如(“Times New Roman”)

    当英文字体只有一个单词组成是不加双引号;如:(Arial);

    Windows中文版本操作系统下,中文默认字体为宋体或者新宋体,英文字体默认为Arial.

    font属性的简写:

    说明:font的属性值应按以下次序书写(各个属性之间用空格隔开)

    顺序: font-weight | font-size / line-height | font-family

    (1)简写时 , font-size和line-height只能通过斜杠/组成一个值,不能分开写。

    (2) 顺序不能改变 ,这种简写法只有在同时指定font-size和font-family属性时才起作用,而且,你没有设定font-weight 他们会使用缺省值。

    文本修饰:text-decoration:none/underline/overline/line-through/blink.(高版本浏览器不支持blink属性)

    首行缩进:{text-indent:value;}
    说明:

    1)text-indent可以取负值;

    2)text-indent属性只对第一行起作用。

    字间距{letter-spacing:value;}控制英文字母和汉字的字距。(英文字母和字母)
    词间距{word-spacing:value;}控制英文单词词距。(通用于英文词和词之间的间距)

    文本流控制{layout-flow:horizontal/vertical-ideographic;}(只支持IE浏览器) 
    说明:

    1)horizontal:自左向右

    2)vertical-ideographic:自上而下

    关于溢出:

    1)溢出属性(容器的)

    overflow:visible/hidden(隐藏)/scroll/auto(自动)/inherit;

    visible:默认值,内容不会被修剪,会成现在元素框之外;

    hidden:内容会被修剪,并且其余内容是不可见的;

    scroll:内容会被修剪,但是浏览器会显示滚动条,以便查看其余的内容;

    auto:如果内容被修剪,则浏览器会显示滚动条,以便查看其他的内容;

    inherit:规定应该从父元素继承overflow属性的值。

    2)空余空间

    white-space:normal/pre/nowrap/pre-wrap /pre-line /inherit

    该属性用来设置如何处理元素内的空白;

    normal:默认值,空白会被浏览器忽略,

    pre:空白会被浏览器保留,其行为方式类似HTML中的pre标签;

    nowrap:文本不会换行,文本会在同一行上继续,直到遇到<br/>标签为止;

    pre-wrap:保留空白符序列,但是正常的进行换行;

    pre-line:合并空白符序列,但是保留换行符;

    inherit:规定应该从父元素继承White-space属性的值;(ie浏览器都不支持此属性值)

    3)文本溢出:text-overflow:clip/ellipsis

    取值:

    clip:不显示省略号(...),而是简单的裁切;

    ellipsis:当对象内文本溢出时,显示省略标记;

    说明:

    text-overflow属性仅是...,当文本溢出时是否显示省略标记,并不具备其它的样式属性定义,要实现溢出时产生省略号的效果还需定义:

    1、容器宽度:width:value;

    2、强制文本在一行内显示:white-space:nowrap;

    3、溢出内容为隐藏:overflow:hidden;

    4、溢出文本显示省略号:text-overflow:ellipsis;

    9、 css 列表,表单,表格

    ul 无序列表、ol 有序列表、dl 自定义列表

    定义列表符号样式:

    list-style-type:disc(实心圆)/circle(空心圆)/square(实心方块)/none(去掉列表符号);

    使用图片作为列表符号:

    list-style-image:url(所使用图片的路径及全称);

    定义列表符号的位置:

    list-style-position:outside(外边)/inside(里边);

    list-style:none;去掉列表符号

    表单

    1)表单字段集

    <fieldset></fieldset>

    功能:相当于一个方框,在字段集中可以包含文本和其他元素。该元素用于对表单中的元素进行分组并在文档中区别标出文本。

    fieldset元素可以嵌套,在其内部可以在设置多个fieldset对象。

    2)字段级标题

    <legend></legend>

    功能:legend元素可以在fieldset对象绘制的方框内插入一个标题。legend元素必须是fieldset内的第一个元素。 

    3)提示信息标签

    <label for="绑定控件id名"></label>

    功能:label元素用来定义标签,为页面上的其他元素指定提示信息。要将label元素绑定到其他的控件上,可以将label元素的for属性设置为与该控件的id属性值相同。

    表格高级

    1、表格的作用:显示数据;

    (一)关于表格的CSS属性

    1、单元格间距(该属性必须给table添加)

    border-spacing:value;

    2、合并相邻单元格边框

    border-collapse:separate(边框分开)/collapse(边框合并);

    3、无内容单元格显示、隐藏

    empty-cells:show/hide;

    4、表格布局算法(加快运行的速度)

    table-layout:auto/fixed(固定宽高,不会随内容多少改变单元格宽高)

    5、表格标题

    <caption>标题内容</caption>

    caption:表格标题

    表格标题位置:caption-side:top/right/bottom/left

    说明:left,right位置只有火狐识别,top,bottom IE6以上版本支持,ie6以下版本不支持其它属性值,只识别top;

    6、表格布局元素

    1、表格基本组成

    table(表格)      tr(行)      td(列)

    th:表格列标题(放在tr里)

    重要属性:

    1)colspan="value"    合并列

    2)rowspan="value"  合并行

    3)valign="top/bottom/middle/baseline" 垂直对齐方式 

    4)rules="groups/rows/cols/all/none"    添加组分隔线

    说明:

    rows:位于行之间的线条

    cols:位于列之间的线条

    all:位于行和列之间的线条

    none:没有线条

    groups:位于行组和列组之间的线条

    2、数据行分组

    <thead></thead>      表头

    <tbody></tbody>      表体

    <tfoot></tfoot>         表尾

    说明:一个Table中,只能包含一个thead,一个tfoot,但可包含多个tbody。

    3、数据列分组

    <colgroup span="value"></colgroup>

    <col  span="value" />

    说明:

    1)col和colgroup元素会根据从左到右的顺序依次对数据表格进行分组。

    2)span属性显示指定相邻几列组成一组,span属性值默认为1,默认时仅定义一列为一组。

    3)可以通过给table添加rules="groups"属性来给分组列添加组分割线。

    注意:虽然col和colgroup具有相同的功能,但是,我们只能使用colgroup元素来决定表格内容部分分割线(rules)应该处于的位置,而col没有这个功能。

    10、css3新增透明属性

    语法 :background:rgba(value,value,value,value);

    说明:前三个值是RGB的颜色值,最后一个是透明的数值。

     CSS3新增伪类举例:

        p:first-of-type 选择属于其父元素的首个 <p> 元素的每个 <p> 元素。

        p:last-of-type  选择属于其父元素的最后 <p> 元素的每个 <p> 元素。

        p:only-of-type  选择属于其父元素唯一的 <p> 元素的每个 <p> 元素。

        p:only-child    选择属于其父元素的唯一子元素的每个 <p> 元素。

        p:nth-child(2)  选择属于其父元素的第二个子元素的每个 <p> 元素。

        :enabled、:disabled 控制表单控件的禁用状态。

        :checked,单选框或复选框被选中。

    11、css unicode

    &gt;      >

    &lt;      <

    &nbsp;

    &copy;

    &amp;

    12、Flash和marquee(滚动字幕)

    1、插入flash

    1)语法:

    <object width="value" height="value">
    <param name="movie" value="flash路径及全称" />
    <embed width="value" height="value" src="flash路径及全称"></embed>
    </object>

    说明:flash源文件格式.fla,

    导出影片为.swf,

    创建播放器格式为.exe.

    gif格式:.gif

    2)将flash背景设置为透明

    <param name="wmode" value="transparent" />

    给<embed>标记添加属性:wmode="transparent"

    13、伪对象选择符:

    1):after与content属性一起使用,定义在对象后的内容。

    如:div:after{content:url(logo.jpg);}

          div:after{content:"文本内容";}

    2):before与content属性一起使用,定义在对象前的内容。

    如:div:before{content:"在其前放内容";}

    3)、:first-letter定义对象内第一个字符的样式。

    说明:(该伪元素只能用于块级元素。)

    4)、:first-line:定义对象内第一行的样式。

    说明:

    *(该伪元素只能用于块级元素。)

    *ie6以下版本浏览器不支持伪对象选择符。

    *visibility:hidden/visible;隐藏/可见

    *visibility:hidden;和display:none;的区别:

    visibility:hidden;属性会使对象不可见,但该对象在网页所占的空间没有改变,等于留出了一块空白区域,而 display:none属性会使这个对象彻底消失。

  • 相关阅读:
    shell
    Python全栈开发:django网络框架(二)
    Python全栈开发:django网络框架(一)
    动态规划问题以及诸多实例分析
    python实现并查集
    使用命令行编译和运行 c、Java和python程序
    整数除法操作的取整问题
    使用TensorFlow低级别的API进行编程
    使用TensorFlow高级别的API进行编程
    TensorFlow安装和HelloWorld
  • 原文地址:https://www.cnblogs.com/wmwPro/p/5693833.html
Copyright © 2011-2022 走看看