H5学习笔记面试前端面试

20家前端面试题参考

2017-04-28  本文已影响1216人  土乒76

题目来自前端面试--四月二十家前端面试题分享,知道某一题目时可以直接ctrl+f找答案,有些选择题或者输出结果的题目就没放到这里,一起学习交流~

1、CSS实现垂直水平居中

<div class="box">
    <div class="con"></div>
</div>

解:

.box {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    margin: auto;
    width: 400px;
    height: 400px;
    border: 1px solid red;
    display: flex;
    justify-content: center;
    align-items: center;
}

.con {
    height: 100px;
    width: 100px;
    background-color: red;
}

2、原生JS或JQ循环出li中的内容

解:

// JS版本
var aLi = document.querySelectorAll('ul li');
aLi.forEach(function(item, index, arr){
    console.log(item.innerHTML);
});
// JQ版本
$('ul li').each(function(index, item){
    console.log(item.innerHTML);// item是原生的DOM元素喔
});

3、Ajax请求的时候GET和POST的区别

解:

GET大小限制,安全低,POST则相反
GET请求需考虑缓存问题,POST无需关心
POST请求必须设置Content-Type值为application/x-form-www-urlencoded
GET请求的参数写在url里,所以send函数发送的参数为null,而POST请求的数据需要写在send中

4、JS中函数split()和join()的区别

解:

// 根据传入参数的不同,字符串拆分成数组和数组拆分成字符串
var str = 'my name is moka.';
var arr = str.split(" ");
console.log(arr);// ["my", "name", "is", "moka."]

str = arr.join(" ");
console.log(str);// my name is moka.

5、熟悉微信小程序吗

解:

实事求是的随便扯点吧...去面试时可以先关注下该公司是否有做这个,根据情况往要点子上扯

6、HTTP状态码及其含义

解:

1开头表示信息类:收到请求正在处理中
2开头表示成功类:请求被正确接收,理解和处理,例如:200
3开头表示重定向类:请求失败
4开头表示客户端错误:请求有错误,例如:404代表请求内容不存在
5开头表示服务器错误:服务器不能完成对请求的处理:如 500

7、设置元素浮动后,该元素的display值是多少

解:

var oBox = document.querySelector('#box');
console.log(getComputedStyle(oBox, "null")['display']);// block

// PS:猛一瞅这题吓我一跳,难道不是block吗,事实就是block...

8、请描述cookie、sessionStorage、localStorage的区别

解:

同:
    都是保存在浏览器端,且同源的(同协议,同域名和同端口)
异:
    cookie数据始终在同源的http请求中携带(即使不需要),即cookie在浏览器和服务器间来回传递,sessionStorage和localStorage不会自动把数据发给服务器,仅在本地保存;

    cookie数据有路径(path)的概念,可以限制cookie只属于某个路径下;
    
    cookie数据不能超过4k,同时因为每次http请求都会携带cookie,所以cookie只适合保存很小的数据,如会话标识,sessionStorage和localStorage 虽然也有存储大小的限制,但比cookie大得多,可以达到5M或更大;

    数据有效期不同,sessionStorage仅在当前浏览器窗口关闭前有效,自然也就不可能持久保持,localStorage始终有效,窗口或浏览器关闭也一直保存,因此用作持久数据,cookie在设置的过期时间之前一直有效;

    作用域不同,sessionStorage不在不同的浏览器窗口中共享,即使是同一个页面,localStorage 在所有同源窗口中都是共享的,cookie也是在所有同源窗口中都是共享的;

    Web Storage 支持事件通知机制,可以将数据更新的通知发送给监听者,其api接口使用更方便

9、请解释你对盒模型的理解,以及如何在CSS中告诉浏览器使用不同的盒模型来渲染你的布局

解:

W3C标准盒子模型:宽是宽,高是高
IE盒子模型:宽高包括padding和border
box-sizing: border-box;// 变为IE盒子模型

