学习总结

1:如何合并多个对象

答:object.assign()或扩展函数...

2:如何改变this作用域?

答:apply()或call(),bind()

3:settimeout的this指向是什么

答:指向window

4:获取对象的键或者值

答:Object.keys(obj)  、Object.values(obj)

参考:Ⅶ期Day2:创建对象、原型、属性的查询与设置

5:基本类型与引用类型

  • 基本:字符串(String)、数字(Number)、布尔(Boolean)、对空(Null)、未定义(Undefined)、Symbol。
  • 引用:对象(Object)、数组(Array)、函数(Function)。

6:基本类型和引用类型的区别

答:传值与传址

7:栈内存(stack)和堆内存(heap)

  • 栈:自动分配内存空间,系统自动释放,里面存放的是基本类型的值和引用类型的地址
  • 堆:动态分配的内存,大小不定,也不会自动释放。里面存放引用类型的值。

8:如何判断数据类型

  1. typeof (基本数据类型)
  2. instanceof (引用类型(对象类型))
  3. Object.prototype.toString.call (对象的一个原生原型扩展函数,用来更精确的区分数据类型)
  4. constructor 也能判断数据类型
  5. Array.isArray()(判断是否是数组)

9:面向对象的三大特性

答:封装、继承、多态

10:什么是AJAX?

答:AJAX=AsynchronousJavaScriptandXML(异步的 JavaScript 和 XML) 是一种用于创建快速动态网页的技术,使网页实现异步更新。

11: 什么是跨域?
答:跨域是指从一个域名的网页去请求另一个域名的资源。只要协议、域名、端口有任何一个不同,都被当作是不同的域。 

12:浅拷贝与深拷贝

答:浅拷贝:对象(for,扩展函数,Object.assign({},obj));数组(for,slice,concat,扩展函数,Array.from());

       深拷贝:递归,JSON.stringify()无构造器。

13:JS原生常用方法

  1. 获取属性:getAttribute('属性名');
  2. 设置属性:setAttribute('属性名','值');
  3. 移出属性:removeAttribute('属性名');
  4. 追加元素:appendChild
  5. 删除元素:removeChild

14:display与visibility区别?

  • display='none'//不占位
  • visibility='hidden'//占位
  • opacity=0;//占位

15:伪数组变真数组方法?

  1. Array.prototype.slice.call(arguments);
  2. Array.from(arguments);//ES6

16:如何阻止事件冒泡?

stopPropagation

17:数据属性与访问属性?

  • 数据属性:value,writable,enumerable,configurable
  • 访问属性:enumerable,configurable,get(读取属性值的时候调用),set(值改属性的时候调用)

只有get时,只读不写;只有set,只写不读。configurable为true时可以转换为访问器属性,为false无法转换。

18:具有iterable属性的有那些?

Array,Map,Set都可通过for...of循环遍历

19:如何继承属性?

  1. Object.create();
  2. Object.setPrototypeOf(obj,prototype);

20:立即执行函数

  • ()()
  • +function(){}()
  • -function(){}()
  • ;function(){}()

21:common.js AMD CMD:

commonjs、amd、cmd、import同步加载变量赋值过程、异步加载,接受一个回调函数,提前执行、异步按需加载,延迟执行

方案 | 优势 | 劣势 | 特点
AMD | 速度快 | 会浪费资源 | 预先加载所有的依赖,直到使用的时候才执行
CMD | 只有真正需要才加载依赖 | 性能较差 | 直到使用的时候才定义依赖

22:BFC理解与应用

  • block format context,块级格式化上下文
  • 一块独立渲染区域,内部元素的渲染不会影响边界以外的元素

23:BFC常见应用

清除浮动

24:手写clear fix

.clearfix:after{
content:'';
display:table;
clear:both;
}
25:absolute和relative定位
  • relative依据自身定位
  • absolute依据最近一层的定位元素定位,没有最近定位位置就以body定位

26:居中对齐的实现

水平居中
inline元素:text-align:center
block元素:margin:auto;
absolute元素:left:50%+margin-left负值
垂直居中
inline元素:line-height的值等于height值
absolute元素:transform(-50%,-50%)
absolute元素:top:50%+margin-top负值
absolute元素:top,left,bottom,right=0+margin:auto
27:css编写三角形:

div {
    width: 0;
    height: 0;
    border: 40px solid;
    border-color: transparent transparent red;
}

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值