1.伪类与伪元素的区别?

1) 定义区别

伪类

伪类用于选择DOM树之外的信息,
或是不能用简单选择器进行表示的信息。
前者包含那些匹配指定状态的元素,
比如:visited,:active;
后者包含那些满足一定逻辑条件的DOM树中的元素,
比如:first-child,:first-of-type,:target。 伪元素
伪元素为DOM树没有定义的虚拟元素。
不同于其他选择器,它不以元素为最小选择单元,
它选择的是元素指定内容。
比如::before表示选择元素内容的之前内容,
也就是"";::selection表示选择元素被选中的内容。                

2) 语法区别

在CSS3中,伪类与伪元素在语法上也有所区别,
伪元素修改为以::开头。
但因为历史原因,
浏览器对以:开头的伪元素也继续支持,
但建议规范书写为::开头。

3) 伪类/伪元素一览表

<伪类如下>
1:active 选择正在被激活的元素  
1:hover  选择被鼠标悬浮着元素  
1:link   选择未被访问的元素  
1:visited    选择已被访问的元素  
1:first-child    选择满足是其父元素的第一个子元素的元素
2:lang   选择带有指定 lang 属性的元素  
2:focus  选择拥有键盘输入焦点的元素  
2:enable 选择每个已启动的元素  
3:disable    选择每个已禁止的元素  
3:checked    选择每个被选中的元素  
3:target 选择当前的锚点元素   <伪元素如下>
::first-letter  选择指定元素的第一个单词
1::first-line    选择指定元素的第一行  
1::after 在指定元素的内容后面插入内容  
2::before    在指定元素的内容前面插入内容  
2::selection 选择指定元素中被用户选中的内容

2. css样式优先级,各自的权重

优先级别:

通用选择器
(*) < 元素(类型)选择器 < 类选择器 <
属性选择器
< 伪类 < ID 选择器 < 内联样式 权重: 第一等:
代表内联样式,
如:
style=””,权值为1000。
第二等:代表ID选择器,
如:
#content,权值为100。
第三等:代表伪类和属性选择器,
如.content,权值为10。
第四等:
代表类型选择器和伪元素选择器,
如div p,权值为1。

3.常见的DOM操作有哪些?

主要操作包括:
查找节点,新建节点,添加节点,删除节点,修改节点;

开发中,我们用到最多的是element类型,

用于表现HTML元素,

提供了对元素标签名、子节点及特性的访问。

1)DOM常用操作举例:

// 查找节点
document.getElementById('id属性值');
// 返回拥有指定id的第一个对象的引用        
document.getElementsByClassName('class属性值');
// 返回拥有指定class的对象集合

2)新建节点:

// 创建新的元素节点
document.createElement('元素名');
// 创建新的属性节点
document.createAttribute('属性名');
// 创建新的文本节点
document.createTextNode('文本内容');
// 创建新的注释节点
document.createComment('注释节点');

3)添加节点:

var element = 
document.getElementsByTagName('p')[0];
element.innerHTML='新增文本内容'; //插入文本内容

4)删除节点:

parentNode.removeChild( existingChild );
//删除已有的子节点,返回值为删除节点
element.removeAttribute('属性名');
// 删除具有指定属性名称的属性,无返回值
element.removeAttributeNode( attrNode );
// 删除指定属性,返回值为删除的属性

5)修改节点:

// 添加属性节点,修改属性值
element.setAttribute( attributeName, attributeValue );

6)属性节点:

// 增添id属性,并修改class属性值
var element =
document.getElementsByTagName('p')[0];
// 添加属性节点
var attr =
document.createAttribute('id');
attr.value = 'idValue';
element.setAttributeNode(attr);
// 修改属性值
var attr =
document.createAttribute('class');
attr.value = 'classNewValue';
element.setAttributeNode(attr);

7)DOM事件:

允许 JavaScript 对 HTML 事件作出反应,主要包括:

onclick 事件——当用户点击时
onload 事件——用户进入
onunload 事件——用户离开
onmouseover事件——鼠标移入
onmouseout事件——鼠标移出
onmousedown事件——鼠标按下
onmouseup 事件——鼠标抬起

