JS常见面试题总结-真实被问到的!
1、判断数据类型有几种方法
console.log(typeof 'abc')
// string
console.log(Object.prototype.toString.call('abc'))
// [object String]
console.log('abc'.constructor == String)
// true
2、数据类型有哪些?
基本类型:String、Number、boolean、undefined、null 复杂类型:function、object、NaN、Array、regexp
3、字符串反转
var str = 'abcdef'.split('').reverse().join('')
4、什么是事件委托;
事件委托是利用冒泡,子标签的触发事件让父标签代替执行;
// html
<ul>
<li>1</li>
<li>2</li>
<li>3<li>
</ul>
// script
var ul = document.querySelector('ul');
ul.onclick = function(e){
e.target.style.color = 'red'
}
5、什么是闭包,有什么作用
闭包就是能够记住当初所处作用域时候的变量,不管函数在哪里执行,都能够记住当初所处作用域时候的变量,并且会遮蔽新作用域的变量;
1、可用作迭代器
2、可预测状态容器
function fun (){
let a = 10;
return function(){
return a ++;
}
}
var inner = fun()
console.log(inner())//
console.log(inner())//
6、this的指向问题
7、请写出一个函数,清楚前后空格,所有浏览器都兼容
function trim(str) {
if (str & typeof str === "string") {
return str.replace(/(^s*)|(s*)$/g,""); //去除前后空白符
}
}
8、获取url中的地址
console.log(window.location.href)
9、如何实现一个深克隆
const deepclone = (o) => {
if(Array.isArray(o)){
var arr = [];
o.forEach(item => {
arr.push(deepclone(item));
});
return arr;
}else if(typeof o === "object"){
var oo = {};
for(var k in obj){
oo[k] = deepclone(obj[k]);
}
return oo;
}
return o;
}
10、0.1+0.3等于多少
console.log(0.1+0.2)
// 0.30000000000000004
11、什么是优雅降级和渐进渐强?
其实这是浏览器的两种方案
优雅降级:能力检测,如果能力有用新的;如果能力没有,用旧的。
比如:
if(浏览器是高级浏览器){
使用<video>
}else{
使用flash
}
渐进渐强:
低端浏览器仅实现基本功能,高级浏览器实现额外功能。
比如上传文件,低端浏览器就给它提供上传按钮,高端浏览器增
12、substring 和 substr 和 slice 的区别是什么?
substring(首位下标, 末位下标前1位)
slice(首位下标, 末位下标前1位)
substr(首位下标, 子串长度)
slice能够用负数,但是不能颠倒参数位置
substring不能用负数,但是会自动小数在前
13、如何实现小于 10px 的文字?
transform:scale(0.5);
14、输出今天的日期以 YYYY-MM-DD 形式显示?
const date = new Date();
const y = date.getFullYear();
const m = date.getMonth() + 1;
const d = date.getDate(); function buling(n){
return n.toString().length == 1 ? '0' + n : n;
} console.log(y + '-' + buling(m) + '-' + buling(d))
15、添加、移除、移动、复制、创建和查找节点
增加节点
createDocumentFragment() //创建一个DOM片段
createElement() //创建一个具体的元素
createTextNode() //创建一个文本节点
移除、替换、插入
removeChild() //移除
replaceChild() //替换
insertBefore() //插入
查找
getElementsByTagName() //通过标签名称
getElementsByName() //通过元素的Name属性的值
getElementById() //通过元素Id,唯一性
16、call和apply的区别
Object.call(this,obj1,obj2,obj3)
Object.apply(this,argument
17、实现一个对象更改后不会影响原来的对象
let obj = {a:1,b:2}
let newobj = JSON.parse(JSON.stringify(obj))
newobj.b = 5
console.log(obj)
console.log(newobj)
18、问:有一筐鸡蛋,1个1个能取完, 2个2个剩1个,3个3个剩1个,4个4个剩1个,5个5个剩1个,6个6个剩1个,7个7个可以取完;
for(let i = 0 ; i < 1000 ; i++){
if( i % 1 == 0 &&
i % 2 == 1 &&
i % 3 == 1 &&
i % 4 == 1 &&
i % 5 == 1 &&
i % 6 == 1 &&
i % 7 == 0){
console.log(i)
}
}
如果大家喜欢的话,欢迎关注“前端伪大叔”我将为您不间断的分享前端学习知识!

JS常见面试题总结-真实被问到的!的更多相关文章
- vue.js常见面试题及常见命令介绍
Vue.js介绍 Vue.js是JavaScript MVVM(Model-View-ViewModel)库,十分简洁,Vue核心只关注视图层,相对AngularJS提供更加简洁.易于理解的API.V ...
- 前端JS常见面试题(代码自撸)
题目一示例: 适用于子数组等长度及不等长度. let arr = [ [1,2,3], [5,6,7,8], [9,10,11,12,13] ] function arrayDiagonal(arr) ...
- js常见面试题
1.大小写转化,将字符串转化成驼峰的方法 例:border-bottom-color转化为:borderBottomColor var str="border-bottom-color&qu ...
- JS常见面试题,看看你都会多少?
1. 如何在ES5环境下实现let 这个问题实质上是在回答let和var有什么区别,对于这个问题,我们可以直接查看babel转换前后的结果,看一下在循环中通过let定义的变量是如何解决变量提升的问题 ...
- 【javascript常见面试题】常见前端面试题及答案
转自:http://www.cnblogs.com/syfwhu/p/4434132.html 前言 本文是在GitHub上看到一个大牛总结的前端常见面试题,很多问题问的都很好,很经典.很有代表性.上 ...
- 【搞定 Java 并发面试】面试最常问的 Java 并发基础常见面试题总结!
本文为 SnailClimb 的原创,目前已经收录自我开源的 JavaGuide 中(61.5 k Star![Java学习+面试指南] 一份涵盖大部分Java程序员所需要掌握的核心知识.欢迎 Sta ...
- 【搞定 Java 并发面试】面试最常问的 Java 并发进阶常见面试题总结!
本文为 SnailClimb 的原创,目前已经收录自我开源的 JavaGuide 中(61.5 k Star![Java学习+面试指南] 一份涵盖大部分Java程序员所需要掌握的核心知识.觉得内容不错 ...
- 夯实Java基础系列16:一文读懂Java IO流和常见面试题
本系列文章将整理到我在GitHub上的<Java面试指南>仓库,更多精彩内容请到我的仓库里查看 https://github.com/h2pl/Java-Tutorial 喜欢的话麻烦点下 ...
- Web开发的常见面试题HTML和HTML5等
作为一名前端开发人员,HTML,HTML5以及网站优化都是必须掌握的技术,下面列举一下HTML, HTML5, 网站优化等常见的面试题: HTML常见面试题: 1. 什么是Semantic HTML( ...
随机推荐
- C++数据结构之哈希表
哈希表的定义:哈希表是一种根据关键码去寻找值的数据映射结构,该结构通过把关键码映射的位置去寻找存放值的地方.键可以对应多个值(即哈希冲突),值根据相应的hash公式存入对应的键中. 哈希函数的构造要求 ...
- ButterKnifer使用
ButterKnifer使用 1.集成 github地址: https://github.com/JakeWharton/butterknife 1.1在主Moduel中的使用 在主moduel中的b ...
- asp.NET 下真正实现大文件上传
一般10M以下的文件上传通过设置Web.Config,再用VS自带的FileUpload控件就可以了,但是如果要上传100M甚至1G的文件就不能这样上传了.我这里分享一下我自己开发的一套大文件上传控件 ...
- Web jsp开发学习——终极解决jsp中request和response中文乱码的问题(加个过滤器)
中文乱码真的很烦人的.而且每次都要写,可麻烦了,而且有时候写了还不一定管用,所以我们可以试试过滤器 1.每个jsp头上当然要写上utf8啦 <%@ page language="jav ...
- Linux中如何批量删除目录下文件后缀
1. rename rename分为perl版本和C版本,以下截图是C版本效果: perl版本:rename 's/.bak//' *.bak 2. for循环+awk 3. for循环+cut 4. ...
- php进阶之路 -- 03 命名空间
php进阶之路 -- 03 命名空间 命名空间概述 定义命名空间 空间成员和子空间 空间成员的访问 空间引入 全局空间 一. 命名空间概述 什么是命名空间?从广义上来说,命名空间是一种封装事物的方法. ...
- 网络实验 03-交换机划分VLAN配置
交换机划分VLAN配置 一.实验目标 理解虚拟 LAN(VLAN)基本原理 掌握一般交换机按端口划分 VLAN的配置方法 掌握Tag VLAN配置方法 二.实验背景 某一公司内财务部.销售部的PC通过 ...
- 云计算共享组件--Memcache缓存系统(4)
一.缓存系统 一.静态web页面: 1.在静态Web程序中,客户端使用Web浏览器(IE.FireFox等)经过网络(Network)连接到服务器上,使用HTTP协议发起一个请求(Request),告 ...
- Java生成二维码连接
本文使用的是Goodge的zxing 添加maven依赖 <dependency> <groupId>com.google.zxing</groupId> < ...
- 解决Iframe跨域高度自适应,利用window.postMessage()实现跨域消息传递页面高度(JavaScript)
在iframe跨域引用高度自适应这块写的js方式都试了不管用,最终使用的是window.postMessage() 跨域获取高度 传递信息 1.首先,在主页面上使用iframe引入子页面:也就是A.h ...