前端面试题汇总(含答案)(HTML+CSS篇)

主要自用,持续更新,相同类型的题目尽量放在了一起,参考的实在太多了就没有列出,侵权烦请联系删除。提示:自动生成的目录在页面右边->>>>>>>>>>>>>>>>

1.css选择器优先级

  • css选择器的种类

1.标签选择器(如:body,div,p,ul,li)

2.类选择器(如:class="head"class=“head_logo”)

3.ID选择器(如:id=“name”,id=“name_txt”)

4.全局选择器(如:*号)

5.组合选择器(如:.head .head_logo,注意两选择器用空格键分开)

6.后代选择器 (如:#head .nav ul li 从父集到子孙集的选择器)

7.群组选择器 div,span,img {color:Red} 即具有相同样式的标签分组显示

8.继承选择器(如:div p,注意两选择器用空格键分开)

9.伪类选择器(如:就是链接样式,a元素的伪类,4种不同的状态:link、visited、active、hover。)

10.字符串匹配的属性选择符(^ $ *三种,分别对应开始、结尾、包含)

11.子选择器 (如:div>p ,带大于号>)12.CSS 相邻兄弟选择器器 (如:h1+p,带加号+)

  • css选择器的优先级

!important > 行内样式>ID选择器 > 类选择器 > 标签 > 通配符 > 继承 > 浏览器默认属性

2.css选择器有哪些?他们的权重

  • 内联样式,如: style=“…”,权值为1000。
  • ID选择器,如:#content,权值为0100。
  • 类,伪类、属性选择器,如.content,权值为0010。
  • 类型选择器、伪元素选择器,如div p,权值为0001。
  • 通配符、子选择器、相邻选择器等。如* > +,权值为0000。
  • 继承的样式没有权值

3.说一下盒模型

https://www.cnblogs.com/qianguyihao/p/7256371.html

盒子模型,英文即box model。无论是div、span、还是a都是盒子。但是,图片、表单元素一律看作是文本,它们并不是盒子。这个很好理解,比如说,一张图片里并不能放东西,它自己就是自己的内容。

一个盒子中主要的属性就5个:width、height、padding、border、margin,宽度和真实占有宽度,不是一个概念,这是因为还要加上padding、border,真实的大小是margin border padding content的大小和,height、width指的都是content的大小

在标准盒子模型中,width 和 height 指的是内容区域的宽度和高度。增加内边距、边框和外边距不会影响内容区域的尺寸,但是会增加元素框的总尺寸。IE盒子模型中,width 和 height 指的是内容区域+border+padding的宽度和高度。

综合属性的写法:(上、右、下、左)(顺时针方向,用空格隔开。margin的道理也是一样的)

4.flex:1什么意思

  • CSDN收藏夹:flex:1 == flex:1 1 auto

  • flex的三个属性

1.flex-grow:默认为0,指定了flex容器中剩余空间的多少应该被分配给项目

2.flex-shrink:默认为1,仅在默认宽度之和大于容器宽度的时候才会收缩。

3.flex-basis:指定了flex元素在主轴方向上的大小,如果不用box-sizing改变盒模型,这个属性就决定了flex元素的内容尺寸,如果设置了flex-basis,那么元素占用的空间就为这个值,没有设置或auto那么元素占用的就是元素的width/height值

5.哪些方法可以实现水平垂直居中

1.块元素的特点:
a.总是在新行上开始;
b.高度、行高以及外边距和内边距都可控制;
c.宽度默认是它容器的100%,除非设定一个宽度;
d.他可以容纳内联元素和其他块元素。
2.内联元素的特点:
a.和其他元素都在同一行;
b.高,行高及外边距和内边距不可改变;
c.宽度就是它的文字和图片的宽度,不可改变;
d.内联元素只能容纳文本或者其他内联元素。

水平居中

    1. 若是行内元素, 给其父元素设置 text-align:center,即可实现行内元素水平居中.
    1. 若是块级元素, 该元素设置 margin:0 auto即可.
    1. 若子元素包含 float:left 属性, 为了让子元素水平居中, 则可让父元素宽度设置为fit-content,并且配合margin, 作如下设置:
      .parent{
      width: -moz-fit-content;
      width: -webkit-fit-content;
      width:fit-content;
      margin:0 auto;
      }
      fit-content是CSS3中给width属性新加的一个属性值,它配合margin可以轻松实现水平居中, 目前只支持Chrome 和 Firefox浏览器.
    1. 使用flex 2012年版本布局, 可以轻松的实现水平居中, 子元素设置如下:
.son{
    display: flex;
    justify-content: center;
}
    1. 使用CSS3中新增的transform属性, 子元素设置如下:
.son{
    position:absolute;
    left:50%;
    transform:translate(-50%,0);
}
    1. 使用绝对定位方式, 以及负值的margin-left, 子元素设置如下:
.son{
    position:absolute;
    width:固定;
    left:50%;
    margin-left:-0.5宽度;
}
    1. 使用绝对定位方式, 以及left:0;right:0;margin:0 auto; 子元素设置如下:
.son{
    position:absolute;
    width:固定;
    left:0;
    right:0;
    margin:0 auto;
}

垂直居中

单行文本

    1. 若元素是单行文本, 则可设置 line-height 等于父元素高度

行内块级元素

    1. 若元素是行内块级元素, 基本思想是使用display: inline-block, vertical-align: middle(该属性定义行内元素的基线相对于该元素所在行的基线的垂直对齐)和一个伪元素让内容块处于容器中央.
.parent::after, .son{
    display:inline-block;
    vertical-align:middle;
}
.parent::after{
    content:'';
    height:100%;
}
    1. 可用 vertical-align 属性, 而vertical-align只有在父层为 td 或者 th 时, 才会生效, 对于其他块级元素, 例如 div、p 等, 默认情况是不支持的. 为了使用vertical-align, 我们需要设置父元素display:table, 子元素 display:table-cell;vertical-align:middle;

优点

元素高度可以动态改变, 不需再CSS中定义, 如果父元素没有足够空间时, 该元素内容也不会被截断.

缺点

IE6~7, 甚至IE8 beta中无效.

    1. 可用 Flex 2012版, 这是CSS布局未来的趋势. Flexbox是CSS3新增属性, 设计初衷是为了解决像垂直居中这样的常见布局问题
      父元素做如下设置即可保证子元素垂直居中:
.parent {
  display: flex;
  align-items: center;
}

优点

内容块的宽高任意, 优雅的溢出.
可用于更复杂高级的布局技术中.

缺点

IE8/IE9不支持
需要浏览器厂商前缀
渲染上可能会有一些问题

    1. 使用flex 2009版.
.parent {
    display: box;
    box-orient: vertical;
    box-pack: center;
}

优点

实现简单, 扩展性强

缺点

兼容性差, 不支持IE

    1. 可用 transform , 设置父元素相对定位(position:relative), 子元素如下css样式:
.son{
    position:absolute;
    top:50%;
    -webkit-transform: translate(-50%,-50%); 
    -ms-transform: translate(-50%,-50%);
    transform: translate(-50%,-50%);
}

优点

代码量少

缺点

IE8不支持, 属性需要追加浏览器厂商前缀, 可能干扰其他 transform 效果, 某些情形下会出现文本或元素边界渲染模糊的现象.

元素高度固定

    1. 设置父元素相对定位(position:relative), 子元素如下css样式:
.son{
    position:absolute;
    top:50%;
    height:固定;
    margin-top:-0.5高度;
}

优点

适用于所有浏览器.

缺点

父元素空间不够时, 子元素可能不可见(当浏览器窗口缩小时,滚动条不出现时).如果子元素设置了overflow:auto, 则高度不够时, 会出现滚动条.

    1. 设置父元素相对定位(position:relative), 子元素如下css样式:
.son{
    position:absolute;
    height:固定;
    top:0;
    bottom:0;
    margin:auto 0;
}

优点

简单

缺点

没有足够空间时, 子元素会被截断, 但不会有滚动条.

总结

水平居中较为简单, 共提供了8种方法, 一般情况下 text-align:center,marin:0 auto; 足矣

① text-align:center;
② margin:0 auto;
③ width:fit-content;
④ flex
⑤ 盒模型
⑥ transform
⑦ ⑧ 两种不同的绝对定位方法
垂直居中, 共提供了8种方法.

① 单行文本, line-height
② 行内块级元素, 使用 display: inline-block, vertical-align: middle; 加上伪元素辅助实现
③ vertical-align
④ flex
⑤ 盒模型
⑥ transform
⑦ ⑧ 两种不同的绝对定位方法

我们发现, flex, 盒模型, transform, 绝对定位, 这几种方法同时适用于水平居中和垂直居中.

6.Flex相关

https://www.ruanyifeng.com/blog/2015/07/flex-grammar.html

  • flex是FlexibleBox的缩写意思为弹性布局,用来为盒状模型提供最大的灵活性,flex布局子元素的float、clear、vertical-align属性失效

  • 属性值

1.flex-direction:决定项目的排列方向包括row|row-reverse|column|column-reverse

2.flex-wrap:默认为一条线,它定义如果拍不下如何换行包括nowrap|wrap|wrap-reverse(第一行在下方)

3.flex-flow:是前两个的简写形式即 ||

4.justify-content:项目在主轴上的对齐方式包括flex-start|flex-end|center|space-between|space-around(元素之间的间隔比与边框之间的间隔大一倍)

5.align-items:定义项目在交叉轴(一根轴线)上如何对齐flex-start|flex-end|center|baseline(平均在一条线上)|strech

6.align-content多根轴线的对齐方式,只有一根不起作用包括flex-start|flex-end|center|space-between|space-around(每根轴线两侧的间隔都相等。所以,轴线之间的间隔比轴线与边框的间隔大一倍)|strech

7.order:定义项目的排列顺序,数值越小越靠前默认为0

8.flexflex-grow|flex-shrink|flex-basis默认1 0 auto,三个属性值可单独写但不推荐,auto:1 1 auto(即自动铺满),none:0 0 auto(不能伸缩)

9align-self:允许单个和其他的项目不一样的对齐方式,可以覆盖align-items,默认auto,值与align-items一样

7.除了flex布局还有哪些布局

  • flex只兼容ie10以上的浏览器(最大痛点),而且老版的flex的写法还不一样,一会儿display:box,一会儿display:flex,还要做兼容处理。
  • table布局

8.transform介绍一下

http://www.divcss5.com/css3-style/c55513.shtml

Transform字面上就是变形,改变的意思。在CSS3中transform主要包括以下几种:旋转rotate、扭曲skew、缩放scale和移动translate以及矩阵变形matrix。

//transform中使用多个属性时却需要有空格隔开
transform : none |  [  ]* 

transform: rotate | scale | skew | translate |matrix;
  • 1.rotate() :通过指定的角度参数对原元素指定一个2D rotation(2D 旋转),需先有transform-origin属性的定义。transform-origin定义的是旋转的基点,其中angle是指旋转角度,如果设置的值为正数表示顺时针旋转,如果设置的值为负数,则表示逆时针旋转。如:transform:rotate(30deg)
//使元素围绕X轴、Y轴、Z轴旋转
transform:rotateX(45deg);
 
transform:rotateY(45deg);
 
transform:rotateZ(45deg);
 
transform:rotateX(45deg)rotateY(45deg)rotateZ(45deg);
 
transform:scale(0.5)rotateY(45deg)rotateZ(45deg);
  • 2.translate(x,y)水平方向和垂直方向同时移动(也就是X轴和Y轴同时移动);translateX(x)仅水平方向移动(X轴移动);translateY(Y)仅垂直方向移动(Y轴移动)
transform:translate(50px,50px);//水平方向上移动50px,垂直方向上移动50px
transform:translate(50px);//这种情况下视为只在水平方向上移动,垂直方向上不移动。
//使元素在X轴、Y轴、Z轴方向上进行移动
transform:translateX(50px);
transform:translateY(50px);
transform:translateZ(50px);
  • 3.transform:scale(0.5,2);//水平方向缩小一半,垂直方向放大一倍。
transform:scale(0.5);//缩小一半
transform:scale(0.5,2);//水平方向缩小一半,垂直方向放大一倍。
//按X轴、Y轴、Z轴进行缩放
transform:scaleX(0.5);
transform:scaleY(1);
transform:scaleZ(2);
transform:scaleX(0.5)scaleY(1);
transform:scale(0.5)rotateY(45deg);
  • 4.使用skew方法实现文字或图像的倾斜处理,在参数中分别指定水平方向上的倾斜角度与垂直方向上的倾斜角度。
transform:skew(30deg,30deg);//水平方向上倾斜30度,垂直方向上倾斜30度。
transform:skew(30deg)//这种情况下视为只在水平方向上进行倾斜,垂直方向上不倾斜。
transform:skewX(45deg);
transform:skewY(45deg);
  • 5.对一个元素使用多种变形的方法
transform:translate(150px,200px)rotate(45deg)scale(1.5);
  • 6.指定变形的基准点(在使用transform方法进行文字或图像变形的时候,是以元素的中心点为基准点进行变形的。)
transform:rotate(45deg);
transform-origin:leftbottom;//把基准点修改为元素的左下角
//基准点在元素水平方向上的位置:left、center、right
//基准点在元素垂直方向上的位置:top、center、bottom

9.介绍position

CSS position属性用于指定一个元素在文档中的定位方式。top、right、bottom、left 属性则决定了该元素的最终位置。

窗体自上而下分成一行一行,并在每行中按从左至右的顺序排放元素;每个非浮动块级元素都独占一行, 浮动元素则按规定浮在行的一端,若当前行容不下,则另起新行再浮动;内联元素也不会独占一行,几乎所有元素(包括块级,内联和列表元素)均可生成子行,用于摆放子元素;有三种情况将使得元素脱离normal flow而存在,分别是 float,absolute ,fixed,但是在IE6中浮动元素也存在于normal flow中。

  • position: static(默认)

该关键字指定元素使用正常的布局行为,即元素在文档常规流中当前的布局位置。此时 top、right、bottom、left 属性无效。

  • position: relative

该关键字下,元素先放置在未添加定位时的位置,再在不改变页面布局的前提下调整元素位置(因此会在此元素未添加定位时所在位置留下空白)。position:relative 对 table-*-group, table-row, table-column, table-cell, table-caption 元素无效。

  • position: absolute

不为元素预留空间,通过指定元素相对于最近的非 static 定位祖先元素的偏移,来确定元素位置。绝对定位的元素可以设置外边距(margin),且不会与其他边距合并。

  • position: fixed

不为元素预留空间,而是通过指定元素相对于屏幕视口(viewport)的位置来指定元素位置。元素的位置在屏幕滚动时不会改变。打印时,元素会出现在的每页的固定位置。fixed属性会创建新的层叠上下文。当元素祖先的 transform 属性非 none 时,容器由视口改为该祖先。个人理解:fixed相对于window固定,滚动浏览器窗口并不会使其移动,会脱离normal flow。

  • position: sticky

盒位置根据正常流计算(这称为正常流动中的位置),然后相对于该元素在流中的 flow root(BFC)和 containing block(最近的块级祖先元素)定位。在所有情况下(即便被定位元素为 table时),该元素定位均不对后续元素造成影响。当元素 B 被粘性定位时,后续元素的位置仍按照 B 未定位时的位置来确定。position: sticky对 table元素的效果与 position: relative 相同。

  • position: inherit

规定应该从父元素继承 position 属性的值。

10.img src为什么不能用空 应该用什么

img标签src为空的陷阱

出现一次这样的标签会导致向你的服务器多做一次请求。

  • 在IE中,这样做会请求一次当前页面所在的目录。如在http://playgoogle.com/demo/a.html 中出现这种空src的标签,会导致重新请求一次://playgoogle.com/demo/

  • 在Safari 和 Chrome中,将请求当前页面本身。

  • 在Firefox 3.5以前的版本中,有和Safari同样的问题,但是在3.5中修正了这个BUG。

  • 在Opera 中,不会做额外的请求。

在一个访问量不高的网站中,多一个这样的请求也无所谓(甚至可以让你的网站浏览看上去翻番),但在一个千万级访问量甚至更高的WEB站点里,这样会导致你的服务器和带宽的成本显著增加。 另外一个隐患是,重新请求某个页面可能会导致用户的一些信息被无意中修改,例如cookies,或者ajax操作。

其他的标签中的空src会不会导致这样的问题? 好消息是,在IE中只有image标签有这个问题。坏消息是,在Chrome, Safari, 和 Firefox中

  • 媒体查询

媒体查询可以让我们根据设备显示器的特性(如视口宽度、屏幕比例、设备方向:横向或纵向)为其设定CSS样式,媒体查询由媒体类型和一个或多个检测媒体特性的条件表达式组成。





/* 大屏幕 */
@media only screen and (min-width:1200px) {
}
/* 中等屏幕 */
@media only screen and (min-width: 992px)and (max-width: 1199px) {
}
/* 小屏幕 */

页面大于 768px, 小于 991px 时显示的样式效果

@media only screen and (min-width: 768px)and (max-width: 991px) {
}
/* 手机端显示 */
屏幕小于 767px 时的样式
@media only screen and (max-width: 767px) {
}
  • 响应式布局

用百分比去写元素的宽度不要写绝对宽度,让子元素撑起父元素的高度不写绝对高度,字体使用相对大小em或rem

h1 {
    font-size: 2rem;
}

1.浏览器默认字体为 16px ,2rem 即 2 * 16px = 32px
2.em(font size of the element)是指相对于父元素的字体大小的单位,如当前对行内文本的字体尺寸未被人为设置,则相对于浏览器的默认字体尺寸,因此 em 的大小并不是固定的
3.rem是指相对于根元素的字体大小的单位,目前,除了IE8及更早版本外,所有浏览器均已支持rem。
对于不支持它的浏览器,应对方法也很简单,就是多写一个绝对单位的声明。
这些浏览器会忽略用rem设定的字体大小。
h1 {
    font-size: 32px;
    font-size: 2rem;
}

12.form表单包括哪些

  • 普通文本框:
  
  • 密码框:
  
  • 单选按钮:
  
  • 多选框:
  
  • 下拉菜单:
  
  描述
  描述
  
  • 按钮:
  //提交按钮:
  
  //图片提交:
  
  //普通按钮:没有任何意义的按钮,和js关联使用
  
  //重置按钮:
  
  //隐藏域:在浏览器中看不到的传递数据表单
  
  //多行文本域:
  

13.html标签的一些共有的属性有哪些

  • id:用来给标签取一个唯一的名称。id名称在一个网页必须是唯一的。

  • class:用来给标签取一个类名。

  • style:用来设置该标签的行内样式。

  • title:当鼠标移到该标签,所显示的提示内容

14.html5的新特性

  • 语义化标签(为页面提供了更好的页面结构。)
//定义文档的头部区域
//定义文档的尾部区域 //定义文档的导航区域
//定义文档的段落
//定义页面独立的内容区域 //定义页面侧边栏内容 //定义命令按钮
//标签包含 details 元素的标题 //定义对话框
  • 增强型表单(多个新的表单输入类型)
//类型
color	//主要用于选取颜色
date	//从一个日期选择器选择一个日期
datetime	//选择一个日期(UTC 时间)
datetime-local	//选择一个日期和时间 (无时区)
email	//包含 e-mail 地址的输入域
month	//选择一个月份
number	//数值的输入域
range	//一定范围内数字值的输入域
search	//用于搜索域
tel	//定义输入电话号码字段
time	//选择一个时间
url	 //URL 地址的输入域
week	//选择周和年

//新的表单属性
//1.placehoder 属性,简短的提示在用户输入值前会显示在输入域上。即我们常见的输入框默认提示,在用户输入后消失。
//2、required  属性,是一个 boolean 属性。要求填写的输入域不能为空
//3、pattern 属性,描述了一个正则表达式用于验证 元素的值。
//4、min 和 max 属性,设置元素最小值与最大值。
//5、step 属性,为输入域规定合法的数字间隔。
//6、height 和 width 属性,用于 image 类型的  //标签的图像高度和宽度。
//7、autofocus 属性,是一个 boolean 属性。规定在页面加//载时,域自动地获得焦点。
//8、multiple 属性 ,是一个 boolean 属性。规定 元素中可选择多个值。
  • 音频和视频



  • canvas 绘图
    (见canvas绘图相关)

  • SVG 绘图(可伸缩的矢量图形)

SVG 是一种使用 XML 描述 2D 图形的语言。Canvas 通过 JavaScript 来绘制 2D 图形。SVG 基于 XML,这意味着 SVG DOM 中的每个元素都是可用的。您可以为某个元素附加 JavaScript 事件处理器。在 SVG 中,每个被绘制的图形均被视为对象。如果 SVG 对象的属性发生变化,那么浏览器能够自动重现图形。Canvas 是逐像素进行渲染的。在 canvas 中,一旦图形被绘制完成,它就不会继续得到浏览器的关注。如果其位置发生变化,那么整个场景也需要重新绘制,包括任何或许已被图形覆盖的对象。

  • 地理定位(Geolocation用于定位用户的位置)
window.navigator.geolocation {
    getCurrentPosition:  fn  用于获取当前的位置数据
    watchPosition: fn  监视用户位置的改变
    clearWatch: fn  清除定位监视
}   

navigator.geolocation.getCurrentPosition(
    function(pos){
    console.log('用户定位数据获取成功')
    //console.log(arguments);
    console.log('定位时间:',pos.timestamp)
    console.log('经度:',pos.coords.longitude)
    console.log('纬度:',pos.coords.latitude)
    console.log('海拔:',pos.coords.altitude)
    console.log('速度:',pos.coords.speed)

},    //定位成功的回调
function(err){ 
    console.log('用户定位数据获取失败')
    //console.log(arguments);

}        //定位失败的回调
)
  • 拖放API(任何元素都能够拖放)

在HTML5中,拖拽(draganddrop)成为了标准操作,任何元素都支持。

//设置元素可拖放

//拖动什么 - ondragstart 和 setData()
function drag(ev)
{
ev.dataTransfer.setData("Text",ev.target.id);
}
//放到何处 - ondragover
event.preventDefault()
//进行放置 - ondrop
function drop(ev)
{
ev.preventDefault();
var data=ev.dataTransfer.getData("Text");
ev.target.appendChild(document.getElementById(data));
}
//拖放(Drag 和 Drop)各属性生命周期
//拖动开始	ondragstart	script
//拖动过程中	ondrag	script
//拖动过程中	ondragenter	script
//拖动过程中	ondragover	script
//拖动过程中	ondragleave	script	
//拖动结束	ondrop	script	
//拖动结束	ondragend

//写在哪呢?
//被拖放的元素


//目标元素
  • Web Storage
//localStorage :没有时间限制的数据存储
//sessionStorage : 针对一个 session 的数据存储, 当用户关闭浏览器窗口后,数据会被删除。
//常用的API
//1、保存数据:localStorage.setItem(key,value);
//2、读取数据:localStorage.getItem(key);
//3、删除单个数据:localStorage.removeItem(key);
//4、删除所有数据:localStorage.clear();
//5、得到某个索引的key:localStorage.key(index);
  • WebSocket

WebSocket 是HTML5开始提供的一种在单个 TCP 连接上进行全双工通讯的协议。在WebSocket API中,浏览器和服务器只需要做一个握手的动作,然后,浏览器和服务器之间就形成了一条快速通道。两者之间就直接可以数据互相传送。

浏览器通过 JavaScript 向服务器发出建立 WebSocket 连接的请求,连接建立以后,客户端和服务器端就可以通过 TCP 连接直接交换数据。

当你获取 Web Socket 连接后,你可以通过 send() 方法来向服务器发送数据,并通过 onmessage 事件来接收服务器返回的数据。



   
   
   W3Cschool教程(w3cschool.cn)
    
      
   
   
      
   

iframe

iframe标签能解决在一个页面张添加不同的HTML文件,选择不同的地址可以进入不同的页面中去,在同一个页面中修改其中某一块的内容来达到菜单切换的效果

	

1.name:内嵌帧的名称

2.width:内嵌帧的宽度(可用像素值和百分比)

3.height:内嵌帧的高度(可用像素值和百分比)

4.frameborder:内嵌帧的边框,一般设置为0

5.scrolling:是否出现滚动条(auto为自动,yes为显示,no为不显示)

6.src:内嵌入文件的地址

//高度自适应设置

                    
                    

你可能感兴趣的:(前端开发,css,html5,css3)