10、下面的语句的返回值是什么

var a = 6;
setTimeout(function(){
    alert(a);
    a = 666;
}, 1000);
a = 66;

解:

是66,setTimeout是异步的

11、CSS选择符有class选择符,还有另外两种是什么,按优先级

解:

选择符多了去了,后代、兄弟、属性,这里问的应该是常用的ID和标签,优先级:ID、class、标签

12、前端页面有行为层JS和另外两个层是什么,作用是什么

解:

HTML(结构)和CSS(样式),假如盖一个楼:HTML就是整体楼空荡荡的框架,CSS相当于粉刷装修,JS就是给屋子里面通电后,电视机,空调,电脑等一系列功能性的东西

13、你做的页面在哪些内核浏览器测试过,说出3种

解:

Trident(IE内核)
Gecko(Firefox内核)
Webkit(Safari内核)

14、在jQuery中被誉为工厂函数的是

解:

$()
我的第一印象以为是要问工具方法有哪些:$.extend()、$.type()、$.proxy()

15、要动态改变层中内容可以使用的方法有

解:

innerHTML/innerText

16、当按键盘A时,使用onkeydown事件打印even.keyCode的结果是

解:

65

17、能设置或返回下拉列表中被选选项的索引号是什么属性

解:

selectedIndex 

18、希望图片具有”提交”按钮同样的功能,该如何编写表单提交

解:

在图片的onClick事件中手动提交

19、ping基于什么协议

解:

// 涨姿势了
ICMP:Internet控制报文协议。它是TCP/IP协议族的一个子协议,用于在IP主机、路由器之间传递控制消息

20、JS如何操作select中的值

解:

// http://www.cnblogs.com/jiujiaoyangkang/p/6797315.html 

21、console.log(1&&2)和console.log(1||2)结果是

解:

2和1,"&&"是同真才为真,开始1是真,还不能确定最终的结果,所以会继续往下运行是2,"||"是有真即真,1是真已经能确定结果就不会往下走了

22、下面代码的输出结果

解:

window.val = 1;
var json = {
    val: 10,
    dbl: function(){
        this.val *= 2;
    }
};
json.dbl();// json.val = 20
var dbl = json.dbl;
dbl();// window.val = 2
json.dbl.call(window);// window.val = 4
console.log(window.val + json.val);// 24
(function(){
    var val = 1;
    var json = {
        val: 10,
        dbl: function(){
            val *= 2;
        }
    };
    json.dbl();
    alert(json.val + val);// 12
}());
var foo = "Hello";
(function(){
    var bar = " world";
    alert(foo + bar);// Hello world
})();
alert(foo + bar);// Uncaught ReferenceError: bar is not defined
(function func(){
    var a = b = 'res';
})();
console.log(b);// res
console.log(a);// a is not defined

23、请实现下列的findDocList方法

var docs = [
    {
        id: 1,
        words: ['hello','world']
    },
    {
        id: 2,
        words: ['hello','kids']
    },
    {
        id: 3,
        words: ['hello','dogs']
    }
];
findDocList(docs, ['hello']);// 文档1,文档2,文档3
findDocList(docs, ['hello','world']);// 文档1

解:

function findDocList(docs, arr){
    for(var i = 0;i < docs.length; i++){
        var oBar = false;
        for(var j = 0;j < arr.length; j ++){
            var str = arr[j];
            if(docs[i].words.indexOf(str) == -1){
                oBar = true;
            }
        }
        if(!oBar){
            console.log('文档' + docs[i].id);
        }
    }
}

24、用JS写一个继承实例

解:

// 构造函数A
function A() {
    this.name = 'aaa';
}
A.prototype.showName = function() {
    console.log(this.name);
};
// 构造函数B
function B(){ /*...*/ }
// 继承开始
B.prototype = new A();
B.prototype.constructor = B;
// 使用
var b1 = new B();
b1.showName();

