【 题外话 】:本博主作为一名准毕业生,即将面临毕业就业问题,即将到大四了,不准备考研的我,那么该去干嘛呢?毫无疑问,那就是实习,那么即使是实习,那么在要想进入自己心仪的企业之前,笔试这一关终究是无法避免的!特此,刷刷题也是有必要的哈!

【 第一题 】

 var str = 'abc123';
var num = parseInt(str);
if (num == NaN) {
alert(NaN);
}else if (num == 123) {
alert(123);
}else if (typeof num == 'number') {
alert('number');
}else {
alert('str');
}

答案:弹出 number

解析:

parseInt():作用:解析一个字符串,参数:string [, radix],返回:解析后的数字,原有数组是否改变:否;该解析字符串为:'abc123',解析时从第一个字符开始解析,遇到非 Number 终止执行,故 num 的结果为:NaN,NaN 属于 number 类型,但不是一个有效的数字,并且NaN 和谁都不相等,包括自己,故弹出 number

【 第二题 】

 var a = 'abc' + 123 + 456;
console.log(a); var a = '456' - '123';
console.log(a); var a = 1;
var b = '2';
var c = a > b ? (a < b ? a : b) : (a == b ? a : b);
console.log(c); var a = 5 & 3;
console.log(a);

答案:abc123456  333  2  1

解析:

(1)+ :连字符

(2)除了 + 运算符,有连字符的特殊意义,其它均为运算符,浏览器会进行数据类型转换,对参与计算的自动转换成 number 类型

(3)b = 2;三元运算符,1 > 2 为假,取 :后面的值,故c = (a == b ? a : b) ,1 == 2 为假,故 c = b = 2

(4) &:位运算符,同 1 得 1,有 0 得 0;5:101 3:011 相与 => 001 => 1

【 第三题 】

 for (var i = 0; i <; i++) {
alert(i);
break;
}
alert(i);
for (var i = 0; i < 10; i++) {
continue;
alert(i);
}
alert(i);

答案:依次弹出三次,分别为:0  0  10

解析:

break:终止循环,故 i = 0 执行后便终止了,i++ 便没有执行,继续往下执行,此时 i 的值为:0,故再次弹出 0;

continue:跳出本次循环,所以不会执行 for 中的 alert(i),但会执行 i++ 直到 i = 10 结束循环,此时 i = 10,弹出 10.

【 第四题 】

 function fun(a, b, c) {
var l = arguments.length;
var num = 0;
for (var i = 0; i < l; i++) {
num += arguments[i];
}
alert(num)
}
fun(1,2,3);
fun(1,2,3,4);

答案:6  10

解析:

arguments 是一个对象,不是一个 Array,但类似 Array,除了 length 属性和索引元素之外没有任何 Array 属性,可以使用 arguments 对象在函数中引用函数的参数,所以即就是相当于函数的参数可作为属性存储在 arguments 中,以数组索引的方式调取引用,此处即为实现三个/四个数求和.【 可实现任意数求和 】

【 第五题 】

 var a = 0;
function fun() {
alert(a);
var a = 10;
}
fun();
alert(a);

答案:undefined  0

解析:

变量提升:a,形成一个私有作用域,存储一堆字符串:alert(a);var a = 10;

形参赋值,代码自上而下执行:全局变量 a = 0;fun();函数执行,其私有作用域中,同理变量提升,故 a 为 undefined;赋值:私有变量:a = 10;

弹出全局变量 a 的值:0

给自己点小自律:每天五道题,三个小demo,一需求,了解、巩固、熟悉、学习新知识;fighting

如有错误之处,欢迎大家评论指出哈!

