×

前端啥也不会面试过了 前端

没有项目经验的前端应届生,如何面试才会被录用?前端是什么

admin admin 发表于2022-06-20 15:04:19 浏览95 评论0

抢沙发发表评论

没有项目经验的前端应届生,如何面试才会被录用


  一、 基本沟通能力的测试
  作为一个面试人员,如果不能很好的进行自我介绍说明他的沟通能力存在一定的障碍,应届生则更需要做好充足的准备,不打无把握的仗。准备好完整的自我介绍是首要工作,这样做的目的从侧面还可以反映出你对于工作的态度以及对与该工作岗位和公司的重视。
  二、 基础知识的掌握
  包括一些技术的规范、框架的掌握、插件及类库的使用以及具体业务功能的尝试要有一定的概念。你可以没有实际的项目,但是不能不掌握基本的知识结构。H5/C3/Es5/Es6/Amd/Cmd/Commonjs等规范,Jquery/Zepto/Bootstrap/Easyui等框架,Swiper/Iscroll/Lodash/Moment等插件类库,一般项目的功能模块有哪些等。
  三、 现代框架技术的熟悉
  什么是MVC、MVVM,Vue/React/Angular等属于什么类型的框架,与传统框架又有什么区别,和他们配合的UI框架有哪些,应用这些架框需要使用什么开发工具,什么构建工作等。
  四、 知识范围的扩展
  对于原生JS的知识扩展包括一些常用算法,对于现代化前端框架配合的Gulp/Webpack/Grunt以及前端预编译样式程序Sass/Less等有无一定的了解。能不能将示例项目的代码托管到码云、Github、Coding上。
  五、 排错能力的展现
  遇到问题了以后会进行怎么样的工作顺序?先看出错信息、断点调试、步调、测试工作的使用等。
  六、 学习方法的应用
  学习需要有一定的方法,比如说六何分析法。学习还需要定期的总结,有没有自己的一些总结内容和总结心得。
  七、 心态的状态
  公司看的面试人员的重要标准就是能力,而在没有技术能力的前提下要看到的是员工的心态。对应的能力获取对应的薪酬,如果说能力不足的情况下能否接受相对较低的薪酬标准,不能眼高手低。
  八、 有无示例项目,包括码云、Github账号
  没有完整的项目经验不代表没有操作过,包括示例项目,可以将自己的一些学习项目以及尝试项目做好Git的维护,也能够相应的加分。

前端是什么


前端即网站前台部分,运行在PC端,移动端等浏览器上展现给用户浏览的网页。随着互联网技术的发展,HTML5,CSS3,前端框架的应用,跨平台响应式网页设计能够适应各种屏幕分辨率,合适的动效设计,给用户带来极高的用户体验。
前端技术一般分为前端设计和前端开发,前端设计一般可以理解为网站的视觉设计,前端开发则是网站的前台代码实现,包括基本的HTML和CSS以及JavaScript/ajax,最新的高级版本HTML5、CSS3,以及SVG等。

前端开发中常用到的js特效有哪些


HTML5 DOM 选择器
// querySelector() 返回匹配到的第一个元素var item = document.querySelector(’.item’);console.log(item);// querySelectorAll() 返回匹配到的所有元素,是一个nodeList集合var items = document.querySelectorAll(’.item’);console.log(items);1234567

阻止默认行为
// 原生jsdocument.getElementById(’btn’).addEventListener(’click’, function (event) { event = event || window.event; if (event.preventDefault){ // w3c方法 阻止默认行为
event.preventDefault();
} else{ // ie 阻止默认行为
event.returnValue = false;
}
}, false);// jQuery$(’#btn’).on(’click’, function (event) { event.preventDefault();
});1234567891011121314151617

阻止冒泡
// 原生jsdocument.getElementById(’btn’).addEventListener(’click’, function (event) { event = event || window.event; if (event.stopPropagation){ // w3c方法 阻止冒泡
event.stopPropagation();
} else{ // ie 阻止冒泡
event.cancelBubble = true;
}
}, false);// jQuery$(’#btn’).on(’click’, function (event) { event.stopPropagation();
});1234567891011121314151617

鼠标滚轮事件
$(’#content’).on(“mousewheel DOMMouseScroll“, function (event) {
// chrome & ie || // firefox
var delta = (event.originalEvent.wheelDelta && (event.originalEvent.wheelDelta 》 0 ? 1 : -1)) || (event.originalEvent.detail && (event.originalEvent.detail 》 0 ? -1 : 1));

if (delta 》 0) {
// 向上滚动
console.log(’mousewheel top’);
} else if (delta 《 0) { // 向下滚动
console.log(’mousewheel bottom’);
}
});123456789101112

检测浏览器是否支持svg
function isSupportSVG() {
var SVG_NS = ’http://www.w3.org/2000/svg’; return !!document.createElementNS &&!!document.createElementNS(SVG_NS, ’svg’).createSVGRect;
}

// 测试console.log(isSupportSVG());1234567

检测浏览器是否支持canvas
function isSupportCanvas() {
if(document.createElement(’canvas’).getContext){ return true;
}else{ return false;
}
}// 测试,打开谷歌浏览器控制台查看结果console.log(isSupportCanvas());12345678910

检测是否是微信浏览器
function isWeiXinClient() {
var ua = navigator.userAgent.toLowerCase();
if (ua.match(/MicroMessenger/i)==“micromessenger“) {
return true;
} else {
return false;
}
}// 测试alert(isWeiXinClient());1234567891011