25、移动端如何适配不同手机屏幕,你的适配方案是什么

解:

百分比、REM、Flexible,后面展开说...

26、编写JS深度克隆函数deepClone

解:

// 浅拷贝
var json1 = {
    name: 'aaa',
    age: 25,
    data: {
        a: 1,
        b: 2
    }
};

function copy(parent, child) {
    var child = child || {};
    for(var i in parent) {
        child[i] = parent[i];
    }
    return child;
}

var json2 = copy(json1);
json2.data.a = 3;
console.log(json1.data.a);// json1.data.a受影响也变成3了
console.log(json2.data.a);
// 深拷贝:利用递归
var json1 = {
    name: 'aaa',
    age: 25,
    data: {
        a: 1,
        b: 2
    }
};

function deepCopy(parent, child) {
    var child = child || {};// 并不是直接声明一个新child为空{},传过来的就用传过来的
    for(var i in parent) {
        if(typeof parent[i] === 'object') {
            child[i] = (parent[i].constructor === Array) ? [] : {};// child.data = {};
            deepCopy(parent[i], child[i]);// {a: 1,b: 2},传过去的是child.data的空json
        }
        else {
            child[i] = parent[i];// child.data.a ...
        }
    }
    return child;
}

var json2 = deepCopy(json1);
json2.data.a = 3;
console.log(json1.data.a);// json1.data.a不受影响,仍旧是1
console.log(json2.data.a);

27、有一个数组a = [8, 10, 30, 55, 78, 90, 1],新建一个数组b,b从a中一次随机选取一个元素,取完为止

解:

var a = [8, 10, 30, 55, 78, 90, 1];
var b = [];
for(var i=0; i<a.length; i++) {
    var randomNum = Math.floor( Math.random() * a.length );
    var newStr = a.splice( randomNum, 1 ).toString();
    i --;// 注意splice后数组塌陷的问题
    b.push( newStr );
}
console.log(b);

27、假设发现有一篇文章,var content = "大量文字...",过滤其中的敏感词汇,如何发现敏感词汇并将其背景标记为红色

解:

<!doctype html>
<html>

<head>
    <meta charset="utf-8">
    <title>敏感词高亮</title>
    <style>
    #div1 {
        width: 330px;
        height: 200px;
        border: 10px solid #063;
        font-size: 14px;
        font-family: "微软雅黑";
        padding: 10px;
    }
    
    span {
        background: #F0F;
    }
    </style>
    <script>
    window.onload = function() {
        // 敏感词
        var arr = ['君子', '也'];

        var oDiv = document.getElementById('div1');
        var oTxt = oDiv.innerHTML;

        for (var i = 0; i < arr.length; i++) {
            oDiv.innerHTML = oTxt.split(arr[i]).join("<span>" + arr[i] + "</span>");
            // 注意更新
            oTxt = oDiv.innerHTML;
        }
    };
    // ps:用正则应该是更好的办法,有时间再改吧
    </script>
</head>

<body>
    <div id="div1">
        君子曰:学不可以已。   青,取之于蓝,而青于蓝;冰,水为之,而寒于水。木直中绳,輮以为轮,其曲中规,虽有槁暴,不复挺者,輮使之然也。故木受绳则直,金就砺则利,君子博学而日参省乎己,则知明而行无过矣。故不登高山,不知天之高也;不临深溪,不知地之厚也;不闻先王之遗言,不知学问之大也。干、越、夷、貉之子,生而同声,长而异俗,教使之然也。诗曰:「嗟尔君子,无恒安息。靖共尔位,好是正直。神之听之,介尔景福。」神莫大于化道,福莫长于无祸。
    </div>
</body>

</html>

28、请用JS实现数组的快速排序

解:

推荐阮一峰老师的文章快速排序的JS实现