4.判断数据类型有哪些方法?

1)typeof

typeof 是一个操作符,其右侧跟一个一元表达式,
并返回这个表达式的数据类型。
返回的结果用该类型的字符串(全小写字母)形式表示,
包括以下 7 种:
number、boolean、symbol、string、
object、undefined、function 等。

2) instanceof

instanceof 
是用来判断 A 是否为 B 的实例,
表达式为:A instanceof B,
如果 A 是 B 的实例,
则返回 true,否则返回 false。
在这里需要特别注意的是:
instanceof 检测的是原型

3) constructor

当一个函数 F被定义时,
JS引擎会为F添加 prototype 原型,
然后再在 prototype上添加一个 constructor 属性,
并让其指向 F 的引用。

4)toString

toString() 
是 Object 的原型方法,
调用该方法,
默认返回当前对象的 [[Class]]点击并拖拽以移动 。
这是一个内部属性,
其格式为 [object Xxx] ,
其中 Xxx 就是对象的类型。
对于 Object 对象,
直接调用 toString()  
就能返回 [object Object] 。
而对于其他对象,
则需要通过
call / apply 来调用才能返回正确的类型信息。

5.介绍一下 JS 的基本数据类型?

Undefined、Null、Boolean、Number、String

6.介绍一下 JS 有哪些内置对象?

Object 
是 JavaScript 中所有对象的父对象;
数据封装类对象:
Object、Array、Boolean、Number、String
其他对象:
Function、Argument、Math、Date、RegExp、Error

7.push()-pop()-shift()-unshift()分别是什么功能?

// push 方法
// 将新元素添加到一个数组中,并返回数组的新长度值。
var a=[1,2,3,4];
a.push(5);// pop 方法// 移除数组中的最后一个元素并返回该元素。
var a=[1,2,3,4];
a.pop();// shift 方法// 移除数组中的第一个元素并返回该元素。
var a=[1,2];
a.shift();// unshift 方法// 将指定的元素插入数组开始位置并返回该数组。
var a=[1,2];
a.unshift(0);

8.null 和 undefined 有何区别?

1) null 表示一个对象被定义了,值为“空值”; 
undefined 表示不存在这个值。
typeof undefined //"undefined"
2) undefined :
是一个表示"无"的原始值或者说表示"缺少值",
就是此处应该有一个值,但是还没有定义。
当尝试读取时会返回 undefined;
例如变量被声明了,
但没有赋值时,
就等于undefined。 typeof null //"object"  null :
是一个对象(空对象, 没有任何属性和方法); 3) 注意:
在验证null时,一定要使用 === ,
因为 == 无法分别 null 和 undefined

9.new操作符具体干了什么?

1)  创建一个空对象,并且 this 变量引用该对象。
2)  属性和方法被加入到 this 引用的对象中。
3)  新创建的对象由 this 所引用。

10.你对 JSON 了解吗?

1) JSON(JavaScript Object Notation)
是一种轻量级的数据交换格式。
2) 它是基于JavaScript的一个子集。
数据格式简单,易于读写,占用带宽小。
如:{"age":"12", "name":"back"}

 

