javascript高级试题

javascript高级试题1 判断为数组类型的 4 种方式 Array isArray typeofinstan 判断对象是否包含特定的自身 非继承 属性 hasOwnProper 3 改变 this 的 3 种方式 他们有什么相同点和不同点 call bind apply 这三个函数的第一个参数都是 this 的指向对象 第二个参数差别就来了 call 的参数是直接放进去的 第二第三第 n 个参数全都用逗号分隔 直接放到后面 obj myFun call db 成都

1.判断为数组类型的4种方式
Array.isArray()   typeof   instanceof  constructor

2.判断对象是否包含特定的自身(非继承)属性
hasOwnProperty()

3.改变this的3种方式,他们有什么相同点和不同点
call 、bind 、 apply 这三个函数的第一个参数都是 this 的指向对象,第二个参数差别就来了:
call 的参数是直接放进去的,第二第三第 n 个参数全都用逗号分隔,直接放到后面 obj.myFun.call(db,’成都’, … ,’string’ )。
apply 的所有参数都必须放在一个数组里面传进去 obj.myFun.apply(db,[‘成都’, …, ‘string’ ])。
bind 除了返回是函数以外,它 的参数和 call 一样。

4.使用递归求0.1+0.2+….+1的和
let num = 0;
let sum = 0;
function add(num) {

        num += 0.1;
        if (num <= 1) {

            sum += num;
            add(num);
        };
        return sum;
};
console.log(add(num));

5.闭包的3个特性
①函数嵌套函数
②函数内部可以引用函数外部的参数和变量
③参数和变量不会被垃圾回收机制回收

6.什么是BFC
BFC (块级格式化上下文)overflow:hidden; 

7.让一个200*200的元素垂直水平居中
答案不唯一
div{

            width: 200px;
            height: 200px;
            position: absolute;
            top: 0;
            bottom: 0;
            left: 0;
            right: 0;
            margin: auto;
        }
8.获取滚动条的高度
document.documentElement.scrollTop || document.body.scrollTop;(兼容代码)

9.For,forEach,for…in,while语法
for(初始值;判断条件;变化语句){循环体}
数组(对象).forEach(item,index,arr)—值,下标,当前循环数组
for(键名 in 对象){执行语句(循环体);}
while(判断语句){循环体};

10.Opacity兼容5大浏览器的写法
opacity{

            filter: alpha(opacity=50); 兼容IE6、7、8
            -moz-opacity:0.5; 老版的Mozilla
            -khtml-opacity:0.5; 老版的Safari
            -webkit-opacity:0.5; 支持webkit内核的浏览器
            opacity: 0.5; 支持opacity的浏览器
}
11.方法会直接在一个对象上定义一个新属性,或者修改一个对象的现有属性,并返回此对象语法和参数
Object.defineProperty(obj, prop, descriptor)
obj要定义属性的对象
prop要定义或修改的属性的名称或 Symbol
descriptor要定义或修改的属性描述符
12.Symbol与Symbol.for与Symbol.keyFor
Symbol会被登记在全局环境中供搜索,后者不会,
Symbol.for()不会每次调用就返回一个新的 Symbol 类型的值,而是会先检查给定的key是否已经存在,如果不存在才会新建一个值
Symbol.keyFor返回一个已登记的 Symbol 类型值的key
13.Map方法中,什么方法可以返回一个新的迭代对象,对象中每个元素是数组,键,值
14.For…of和forEach区别
For…of   
使用return,break,continue来终止循环    
遍历字符串
仅仅支持数组的遍历,同时也适用于很多类似数组的对象
15.什么可以从一个类似数组或可迭代对象创建一个新的,浅拷贝
Array.from(arrayLike[, mapFn[, thisArg]])
arrayLike想要转换成数组的伪数组对象或可迭代对象。
        // mapFn 回调  thisArg回调第二个this 对象
16.过滤器
filter作对比,谁点filter,点的是被比较的
17.Set, Map区别(3个区别)
Set成员不能重复
(2)只有键值没有键名,类似数组
(3)可以遍历,方法有add, delete,has
Map:
(1)本质上是健值对的集合,类似集合
(2)可以遍历,可以跟各种数据格式转换
18.js中监听事件语法,(IE兼容写法)
element.addEventListener(event, function, useCapture);
element.attachEvent(event, function);
element.detachEvent(event, function);
19.什么是解构赋值ES6 允许按照一定模式,
从数组和对象中提取值,对变量进行赋值
20.使用箭头函数应该注意什么
1用了箭头函数,this就不是指向window,而是父级(指向是可变的2不能够使用arguments对象
3不能用作构造函数,这就是说不能够使用new命令,否则会抛出一个错误
4不可以使用yield命令,因此箭头函数不能用作 Generator 函数

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/232126.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • JVM简介

    JVM简介

    2021年9月8日
    41
  • 初探js逆向「建议收藏」

    初探js逆向「建议收藏」转载自三尾先生博客初探js逆向在开始之前想先说下阅读完三尾先生这篇文章的一点个人理解,文章写得挺好的,很值得新手学习了解,首先谈下逆向激活成功教程思路1.需要逆向的时候一般是遇到了加密问题,加密情况有参数加密,有结果加密。但不管怎样的加密只要页面能正常显示,那就有解密过程!2.先找到加密的字段名,通过字段名在sources全局搜索3.在含有这些字段的位置打断点,一般sources里看到的会是一行的压缩代码,我们可以通过点击左下角的双大括号格式化js代码然后通过断点一步步查看参数在哪一步骤发生了变

    2022年6月22日
    44
  • nginx与tomcat配合部署web工程接口访问报414 Request-URI Too Large错误

    nginx与tomcat配合部署web工程接口访问报414 Request-URI Too Large错误首先查看nginx配置nginx.conf调节http模块以下参数值client_header_buffer_size512k;large_client_header_buffers4512k;如接口正常访问项目即修改有效;若报出"(104: Connection reset by peer) while connecting to upstream"继续检查tomcat下…

    2022年6月4日
    69
  • c++中如何定义常量_电脑基础知识教程自学

    c++中如何定义常量_电脑基础知识教程自学想学习c++的朋友可以来关注一下a,从入门的知识开始。

    2025年6月29日
    2
  • CheckListBox的使用方法

    CheckListBox的使用方法checklistbox控件 1.添加项 checkedListBox1.Items.Add(“蓝色”); checkedListBox1.Items.Add(“红色”); checkedListBox1.Items.Add(“黄色”);   2.判断第i项是否选中,选中为true,否则为false if(checkedListBox1.G

    2022年6月26日
    51
  • 递归迭代动态规划「建议收藏」

    递归迭代动态规划「建议收藏」一、定义递归:程序调用自身,从顶部将问题分解,其问题与其子问题是同一概念。通过解决掉所有分解出来的小问题,来解决整个问题。迭代:利用变量的原值推算出变量的下一个值。递归中一定有迭代,但是迭代中不一定有递归。动态规划:通常与递归相反,其从底部开始解决问题。将所有小问题解决掉,进而解决的整个问题。为了节约重复求相同子问题的时间,引入一个数组,把所有子问题的解存于该数组中,动态规划算法是空间换时间的算法。动态规划可以递归地实现,也可以非递归(循环的方法)地实现。运行速度:动态规划>迭代&gt

    2025年7月1日
    3

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号