//  在数据集之中,选择一个元素作为"基准"
//  所有小于"基准"的元素,都移到"基准"的左边;所有大于"基准"的元素,都移到"基准"的右边
//  对"基准"左边和右边的两个子集,不断重复第一步和第二步,直到所有子集只剩下一个元素为止
var arr = [3, 1, 4, 6, 5, 7, 2];
function quickSort(arr) {
    if(arr.length == 0) {
        return [];
    }
    var cIndex = Math.floor(arr.length / 2);
    var c = arr.splice(cIndex, 1);// 从索引n开始删除m个元素,并返回删除的元素,原来数组改变
    var l = [];
    var r = [];
    for (var i = 0; i < arr.length; i++) {
        if(arr[i] < c) {
            l.push(arr[i]);
        }
        else {
            r.push(arr[i]);
        }
    }
    return quickSort(l).concat(c, quickSort(r));
}
console.log(quickSort(arr));

29、编写sum()函数求和,非number类型参数需要进行过滤

解:

function sum() {
    var result = 0;
    for(var i = 0; i < arguments.length; i ++) {
        if(isNaN(arguments[i])){// 不是数字
            continue;
        }
        result += arguments[i];
    }
    console.log(result);
}
sum(7, 'aaa', 8, 'bbb');

30、写一个方法将字符串“abcdefg”逆序

解:

var str = "abcdefg";
function reverseStr(str) {
    return  str.split("").reverse().join("");
}
console.log( reverseStr(str) );

31、<input type="radio" name="hello">,让radio为选中状态

解:

// 注意两种不同的书写形式,jQuery中prop相当于原生"."的操作形式,attr相当于setAttribute
input.checked = true;
setAttribute('checked','checked');

32、HTML5为什么只需要写<!DOCTYPE html>

解:

HTML5不基于SGML,因此不需要对DTD进行引用,只需要doctype来规范浏览器的行为即可。

33、

解:

link引用CSS时,在页面载入时同时加载;@import需要页面网页完全载入以后加载

link是XHTML标签,是普通DOM节点,无兼容问题;@import是在CSS2.1提出的,低版本的浏览器不支持

34、HTML5离线缓存有几种方式

解:

localStorage和sessionStorage两种

35、Doctype作用,标准模式与兼容模式各有什么区别

解:

作用:告知浏览器的解析器用什么文档标准解析这个文档
区别:标准模式的排版和JS运作模式都是以该浏览器支持的最高标准运行,兼容模式顾名思义...

36、如何修改chrome记住密码后自动填充表单的黄色背景

解:

// 使用足够大的纯色内阴影来覆盖默认的背景色
input: -webkit-autofill {
    -webkit-box-shadow: 0 0 0px 1000px white inset;
}
// 或者关闭这个自带功能
autocomplete=‘off’

37、介绍JS的基本数据类型

解:

基本:number、string、boolean、null、undefined
引用:object

38、如何将字符串转换为数字,例如"12.3b"

解:

parseInt/parseFloat

39、如何将浮点数点左边的数12000000.11每3位添加一个逗号

解:

// 试着先理解,关于正则后面专门再写吧
var num = 12000000.11;

function addDot(num) {
    // ?=表示“只能是”,(\d{3})+:表示3的倍数个数字
    return num && num.toString().replace( /(\d)(?=(\d{3})+\.)/g, function($1, $2) {
        return $2 + ',';
    } );
}

var newNum = addDot(num);
console.log(newNum);

40、实现数组的随机排序,2种方法以上

解:

var arr = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9];
arr.sort(function(num1, num2) {
    // -1表示每次num1在num2的前面,1则相反,用Math.random()和0.5相比较,也就实现随机的正反,即随机排序
    return Math.random() > 0.5 ? -1 : 1;
});
console.log(arr);

41、this在JS中如何工作的

解:

// case1:看方法名前面是否有点,有的话点前面是谁this就是谁
function fn(){
    console.log(this);
}
var obj = {
    fn:fn
};
fn();// this > window,严格模式下undefined
obj.fn();// this > obj

