前端简答算法题汇总
作者:互联网
1、linux中vim有几种模式?如何进行这几种模式的切换。
命令行模式、插入模式、底行模式
命令行模式->插入模式 I A O i a o
命令行模式->底行模式 : ?
插入模式->命令行模式 ecs
2、css3中animation和transition表示什么意思?
animation 表示动画:animation-xxx
transition 表示过度:transition-xxx
3、css中verticle-align规则有什么作用
设置行内元素的垂直对齐方式。
默认取值为baseline,及行内元素默认按照基线来进行排列
4、相对定位、绝对定位、固定定位、粘滞定位、静态定位有什么区别?
脱离文档流的是:绝对定位、固定定位、粘滞定位
没有定位属性与效果:静态定位
参考点不同:
相对定位:相对原先自己的位置。
绝对定位:相对具有定位属性的上层元素。
固定定位:相对浏览器窗口定位。
粘滞定位:相对定位+固定定位,有临界值。
5、什么是响应式网页?如何实现一个响应式网页?
响应式网页可以根据用户的访问设备不同而发生自适应变化。
可以通过@media来进行媒体查询,不同的设备尺寸执行不同的css代码,也可以使用bootstrap第三方库来完成响应式布局。
6、linux中远程登录命令、远程文件传输命令、查看java进程命令分别是什么?
ssh用户名@ip
scp本地文件路径 用户名@ip:远程文件路径 或者 ftp 用户名@ip
pa -ef | grep java
7、什么是块元素,块元素有哪些特点?
块元素常用于搭建网页框架,常见的块元素有:div、p、h1~h6
特点:独占一行空间,高度由内容决定,可以指定宽高,块元素内允许嵌套其他块元素与行内元素。
8、em与rem的区别
em:相对于当前元素上的字体大小
rem:相对于html元素上声明的字体大小
9、如何使用css绘制一个三角形?
不给盒子元素设置宽高,给4个方向分别设置边框,但是颜色都为透明,设置其中一个方向边框色。
#app{
width:0;
height:0;
border:100px soild transparent;
border-botton:100px solid #ccc;
}
10、简述flex布局
伸缩盒布局用于解决块元素在x轴以及y轴上排列的问题。
伸缩盒容器规则:
display
flex-direction 决定主轴的方向 row column
flex-wrap 换行
justify-content 块元素在主轴上对排列方式
align-items 在交叉轴上如何对齐
伸缩盒元素规则:
flex-grow 放大
flex-shrink 缩小
flex-basis 如何分配空白空间
11、js数组中哪些方法是在原值上进行的修改?哪些方法没有对原值进行修改?
改变原数组:push()后面增加、pop()删除后面的、shift()删除前面的、unshift()前面增加、sort()排序
不改变原数组:concat()、slice()、every()、some()、filter()、map()、forEach()
12、写出让元素垂直居中的多种布局方法
通过margin、padding挤压
通过相对定位、绝对定位
通过flex布局display:flex align-items:center
13、简述css3选择器的优先级机制
如果添加!important表示至高无上的权限
权重规则:
1000 style
100 id
10 class、伪类
1 元素,伪元素
当权重相等情况下,后者优先级比前者更大
14、伪元素选择器 ::after 有哪些常见用法?
常用于清理浮动、插入文本
ul::after{
display:bolck;
content:"";
clear:both;
}
15、写出几个你熟悉的Git命令
git add 添加到暂存区
git commit 提交
git push 上传
git pull 更新
git branch 删除
16、在js中如何判断一个数据类型?
可以通过typeof来判断基本数据类型以及对象,函数。
通过Array.isArray()来判断引用数据类型是对象还是数组
通过instanceof来判断对象是否是某个构造函数的实例对象
通过isNaN()、isInfinite()来判断一个数字是否非数值类型,无穷数。
17、在js的面向对象中继承方式有哪几种,分别进行描述
原型链
借用构造函数
原型链与借用构造函数组合
18、简述js函数的this只想问题
this指向实际操作对象,如果没有操作对象则指向全局的window对象
19、如何实现一个对象的深拷贝?
方法1:使用JSON
var copy = JSON.parse(JSON.stringify(obj));
方法2:第三方库lodash 的 cloneDeep
方法3:jQuery自带的extend方法可以用来实现对象的复制
var a = {v1:1,v2:2};
var b = {};
$.extend(b,a);
方法4:自己封装实现
20、什么是闭包?如何理解闭包打来的内存泄露问题?
闭包是能够访问另一个函数作用域中的变量的函数,闭包的创建方式,就是一个函数内部创建另一个函数。
内存泄露问题:主动释放内存空间,再退出函数之前,不用的变量全部删除,赋值为null
21、盒子模型种类及主要区别?
边框盒子/IE盒子/怪异盒子Border-box
内容盒子/W3C盒子/默认盒子 content-box
区别:计算尺寸方式不同,
对于边框盒子设置的宽高是包含了border、padding、content的结果
对于内容盒子设置的宽高只是指content
22、简述http协议的报文格式
请求报文:浏览器会将前端请求封装成请求报文发送给后端,请求报文中包含请求体,请求头,请求体
响应报文:服务器接收到前端发来的请求,会将相应内容封装成为一个响应报文,浏览器会对响应报文进行解析,进而显示出来。响应报文中包含响应行,响应头,响应体。
23、用递归的方法实现1到100求和。
function add(n1,n2) {
var num = n1 + n2;
if(n2 + 1 > 100) {
return num;
}else{
return add(num,n2 + 1)
}
}
var sum = add(1,2)
console.log(sum);
24、统计一个字符串中某个字符出现了几次,例如:输入hello,l输出2。
function sort(str,n) {
var num = 0;
for(i = 0; i < str.length; i++){
if(str[i] == n)
num++
}
return num;
}
console.log(sort('hellojavascript','a'));
25、编写代码实现数组扁平化输出,例如:输入[[1,2,3,[4,5,6,[7,8]]],[9,10],[11,12,[13]],5] 输出为[1,2,3,4,5,6,7,8,9,10,11,12,13,5]。
var arr=[[1,2,3,[4,5,6,[7,8]]],[9,10],[11,12,[13]],5];
方法一:var brr = arr.toString().split(‘,’)
console.log(arr);
方法二: console.log(arr.flat(Infinity))
26、使用任意一种排序算法对数组进行排序,例如:输入[3,2,1,6,12,8,9] 输出:[1,2,3,6,8,9,12]。
var arr = [3, 2, 1, 6, 12, 8, 9]
function setSort(arr) {
for (var i = 0; i < arr.length; i++) {
for (var j = 0; j < arr.length - 1 - i; j++) {
if (arr[j] > arr[j + 1]) {
var temp = arr[j + 1]
arr[j + 1] = arr[j]
arr[j] = temp
}
}
}
return arr;
}
setSort(arr)
console.log(arr);
标签:定位,arr,盒子,flex,元素,汇总,算法,简答,var 来源: https://blog.csdn.net/qq_45334571/article/details/120303113