【面试问题】——秋招面试中遇到的一些问题&思维导图

前言:秋招也跑了挺多的公司,虽然都是招Web前端,但是不同的公司,因为需求和目的不同,面试的考察点也是各不相同。我没有实习经验,只有自己学东学西比较杂也比较浅的一些知识积累可以用,这个过程我发现了自己的不足,也增加了很多对公司、对社会的阅历,觉得自己成长了。哈哈哈,废话不多说,下面我就整理一下自己面试的很多问题,还有自己整理总结的答案、分析。


一、基础入门类

  

二、原生JS和Jquery操作DOM元素

  • 常用的事件:十个
  1. click
  2. mousemove
  3. mouseover
  4. mouseout
  5. mouseenter
  6. mouseleave
  7. mouseup
  8. scroll
  9. mousewheel
  10. onkeydown

【特别注明:这里原生JS和JQuery操作DOM元素  参考梳理自博文 —— 感谢原作者的分享,这里仅作学习整理】

 

三、PHP和Node.js的区别

 

 

面试问了PHP和Node.js的区别,是因为它们首先值得比较(相似点很多):两者都是开放源码,都是致力于web开发,并且都可用于相似的项目

下面将会对 PHP 和 Node.js 进行十几个方面的比较。每个对比都会考量可以应用到任意 web 技术的常见的开发挑战。我们不会太深入讨论细节;很少有人会关心随机数生成器或数组排序的价值。

【特别注明:这里PHP和Node.js的区别梳理参考 文章 —— 感谢原作者的分享,这里仅作学习整理】

  PHP Node.js
创建时间 1994年 2009年
运行基础 安装在web服务器(Apache等)上的组件运行的

基于Google的V8 JavaScript解释引擎

(在Chrome浏览器里它负责执行客户端的JavaScript代码)

和其他语言不同的地方 PHP代码可以和HTML混合到一块

Node.js内置了处理网络请求和响应的函数库,

所以不需要单独的服务器(Apache等)或者其他依赖

起步

一段<?php …php>代码可以放在任意.php文件中,

在浏览器中输入URL跳转到文件即可

但是,只能运行于安装了PHP的web服务器

只需要 下载安装程序 或 使用包管理器

在浏览器输入http://127.0.0.8080/之前,

需要在终端输入node app.js来启动应用程序

帮助和支持 有大量的指南和二十年的 Q&A 拥有很好的文档,但是更加年轻,能提供的帮助较 PHP 也少
语言语法

PHP不会限制按特定的方式编写,

PHP在版本间可能有一些调整,但是向后兼容一般都做的很好

也导致一个问题:PHP很混乱,

怎么统计一个字符串中字符的个数

PHP有数以百记的函数,而且命名规则也不完全一致

JavaScript代码比PHP简洁

例如,你再不需要跟 JSON 转来转去—— UTF-8 也不用

全栈工程师可以同时在客户端与服务端使用 JavaScript 

大脑不用来回切换

开发工具  

NPM包管理器

NPM允许安装和管理依赖,设置配置变量,定义脚本和其他

 环境  PHP本质上就是一个服务端技术,它很擅长该领域

 JavaScript原来的主战场还是浏览器,

Node.JS出现后可以在任何地方使用,

浏览器、服务器、终端、桌面甚至嵌入型系统

 集成  PHP的扩展,使他能和拥有主流或冷门的API的服务器直接通讯

 Node.js会为某些老旧冷门的技术寻找成熟集成组件而头疼

 托管和部署

 随机联系某个网页托管公司你可以找到对主要的 PHP 支持,

也许还免费附送 MySQL

 Node.js 是个不同的野兽,服务端的应用永远运行。

你需要一台物理/虚拟/云或定制的服务器环境,最好有 root 权限,

这对有些服务器来说遥不可及,特别是那些共享的服务器,

你有可能让整台服务器宕机

 性能 ↓

 PHP很快,

有很多项目和选项可以使他跑得更快,

几乎不会担心速度问题

 Node.js性能通常会更好一点

1、Node.js更少的依赖

所有对PHP的应用,都必须经过一个Web服务器的路由,

来启动PHP的解释器运行PHP代码

Node.js不需要这些依赖,

而且你基本一定会使用一个带服务器的框架,

比如:Express,它很轻量,很好的扮演应用的一部分

2、Node.js更小更快的解释器

会受到旧版语言遗留兼容问题的拖累

Node.js 的解释器比 PHP 的更小更灵活。

他并不受旧版语言遗留兼容问题的拖累,

而且 Google 在 V8 引擎性能改善上出了大力。

3、Node.js应用永久在线

PHP遵循标准客户端—服务端模型。

每个页面请求都会初始化应用;

读取配置参数、连接数据库、读取信息、渲染HTML。

Node.js应用持久运行,只需要启动一次。

例如:可以创建一个单独的数据连接对象,然后所求请求一起复用

4、Node.js事件驱动,无阻塞I/O

PHP跟其他多数服务器语言采用阻塞执行的模型。

当你执行一个命令,比如数据库取数据,

那么必须等这个命令执行完成后,才执行下面的命令

Node.js通常不会等的,

取而代之的是,你需要提供一个回调函数,

这个函数当指令执行后,会被调用一次。

换句话说,当解释器在其他进程处理的时候可以干些别的事情

 关于集成:指开发技术很受限制,除非它们能与数据库和驱动集成。

 关于性能:性能很大程度上决定于开发团队的经验以及是否上心。

 关于Node.js事件驱动,无阻塞I/O的几个警告:

  1. Node.js/JavaScript只能在单线程上运行,但是大多数Web服务器都是多线程,而且并发的处理请求。
  2. 一个用户长时间运行的 JavaScript 处理会阻止其它用户的代码执行,除非拆分任务或者使用Web Workers。

开发建议:评估选项,根据你的需求来选择一门语言,这比这样的”对比“靠谱得多。

四、AngularJS和Node.js的区别

从应用上来说,宽泛的讲:

  1. node.js是用于服务器端,做后台程序的。
  2. AngularJS是前端框架,主要用于数据绑定;不需要安装,只要在<script>标签导入就能用了。

当然,面试一定不是问这个,这个太敷衍了,要区别AngularJS和Nodejs的原因,首先也是因为它们是有相似点的:

  1.  它们都是单线程运行类型。
  2.  都可以使用一个主文件(引导页面或js文件)+多个路由运行的模式,实现页面的跳转。

【特别注明:这里AngularJS和Node.js的路由区别梳理参考 文章 —— 感谢原作者的分享,这里仅作学习整理】

  AngularJS的路由 NodeJS(Express)的路由
页面跳转

针对于页面的路由,每次路由发生变化,

只是页面的状态发生变化,页面本身没有发生跳转

express的路由是针对页面的,

也就是说他做的页面,路由的切换是伴随着页面的切换

路由类型

Angular的路由是前台的就是以前html的各个锚点

#login,#index,#user,看到了没,有个井号

Express的路由是后台的url

例如:/user/:id/edit

互相使用 Angular不可以跑Express

Express可以跑Angular

可以在Express的路由里面跳转到一个Angular页面

之后所有的操作可以在Angular的路由里面玩耍,

但是玩耍到最后,

发生数据交互,还是要发给Express


关于页面跳转的选择,建议:页面内部的路由变化使用angular.js 的router,而页面间的路由用express


注:转载请注明出处

原文地址:https://www.cnblogs.com/ljq66/p/7944421.html