..........

function Person(){
    this.name = "yangk";
}
Person.prototype.showName = function(){
    console.log(this.name);
};
var p1 = new Person;
p1.showName();// this > p1
p1.__proto__.showName();// this > p1.__proto__
Person.prototype.showName();// this > p1.prototype
// case2:自执行函数中的this永远是window,严格模式下是undefined
(function(){
    console.log(this);// this > window
})();
~function(){
    console.log(this);// this > window
}();
// case3:元素的某一个行为绑定一个方法,this > 元素
function fn(){
    console.log(this);
}
oDiv.onclick = fn;
oDiv.onclick = fn();// 注意这里是执行的返回结果返回!!!!!!undefined
oDiv.onclick = function(){
    fn();// this  >  window
};
// case4:使用call/apply强制改变this
var obj = {
    fn: function(){
        console.log(this);
    }
};
obj.fn();// this > obj
obj.fn.call(12);// this > 12

.........

function sum(){
    
}
sum.call(100,100...)// 第一个参数是this,后面对应接受的形参,没有undefined
sum.call();//在非严格模式下,call的第一个参数不写或者写null/undefined,默认的this都是window,严格模式下写谁就是谁,写null就是null,不写是undefined
apply(obj,[...]);

42、请至少用两种方法实现两个变量对调,不借用第三个变量的情况下

解:

// 首先想到的是利用ES6的解构赋值
var a = 'Aaa';
var b = 'Bbb';

[a, b] = [b, a];
console.log(a);
console.log(b);
// 下面这种方法适用a和b都是数字的情况,还可以用位运算(^)有兴趣的研究下
var a = 666;
var b = 888;

a = a + b;// 先变和
b = a - b;// 和减b自然等于a,然后赋给b
a = a - b;// 和减b,此时的b已经是调换后的b了
console.log(a);
console.log(b);
// 把a变成一个JSON,也可以把a变成一个Array
var a = 'Aaa';
var b = 'Bbb';

a = {
    a: b,
    b: a// 此时的a还是'Aaa'
};
b = a.b;
a = a.a;
console.log(a);
console.log(b);
// 此方法神妙,不知道哪位大神想的,随意感受下
var a = 'Aaa';
var b = 'Bbb';

a = [b, b = a][0];// b = a先执行
console.log(a);
console.log(b);

43、实现一个300300的canvas画布,内含100100的红色矩形

解:

var oCanvas = document.createElement("canvas");
// 注意canvas设置宽高的正确姿势,不是oCanvas.style.width,其不是普通的DOM元素,有自己规则
oCanvas.width = 300;
oCanvas.height = 300;
document.body.appendChild(oCanvas);

var oGC = oCanvas.getContext('2d');

oGC.fillRect(50, 50, 100, 100);// L, T, W, H
oGC.fillStyle = "red";

44、用CSS或者JS实现物体的平移动画

解:

// CSS
利用transform:translate(x, y)
// JS
利用定时器

45、一个满屏“品”字布局如何设计

解:

// 定位或浮动,不具体写了

46、::before双冒号和单冒号的区别,解释其作用

解:

// 伪对象选择符和伪类选择符,双冒号是CSS3新增的,配合content在内容最前面添加一些内容

47、HTML5有哪些新特性

解:

// case1:新增/废除了一些标签,例如新增header,废除s、big
// case2:canvas
// case3:数据存储
// case4:Web Socket
// ...

48、如何判断变量是否是数组

解:

// typeof
// instanceof
// constructor
// Object.prototype.toString.call()

49、谈谈对闭包的理解

解:

// http://www.cnblogs.com/jiujiaoyangkang/p/5879384.html

50、列举一下JS垃圾回收方法以及原理

解:

// 详见JavaScript高级程序设计第78页

待续...

上一篇下一篇

猜你喜欢

热点阅读