前端面试题汇总(含答案)(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-function> [ <transform-function> ]* 

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中<script src=“”> 和<link href=“”>都会导致出现一个新的请求。

如何解决这个问题? 可以从两方面着手,一是尽量避免这种坏的编程方式,不要出现空的src标签。另外,可以从服务器端着手,在发现时这种无意义的请求时不要返回任何东西给客户端。

边距塌陷的解决方法

会导致外边距塌陷的两种情况

  • 情况一:两个兄弟盒子,上面的盒子设置了margin-bottom,下面的盒子设置了margin-top,实际中会取值较大的那个属性值显示在网页中。这种情况一般较为少见。这两个属性只设置一个即可解决。

  • 情况二:嵌套盒子(父元素与子元素)间的外边距塌陷(发生在垂直方向上的外边距合并,注意是垂直方向)

解决情况二的外边距塌陷一共有三种方法
方法一:给父元素加边框border
方法二:给父元素加内边距padding以达到类似效果
方法三:给父元素设置overflow:hidden;

11.页面适配的方法有哪些?

  • 一、固定布局(pc端)(静态布局)

以像素作为页面的基本单位,不管设备和浏览器宽度,只设计一套尺寸(这种不太现实)

  • 根据不同根据不同的分辨率,加载不同的CSS样式文件(可切换的固定布局)自适应布局
<script>
	// 分辨率大于等于1680,大部分为1920的范围情况下,调用此css
	if(window.screen.width >= 1680){
		document.write('<link rel="stylesheet" href="css/index_1920.css">');
	}
	// 分辨率在1600-1680这个范围的情况下,调用此css
	else if(window.screen.width >= 1600){
		document.write('<link rel="stylesheet" href="css/index_1600.css">');
	}
	// 分辨率小于1600的范围情况下,调用此css
	else{
		document.write('<link rel="stylesheet" href="css/index.css">');
	}
</script>
  • 媒体查询

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

<link rel="stylesheet" media="(max-width: 800px)" href="example.css" />

<meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=no">

/* 大屏幕 */
@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表单包括哪些

  • 普通文本框:
  <input type="text"name="名称"value="值"value="不写value默认为空"/>
  • 密码框:
  <input type="password"name="名称"value="值"value="不写value默认为空"/>
  • 单选按钮:
  <input type="radio"name="一组名称"value="值"/>
  • 多选框:
  <input type="select"name="一组名称"value="值"/>
  • 下拉菜单:
  <selectname=”名称”>
  <optionvalue=”值”>描述</option>
  <optionvalue=”值”>描述</option>
  </select>
  • 按钮:
  //提交按钮:
  <input type=”submit”value=”显示到按钮上的名称”/>
  //图片提交:
  <input type=”imaget”src=”图片地址”value=””/>
  //普通按钮:没有任何意义的按钮,和js关联使用
  <input type=”button”name=”值”value=”值”>
  //重置按钮:
  <input type=”reset”name=”值”value=”名称”/>
  //隐藏域:在浏览器中看不到的传递数据表单
  <input type=”hidden”name=”值”value=”值”/>
  //多行文本域:
  <textarearows=”行”cols=”列”value=”值”name=”值”></textarea>

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

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

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

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

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

14.html5的新特性

  • 语义化标签(为页面提供了更好的页面结构。)
<header></header>	 //定义文档的头部区域
<footer></footer>	//定义文档的尾部区域
<nav></nav>	//定义文档的导航区域
<section></section>	//定义文档的段落
<article></article>	//定义页面独立的内容区域
<aside></aside>	//定义页面侧边栏内容
<command></command>	//定义命令按钮
<details></details>	//标签包含 details 元素的标题
<dialog></dialog>	//定义对话框
  • 增强型表单(多个新的表单输入类型)
//类型
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 属性,描述了一个正则表达式用于验证<input> 元素的值。
//4、min 和 max 属性,设置元素最小值与最大值。
//5、step 属性,为输入域规定合法的数字间隔。
//6、height 和 width 属性,用于 image 类型的 <input> //标签的图像高度和宽度。
//7、autofocus 属性,是一个 boolean 属性。规定在页面加//载时,域自动地获得焦点。
//8、multiple 属性 ,是一个 boolean 属性。规定<input> 元素中可选择多个值。
  • 音频和视频
<audio controls>
  <source src="xxx.ogg" type="audio/ogg">
  <source src="xxx.mp3" type="audio/mpeg">
您的浏览器不支持 audio 元素。
</audio>

<video width="500" height="300" controls>
  <source src="xxx.mp4" type="video/mp4">
  <source src="xxx.ogg" type="video/ogg">
您的浏览器不支持Video标签。
</video>
  • 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)成为了标准操作,任何元素都支持。

//设置元素可拖放
<img draggable="true" />
//拖动什么 - 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

//写在哪呢?
//被拖放的元素
<span draggable="true" id="Span1" ondragstart="fooDragStart(this, event)" ondrag="fooDrag(this, event)" ondragend="fooDragEnd(this, event)">
<img src="../images/yjj_1.png"></span>
//目标元素
<div  id="div1" ondrop="fooDrop(this, event)"
                            ondragenter="fooDragEnter(this, event)" ondragleave="fooDragLeave(this, event)"
                            ondragover="fooDragOver(this,event)">
                        </div>
  • 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 事件来接收服务器返回的数据。

<!DOCTYPE HTML>
<html>
   <head>
   <meta charset="utf-8">
   <title>W3Cschool教程(w3cschool.cn)</title>
    
      <script type="text/javascript">
         function WebSocketTest()
         {
            if ("WebSocket" in window)
            {
               alert("您的浏览器支持 WebSocket!");
               // 打开一个 web socket
               var ws = new WebSocket("ws://localhost:9998/echo");
               ws.onopen = function()
               {
                  // Web Socket 已连接上,使用 send() 方法发送数据
                  ws.send("发送数据");
                  alert("数据发送中...");
               };
               ws.onmessage = function (evt) 
               { 
                  var received_msg = evt.data;
                  alert("数据已接收...");
               };
               ws.onclose = function()
               { 
                  // 关闭 websocket
                  alert("连接已关闭..."); 
               };
            }
            else
            {
               // 浏览器不支持 WebSocket
               alert("您的浏览器不支持 WebSocket!");
            }
         }
      </script>
   </head>
   <body>
      <div id="sse">
         <a href="javascript:WebSocketTest()">运行 WebSocket</a>
      </div>
   </body>
</html>

iframe

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

	<iframe name="iframename" src="../hong1.html"
		id="myiframe" frameborder="0" scrolling="no"
		style="width: 100%; border: 0px; overflow: hidden;"
		 onload="this.height=this.contentWindow.document.documentElement.scrollHeight">
		 </iframe>

1.name:内嵌帧的名称

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

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

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

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

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

//高度自适应设置
<script type="text/javascript">
	var myiframdocumgetElement('myiframe');
	myifraddEventList('load', function() {
	  myiframe.height = getHeight(myiframe.contentDocument);;
	});
			
	function getHe(doc) {
	  var body = doc.body,
	      html = doc.documentElement;
			
	  var height = Math.max( body.scrollHeight, body.offsetHeight,
	    html.clientHeight, html.scrollHeight, html.offsetHeight );
	  return height;
	}
	script>
  • iframe框架调用
<a class="bg1" href="../hong1.html" target="iframename">红色经典1</a>

<a class="bg2" href="../hong2.html" target="iframename">红色经典2</a>

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值