Web大前端面试题-Day2的更多相关文章

  1. Web大前端面试题-Day12

    1.前端需要注意哪些SEO? 合理的title.description.keywords: 搜索对着三项的权重逐个减小, title值强调重点即可, 重要关键词出现不要超过2次, 而且要靠前, 不同页 ...

  2. Web大前端面试题-Day7

    1. 你能描述一下渐进增强和优雅降级之间的不同吗? 定义: 优雅降级(graceful degradation): 一开始就构建站点的完整功能, 然后针对浏览器测试和修复 渐进增强(progressi ...

  3. Web大前端面试题-Day6

    1.请说明ECMAScript, JavaScript, Jscript之间的关系? ECMAScript提供脚本语言必须遵守的规则. 细节和准则,是脚本语言的规范. 比如:ES5,ES6就是具体的一 ...

  4. Web大前端面试题-Day4

    1. 如何实现瀑布流? 瀑布流布局的原理:1) 瀑布流布局要求要进行布置的元素等宽,   然后计算元素的宽度,   与浏览器宽度之比,得到需要布置的列数;2) 创建一个数组,长度为列数,   里面的值 ...

  5. Web大前端面试题-Day11

    86.如何获得高效的数据库逻辑结构? 从关系数据库的表中 删除冗余信息的过程 称为数据规范化, 是得到高效的关系型数据库表的逻辑结构 最好和最容易的方法. 规范化数据时应执行以下操作: 1.将数据库的 ...

  6. Web大前端面试题-Day10

    1. px和em的区别? px和em都是长度单位; 区别是: px的值是固定的,指定是多少就是多少, 计算比较容易. em得值不是固定的,并且em会继承父级元素的字体大小. 浏览器的默认字体高都是16 ...

  7. Web大前端面试题-Day8

    1. 说说你对作用域链的理解? 作用域链的作用是保证执行环境里 有权访问的变量和函数是有序的, 作用域链的变量只能向上访问, 变量访问到window对象即被终止, 作用域链向下访问变量是不被允许的; ...

  8. Web大前端面试题-Day1

    1. var的变量提升的底层原理是什么? JS引擎的工作方式是:1) 先解析代码,获取所有被声明的变量:2)然后在运行.也就是说分为预处理和执行两个阶段. 变量提升:所有变量的声明语句都会被提升到代码 ...

  9. Web大前端面试题-Day9

    1. 请用至少3中方式实现数组去重? 方法一: indexOfvar arr1=[1,2,3,4,5,4,3,2,1];  function repeat1(arr){    for(var i=0, ...

随机推荐

  1. C# 基于MySQL的数据层基类(MySQLHelper)

    这里介绍下比较简单的方式,引用MySql.Data.dll然后添加一个MySqlHelper类来对MySql数据库进行访问和操作. 1.将MySql.Data.dll引用到你的项目中 下载地址:MyS ...

  2. 菜单栏--Dom选择器

    制作一个左侧菜单栏,包含菜单目录和内容 点击菜单栏才会展示内容,否则隐藏内容 二.事例 2.1 菜单栏基本样式 <body> <div style="height: 48p ...

  3. Java基础-Java中的并法库之线程池技术

    Java基础-Java中的并法库之线程池技术 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.什么是线程池技术 二.

  4. docker 原理

    docker项目的目标是实现轻量级的操作系统虚拟化,Docker的基础是Linux容器(LXC)等技术. 在LXC的基础上,Docker做了进一步的封装,让用户不关心容器的管理,使得操作更为简单.用户 ...

  5. bzoj千题计划264:bzoj3884: 上帝与集合的正确用法

    http://www.lydsy.com/JudgeOnline/problem.php?id=3884 欧拉降幂公式 #include<cmath> #include<cstdio ...

  6. 《Two Dozen Short Lessons in Haskell》(二十四)代数类型

    这是<Two Dozen Short Lessons in Haskell>这本书的最后一章,第23章没有习题. 这一章里介绍了Haskell如果自定义一种类型,并且用一个双人博弈游戏为例 ...

  7. 使用JWPL (Java Wikipedia Library)操作维基百科数据

    使用JWPL (Java Wikipedia Library)操作维基百科数据 1. JWPL介绍 JWPL(Java Wikipedia Library)是一个开源的访问wikipeida数据的Ja ...

  8. 10个造型奇特的css3进度条(有的html被编辑器转义了,上面的代码还是OK的)。。。转载

    <div id="caseVerte"> <div id="case1"></div> <div id="c ...

  9. [ASP.NET]初试Web API

    Web API 1: 需要环境(VS2010/.Net4.0/MVC4 ) http://www.asp.net/web-api/overview/creating-web-apis/creating ...

  10. 6 个 Linux 运维典型问题,大牛的分析解决思路在这里 【转】

    作为一名合格的 Linux 运维工程师,一定要有一套清晰.明确的解决故障思路,当问题出现时,才能迅速定位.解决问题,这里给出一个处理问题的一般思路: 重视报错提示信息:每个错误的出现,都是给出错误提示 ...