1、什么是W3C标准
W3C-万维网联盟标准不是指的某一个标准,而是好多好多标准的集合。网页三大组成部分:结构、表现、行为。结构化标准主要包括XML(可扩展标记语言,它为文档的创建、结构的存储和编码提供了规则)和XTML(基于XML的HTML,大约是HTML的词汇表,HTML的目的是创建结构化的文档,提供文档的语义),表现标准主要就是CSS ,行为标准主要包括W3C DOM、ECMAScript等。
补充一点:
规范标准:1、标准规范可以有效的提高搜索引擎抓取页面数据的效率,对SEO(搜索引擎优化)很有帮助。
2、尽量使用外部css样式表和js脚本,可以使结构、表现、行为很好的分为三部分,符合规范,并且能够提高页面的渲染速度,从而提高用户体验。
3、样式尽量少用内联样式,使结构和表现分离开,标签的属性定义(class、id)要做到见文知意,标签越少,加载就越快,用户体验提高,代码维护简单,便于改版。
注:Jquery不符合W3C标准
2、HTML5新特性和HTML语义化标签
HTML5新特性:
HTML语义化:
3、CSS选择器
元素选择器、ID选择器、类选择器、通配符选择器(*)、并集选择器/组合选择器(多个不同的标签,应用相同的样式/声明冲突时。需要分开计算)
层级选择器
子级选择器(元素之间用>分割) 后代选择器(元素之间用空格分割)兄弟选择器(元素之间用+分隔)
伪类选择器
动态伪类选择器:link、visited只能用于a标签
结构伪类选择器:元素名:first-child第一个元素;last-child最后一个元素
否定伪类选择器:元素名:first-child第一个元素;last-child最后一个元素
伪元素选择器(CSS创建的元素,都是选中元素的子元素)
1、元素名:before(元素的第一个子元素)
2、元素名:after(元素的最后一个子元素)
3、元素名:first-letter(元素的第一个字)
4、元素名:first-line(元素的第一个行)
5、input:: -webkit-input-placeholder(修改输入框提示信息样式)
属性选择器
元素名称[“属性名”+“属性值”] 如:input [type = “text”]
4、CSS动画
css3中有三个关于动画的样式属性transform、transition和animation;
transform可以用来设置元素的形状改变。主要有以下几种变形:rotate(旋转)、scale(缩放)、skew(扭曲)、translate(移动)和matrix(矩形变形)
transition是用来设置样式的属性值是如何从从一种状态变平滑过渡到另外一种状态,它有四个属性:
transition-property(变化的属性,即那种形式的变换;大小、位置、扭曲等)
transition-timing-funct(变化的速率)
transition-delay(变换的延时)
animation比较类似于flash中逐帧动画,逐帧动画就像电影的播放一样,表现非常细腻并且有非常大的灵活性。然而transition只是制定了开始和结束态,整个动画的过程也是由特定的函数控制。学习过flash的同学知道,这种逐帧动画是由关键帧组成,很多个关键帧连续的播放就组成了动画,在css3中是由属性keyframes来完成逐帧动画的。
animationName:动画名称,开发人员自己命名;
percentage:为百分比值,可以添加多个百分比值
properties:样式属性名称,例如:color、left、width等
5、事件委托:
也称事件代理,就是利用冒泡的原理,把加事件到父级上,触发执行效果。(把原本需要绑定在子元素的响应事件委托给父元素,让父元素担当事件监听的职务)
事件委托原理:通过冒泡原理进行事件委托,我们可以把事件只加给父级ul,这样不管移入哪个li ,都会触发父级的移入事件。
前面提到事件委托的原理是DOM元素的事件冒泡,那么事件冒泡是什么呢?
一个事件触发后,会在子元素和父元素之间传播。这中传播分成三个阶段:
捕获阶段:从window对象传导到目标节点(上层传到底层)称为”捕获阶段“,捕获阶段不会响应任何事件;
目标阶段:在目标节点上触发,称为”目标阶段“
冒泡阶段:从目标节点传导回window对象(从底层传回上层),称为“冒泡阶段”。事件代理即是利用事件冒泡的机制把里层所需要响应的事件绑定到外层;
事件委托的优点:(1)可以大量节省内存占用,减少事件注册,比如在ul上代理所有的li的click事件就非常棒
(2)可以实现当新增子对象时无需再次对其绑定(动态绑定事件)
基本实现:(1)JS原生实现事件委托 (2)jQuery事件delegate()实现事件委托
delegate()方法为指定的元素(属于被选元素的子元素)添加一个或多个事件处理程序,并规定当这些事件发生时运行的函数
使用事件委托注意事项
使用“事件委托”时,并不是说把事件委托给的元素越靠近顶层越好。事件冒泡的过程也需要耗时,越靠近顶层,事件的”事件传播链“越长,也就越耗时。如果DOM嵌套结构很深,事件冒泡通过大量祖先元素会导致性能损失。
6、闭包
闭包就是能够读取其他函数内部变量的函数,只有函数内部的子函数才能读取局部变量,在本质上。闭包就是函数内部和 函数外部连接起来的桥梁。
如果在一个 内部函数里,对在外部作用域(但不是全局作用域)的变量进行引用,那么内部函数就被认为是闭包。
闭包的特点:
(1)可以读取自身函数外部的变量(沿着作用域寻找)先从自身开始查找,如果自身没有才会继续往上级查找,自身如果拥有将直接调用。(哪个离得最近就用哪一个)
(2)延长内部变量的生命周期。
(3)函数b嵌套在函数a内部
(4)函数a返回函数b
闭包的作用:
在函数a执行完并返回后,闭包使得JavaScript的垃圾回收机制不会收回a所占用的资源,因为a的内部函数b的执行需要依赖a中的变量,闭包需要循序渐进的过程。
应用场景:
1、保护函数内的变量安全,函数a中只有函数b才能访问,而无法通过其他途径访问到,因此保护了i的安全性。
2、在内存中维持一个变量。
闭包的缺点:滥用闭包会造成内存泄漏,因为闭包中引用的包裹函数中定义的变量都永远不会被释放,所以我们应该在必要的时候,及时释放这个闭包函数。
7、DOM
DOM即文档对象模型。是针对XML并经过扩展用于HTML的应用程序编程接口(API)
所以DOM本质上是一种接口(api),是专门操作网页内容的API标准
DOM把整个页面映射为一个多层节点结构,HTML或XML页面中的每个组成部分都是某种类型的节点。借助DOM提供的API,开发人员可以删、添加、替换或修改任何节点。
8、前端性能优化
减少https请求次数 比如 css精灵 把css和js压缩成一个文件 结构、表现、行为三模块分开 尽量不要使用内联样式 尽量使用html语义化标签
9、前端跨域问题及实现方法
jsonp 通过script标签 src属性传递访问 只适用于get请求方式
cors 修改请求头
postMessage
window.domain
10、响应式设计实现手机端适配
11、Ajax基本原理
1、创建xmlhttpRequest对象
2、向服务器段发送请求。利用open() 方法
3、服务器响应 拿到一个回调函数
4、发送请求 onreadystateChange 利用readyState 如果数据有改变 就触发onreadystateChange方法 从而数据更新
12、ES6基本语法
let const const定义常量 如果是基本数据类型 它的值就无法改变 如果是引用类型 比如 一个对象 它的属性值是可以改变的 因为刚开始创建的时候引用地址指向对象 所以可以改变 但是已经定义好的属性名字是不可以改变的。
箭头函数 :普通函数的一种缩写形式 箭头函数是一个匿名函数 没有this指向 谁调用就指向谁(固定不变的,一直指向的是定义函数的环境) 不会使用new 不能使用argument 和yied关键字 不能定义构造函数 箭头函数还没有原型属性 箭头函数不能通过call()、apply()、bind()方法直接修改它的this指向
promise 异步编程 从语法上讲 promise是一个对象,可以获取异步操作的消息
promise有三种状态:pedding正在请求,rejected失败,resolved成功
基本用法:在异步事件状态的pendding-resolved回调成功时,通过调用resolved函数返回结果;当异步操作失败时,回调用rejected函数显示错误信息。
原型 原型实例化对象和原型的constructor指向构造函数 构造函数的prototype属性指向原型对象 实例化对象的prototype属性,也是他的原型
13、块级作用域
顾名思义 在一个块里有效 。任何一对花括号中的语句都属于一个块,在这之中定义的所有变量在代码块外都是不可见的。 比如let就是一个块级作用域,只作用于当前代码块
14、箭头函数
参考第12点
15、promise管理回调函数
ES6中,可以通过promise来处理回调函数,回调函数经常用于异步操作中,间接来说,可以通过promise优化异步操作。
then可以在promise中实现链式调用,catch方法 相当于then(null,function(err){console.log(err)})
Promise.all 可以接受一个元素为Promise对象的数组作为参数,当这个数组里面所有的Promise对象都变为resolve时,该方法才会返回。
Promise.race race本身翻译过来就是赛跑的意思 就是 谁先回调成功谁就返回。
总结:Promise在定义的时候,在new的时候就会执行一次,因此如果要构造ajax请求可以在new Promise 里传递的这个函数内进行,在定义这个构造Promise的函数里面,可以判断什么时候是执行resolve,什么时候执行reject.
16、MVVM双向绑定的原理有一定的理解
M-数据(model) V-视图(view) VM-数据视图(model-view)
实现方式:(1)发布-订阅者模式 一般通过sub、pub的 方式实现数据和视图的绑定监听,更新数据方式通常做法是vm.set(‘属性值’,value)
(2)脏值检查:angular.js是通过脏值检测的方式比对数据是否有变更,来决定是否更新视图,在指定的事件触发时进入脏值检测
(3)数据劫持 vue.js则是采用数据劫持结合发布者-订阅者模式的方式,通过object.defineProperty()来劫持各个属性的setter、getter,在数据变动时发布消息给订阅者,触发响应的监听回调
17、常见Git常见命令的使用
git init 初始化
git branch 查看本地所有分支
git status 查看当前状态
git commit 提交
git push 将本地分支推送到服务器上去
git remote show 查看远程库
18、原型链
当访问一个对象的某个属性时,会先在它本身属性上找,如果没有就去它的隐式原型_proto_上找,即它的构造函数的prototype;如果还没有找到,就继续去它构造函数prototype的_proto_上找,这样一层一层的查找就会形成原型链。
原型、类、对象
(这里只是个人为了方便理解的一种方式)
原型
可理解为该类拥有的属性,若一个类想要操作一个属性,不能直接进行操作,必须通过原型来进行(函数对象里声明的变量不是属性),即原型、类、对象的关系可以进一步缩减理解为类和对象之间的关系,原型只是对象拥有的属性,类和对象能通过一些方法(prototype、proto)来访问到这个属性
function Person() {
}
Person.prototype.name = ‘Kevin’; // 通过原型
Person.sex = ‘boy’; // 直接操作
console.log(Person.prototype) // Person { name: ‘Kevin’}
console.log(Person.sex) // undefined 直接设置属性失败
console.log(Person.name) // undefined 直接读取属性失败
console.log(Person.prototype.name) // Kevin
类
声明对象功能并实例化一个对象
对象
每一个对象都拥有类的全部功能,当然也可拥有类的属性,而类的属性存放在原型,通过原型进行操作,因此当对象要拿到类属性,只能在原型中拿(当对象中添加了同名属性时,优先度对象>类),当对象中找不到指定属性时,才会往上层寻找。
function Person() {
}
Person.prototype.name = ‘Kevin’;
var person = new Person();
person.name = ‘Daisy’;
console.log(person.name) // Daisy
delete person.name; // 删除成员person中刚添加的name属性
console.log(person.name) // Kevin
对象、类、原型、Object之间的关系
Object.prototype.age = ‘24’;
function Person() {
}
var person = new Person();
Person.prototype.age_ = ‘23’;
console.log(Person.prototype); // Person { age_: 23 }
console.log(Person.prototype.age) // 上面显示的是原型自己内部的属性,实际自己也继承了Object原型的age
console.log(Person.age); // 24
console.log(person.age_); // 23
可以分为两条链路理解:
Object原型 → Object类 → Object对象(Object成员即其他对象的原型)
原型 → 类 → 对象
这样的好处就是只需要记住原型、类、对象的关系三者之间固有的关系即可(加上记住其他类原型即Object三者关系中的对象)
我会持续更新的!