jQuery 获取鼠标在图片上的坐标
$(’#myImage’).click(function(event){
//获取鼠标在图片上的坐标
console.log(’X:’ + event.offsetX+’\n Y:’ + event.offsetY);

//获取元素相对于页面的坐标
console.log(’X:’+$(this).offset().left+’\n Y:’+$(this).offset().top);
});1234567

验证码倒计时代码
《!-- dom --》《input id=“send“ type=“button“ value=“发送验证码“》12
// 原生js版本var times = 60, // 临时设为60秒
timer = null;

document.getElementById(’send’).onclick = function () {
// 计时开始
timer = setInterval(function () {
times--; if (times 《= 0) {
send.value = ’发送验证码’;
clearInterval(timer);
send.disabled = false;
times = 60;
} else {
send.value = times + ’秒后重试’;
send.disabled = true;
}
}, 1000);
}1234567891011121314151617181920
// jQuery版本var times = 60,
timer = null;

$(’#send’).on(’click’, function () {
var $this = $(this); // 计时开始
timer = setInterval(function () {
times--; if (times 《= 0) {
$this.val(’发送验证码’);
clearInterval(timer);
$this.attr(’disabled’, false);
times = 60;
} else {
$this.val(times + ’秒后重试’);
$this.attr(’disabled’, true);
}
}, 1000);
});12345678910111213141516171819202122

常用的一些正则表达式
//匹配字母、数字、中文字符
/^([A-Za-z0-9]|[\u4e00-\u9fa5])*$/

//验证邮箱
/^\w+@([0-9a-zA-Z]+[.])+[a-z]{2,4}$/

//验证手机号
/^1[3|5|8|7]\d{9}$/

//验证URL
/^http:\/\/.+\./

//验证身份证号码
/(^\d{15}$)|(^\d{17}(|X|x)$)/

//匹配中文字符的正则表达式
/[\u4e00-\u9fa5]/

//匹配双字节字符(包括汉字在内)
/[^\x00-\xff]/1234567891011121314151617181920

js时间戳、毫秒格式化
function formatDate(now) {
var y = now.getFullYear(); var m = now.getMonth() + 1; // 注意js里的月要加1
var d = now.getDate(); var h = now.getHours();
var m = now.getMinutes();
var s = now.getSeconds(); return y + “-“ + m + “-“ + d + “ “ + h + “:“ + m + “:“ + s;
}

var nowDate = new Date(2016, 5, 13, 19, 18, 30, 20);

console.log(nowDate.getTime()); // 获得当前毫秒数: 1465816710020console.log(formatDate(nowDate));123456789101112131415

js限定字符数(注意:一个汉字算2个字符)
《input id=“txt“ type=“text“》//字符串截取function getByteVal(val, max) {
var returnValue = ’’; var byteValLen = 0; for (var i = 0; i 《 val.length; i++) { if (val[i].match(/[^\x00-\xff]/ig) != null) byteValLen += 2; else byteValLen += 1; if (byteValLen 》 max) break;
returnValue += val[i];
} return returnValue;
}

$(’#txt’).on(’keyup’, function () {
var val = this.value; if (val.replace(/[^\x00-\xff]/g, “**“).length 》 14) { this.value = getByteVal(val, 14);
}
});12345678910111213141516171819

js判断是否移动端及浏览器内核
var browser = {
versions: function() {
var u = navigator.userAgent;
return {
trident: u.indexOf(’Trident’) 》 -1, //IE内核
presto: u.indexOf(’Presto’) 》 -1, //opera内核
webKit: u.indexOf(’AppleWebKit’) 》 -1, //苹果、谷歌内核
gecko: u.indexOf(’Firefox’) 》 -1, //火狐内核Gecko
mobile: !!u.match(/AppleWebKit.*Mobile.*/), //是否为移动终端
ios: !!u.match(/\(i[^;]+;( U;)? CPU.+Mac OS X/), //ios
android: u.indexOf(’Android’) 》 -1 || u.indexOf(’Linux’) 》 -1, //android
iPhone: u.indexOf(’iPhone’) 》 -1 , //iPhone
iPad: u.indexOf(’iPad’) 》 -1, //iPad
webApp: u.indexOf(’Safari’) 》 -1 //Safari
};
}
}

if (browser.versions.mobile() || browser.versions.ios() || browser.versions.android() || browser.versions.iPhone() || browser.versions.iPad()) {
alert(’移动端’);
}123456789101112131415161718192021

之前我用过一个检测客户端的库 觉得挺好用的,也推荐给大家 叫 device.js,大家可以 Googel 或 百度
GItHub仓库地址:https://github.com/matthewhudson/device.js
getBoundingClientRect() 获取元素位置
//它返回一个对象,其中包含了left、right、top、bottom四个属性var myDiv = document.getElementById(’myDiv’);var x = myDiv.getBoundingClientRect().left;
var y = myDiv.getBoundingClientRect().top;

// 相当于jquery的: $(this).offset().left、$(this).offset().top // js的:this.offsetLeft、this.offsetTop123456

HTML5全屏
function fullscreen(element) {
if (element.requestFullscreen) {
element.requestFullscreen();
} else if (element.mozRequestFullScreen) {
element.mozRequestFullScreen();
} else if (element.webkitRequestFullscreen) {
element.webkitRequestFullscreen();
} else if (element.msRequestFullscreen) {
element.msRequestFullscreen();
}}

fullscreen(document.documentElement);12345678910111213
-前端啥也不会面试过了