web前端笔试篇(一)的更多相关文章

  1. web前端-基础篇

    该篇仅是本人学习前端时,做的备忘笔记: 一.背景图片设置: 设置背景图时的css代码:background-image:url(图片的url路径); ps:设置好这个背景后请一定要设置该背景图片的大小 ...

  2. web前端基础篇⑨

    1.web端.app端 目前实现响应式布局,主要用以下两种方式.CSS原生代码响应式布局 @media screen.bootstrap移动设备优先.自带框架. 兼容性 用原生代码的话 根据不同的屏幕 ...

  3. web前端基础篇①

    html1.html5和css3在IE上都不支持2.超过1100px以上的宽度,就会出现滚动条3.<!doctype html>解析模式 分为 标准模式 混杂模式 非标准模式-针对IE6o ...

  4. web前端笔试选择题

    1. 要动态改变层中内容可以使用的方法有(AB ) a)innerHTML b)innerText c)通过设置层的隐藏和显示来实现 d)通过设置层的样式属性的display属性 2. 当按键盘A时, ...

  5. web前端基础篇⑩

    1.960栅格式布局法屏幕分辨率为1024*768.采用接 main宽为960px的布局方式12列式:每格60px 间距20px 3 6 3版 三格式布局(最常用)16列式:每格40px 间距20px ...

  6. web前端基础篇⑧

    1.伪类选择器 都以冒号开始.:focus 焦点的地方加样式:first-child 向元素的第一个子元素添加样式锚伪类:a:link {color:red} 未访问的链接 a:visited {co ...

  7. web前端基础篇⑦

    1.img src/url后一般接地址信息 标题为<h1>-<h6> 字体依次变小 预文本格式<pre></pre> 2.a标签实现跳转 例:<a ...

  8. web前端基础篇⑥

    LESS.①是一种拓展技术,基于css.②包含变量.混合.函数.运算.③简化css代码.降低维护成本④目前用的解析器(koala) 变量(值可变)@变量名:值步骤:①建立文件夹②建html和less两 ...

  9. web前端基础篇⑤

    1.雪碧图技术(精灵图)sprite cpmpass-合并2.兼容性:1.reset充值技术,normalize技术2.加前缀-webkit —mom -ms— -o-3.<!Doctype&g ...

随机推荐

  1. SSL Converter & Formats

    https://www.sslshopper.com/ssl-converter.html PEM Format The PEM format is the most common format th ...

  2. TStringGrid多选的复制与拷贝

    uses Clipbrd; function StringGridSelectText(mStringGrid: TStringGrid): string; var   I, J: Integer; ...

  3. java多线程之线程安全

    线程安全和非线程安全是多线程的经典问题,非线程安全会在多个线程对同一个对象并发访问时发生. 注意1: 非线程安全的问题存在于实例变量中,如果是方法内部的私有变量,则不存在非线程安全问题. 实例变量是对 ...

  4. Nginx学习笔记---服务与集群

    一.集群 什么是集群 服务器架构集群:多台服务器组成的响应式大并发,高数据量访问的架构体系. 特点: (1)成本高 (2)能够降低单台服务器的压力,使用流量平均分配到多台服务器 (3)使网站服务架构更 ...

  5. 面试还不知道BeanFactory和ApplicationContext的区别?

    接口 BeanFactory 和 ApplicationContext 都是用来从容器中获取 Spring beans 的,但是,他们二者有很大不同 我看到过很多问 BeanFactory 和 App ...

  6. Google Earth Engine城市水体提取

    Google Earth Engine城市水体提取 大家都知道城市水体提取相比较于山区,丘陵的地区,肯定是比较难的,为什么呢,因为城市水体有很多高层建筑导致的阴影,这个就非常复杂了,而且现在很多高分影 ...

  7. spring cloud 系列第8篇 —— config+bus 分布式配置中心与配置热刷新 (F版本)

    源码Gitub地址:https://github.com/heibaiying/spring-samples-for-all 一.config 简介 spring cloud config 分为服务端 ...

  8. Liunx 安装 Nessus

    Liunx 安装 Nessus   啥子是Nessus 它是一款系统漏洞扫描与分析软件,可以扫描服务器存在哪些漏洞,页面简介美观,非常Nice. 获取激活码 首先访问如下网站 https://www. ...

  9. docker相关使用

    安装docker 在CentOS 7上安装docker-ce,首先检查系统中是否已经安装过docker及相关依赖: $ sudo yum remove docker docker-client doc ...

  10. Product Backlog:终极任务清单

    健康的Product Backlog就像一个健康的人那样:整洁有序.组织合理.公开透明.一个按照优先级顺序排好的敏捷Backlog不仅能够简化发版和迭代计划,还能够对团队计划去做的所有工作进行细致规划 ...