WY-javascript练习收集

类型系统


1、以下表达式返回的值是多少?

“1”-null+true

答案: 2

2、type([])的结果是?

  • A “Object”
  • B “Function”
  • C “Array”
  • D “object”

答案: D

3、以下表达式返回的结果是false的有?

  • A (function(){}).constructor == Object
  • B [].constructor == Array
  • C true.constructor == Boolean
  • D (1).constructor == Number

答案: A (Function)

4、以下语句执行后,a的值不是undefined的有?

  • A var a = (function(b){return b;})();
  • B var a = document.getElementById('notExistElement');
  • C var o = {x:1};var a = o.y;
  • D var a

答案: B (null)

知识点
undefined 出现场景:
已声明未赋值的变量
获取对象不存在的属性
无返回值的函数的执行结果
函数的参数没有传入
void(express)

5、实现type函数用于识别标准类型和内置对象类型,语法如下:

var t = type(obj)

答案:

function type(obj){
    return  Object.prototype.toString.call(obj).slice(8, -1).toLowerCase()
}

内置对象


1、以下代码执行完成后president.name的值是

function setName(obj){
    obj.name = "obama";
    obj = {name:"clinton"};
}
var president = {name:"bush"};
setName(president);
  • A."clinton"
  • B.undefined
  • C."obama"
  • D."bush"

答案:C

2、以下代码执行后a、b的值分别是?

var str = "welcome to NetEase!welcome to MOOC!";
var a = str.indexOf("to");
var b = str.indexOf("to", a+1);

答案:8,27

3、以下代码执行后ret和arr的值分别是?

var arr=[1,2,"a","b"];
var ret=arr.splice(1,2,3);

答案:
ret : [2,"a"]
arr : [1,3,"b"]

知识点
splice() 方法 向/从数组中添加/删除项目,然后返回被删除的项目。
注释:该方法会改变原始数组。
语法:arrayObject.splice(index,howmany,item1,.....,itemX)

4、以下表达式返回结果是?

parseInt("10.1",16)
  • A.16
  • B.10
  • C.10.1
  • D.8

答案: A

5、表达式 "1+1".replace("1","2") 返回结果是?

答案:2+1

知识点
replace(str1,str2)方法替换的只是第一个匹配的字符串


如果想要替换全部,可以使用正则。(但这种正则表达式是有局限的)
var str = "男的女的老的少的";
alert(str.replace(new RegExp(/(的)/g),''));


匹配的是一些特定的字符串,如何匹配动态的字符串呢?
var replaceStr = "的";
alert(str.replace(new RegExp(replaceStr,'gm'),''));
这样我们就完成了匹配字符串的动态赋值。


另外还有其他的方法实现全部替换
alert(str.split(replaceStr).join(''));

6、(/^abc/i).test("Abc123")的结果是?

答案:true

7、var obj = Object.create({a:1}); obj.hasOwnProperty('a')返回结果是___?

答案:false ( - a是对象原型连上的属性)

知识点
Object.create(proto[,propertisObject])
是基于原型对象创建新对象


Object.prototype.hasOwnproperty判断一个属性是否是对象自身属性

表达式与运算符


1、代码执行后a,b的值分别是多少?

var a = 0
var b = true || a++

答案: 0,true

2、代码执行后a,b的值分别是多少?

var a = 0
var b = true && a++

答案: 1,0

3、一些表达式返回结果为true的有:?

  • A Number("a") == NaN
  • B false =="0"
  • C "123" == 123
  • D new String("123") =="123"

答案: BCD

知识点补充
类型转换例外情况:
null == undefined //true
null或undefined参与进行==运算时不进行隐式类型转换
0 == null //false
null == false //false
"undefined" == undefined //false

变量作用域


1、以下代码执行时两个alert的值是多少?

(function(){
   a = 5;
   alert(window.a)
   var a = 10;
   alert(a)
 })()

答案:undefined 10

2、以下代码执行时alert的值是多少?

var a = 6;
(function(){
   alert(window.a)
       alert(a)
   var a = 10;
   alert(a)
 })()

答案:6 undefined 10

3、以下代码执行时两个alert的值是多少?

var a = 6;
(function(){
       alert(a)
 })()

答案:6

4、以下代码执行时alert的值是多少?

var x = 10;
function foo(){
    alert(x);
}
function bar(){
    var x = 20;
    foo();
}
bar();

答案:10

知识点1
用词法环境进行分析

知识点2
JS使用动态作用域
JS没有块级作用域
JS函数运行在他们被定义的作用域里
catch语句可以临时改变js变量作用域

闭包

1、以下代码执行时alert的值是多少?

var a=1;
var func = (function(){
    var a=2;
    return function(){
        a++;
        alert(a)
    }
})()
func();
func();

答案:3,4

面向对象


1、eval函数中的this值是?

答案:调用上下文的this

2、下列关于js描述正确的有?

  • A js中可以使用prototype实现原型继承
  • B 在对象构造器中,可以使用this创建对象的属性
  • C js中不能使用面向对象
  • D js中不能给未定义的变量赋值

答案:AB

3、使用 new Function()创建的函数代码中this是全局对象?

  • A js中可以使用prototype实现原型继承
  • B 在对象构造器中,可以使用this创建对象的属性
  • C js中不能使用面向对象
  • D js中不能给未定义的变量赋值

答案:AB

4、使用new Function()创建的函数代码中的this是全局对象?

  • A 错误
  • B 正确

答案:B
例如:

   var foo3 = new Function('var temp = 100; console.log(this); this.temp = 200; return temp + this.temp;');
  //this 指window对象

4、JS中所有函数都可以当成构造器?

  • A 错误
  • B 正确

答案:A

5、以下代码用于判断user对象就有自身属性name?
user.______('name')

答案:hasOwnProperty

5、以下代码alert的值依次是?

function Teacher(){}

Teacher.prototype = {
    job : 'teacher',
    setName : function(name){
        this.name = name
    }
}

var bill = new Teacher()
bill.setName('Bill')
alert(bill.name) //Bill
alert(bill.job) //teacher

bill.job = 'assistant';
alert(bill.job) //assistant
delete bill.job;
alert(bill.job); //teacher

答案:Bill teacher assistant teacher

6、写代码

Object.create

if( typeof Object.create != 'function'){

    Object.create = function(obj){
        if( typeof obj != 'object' ){
            throw TypeError('Object prototype may only be an Object or null')
        }
        var r = function(){}
        r.prototype = obj
        return new r;  //new r() 与new r 没有区别,只是r函数没有参数时,括号可以省略
    }

}

var a = Object.create({x:1,y:2})
alert(a.x)

综合


1、写代码

题目

答案:

function myType(param){
    alert("I am an " + Object.prototype.toString.call(param).slice(8, -1) )
}

2、写代码

题目
function search(arr,dst){
    var type = Object.prototype.toString.call(arr).slice(8,-1);
    if(type != 'Array'){
        throw TypeError('Object prototype may only be an Array')
    }
    var len = arr.length;
    if( !len){
        return -1;
    }

    var l = 0;
    var h = len - 1;
    while(l <= h){
        var m = Math.floor( (h+l)/2 );
        if( arr[m] == dst ){
            return m;
        }else if( dst < arr[m] ){ //左半部分
            h = m - 1;
        }else{ //右半部分
            l = m + 1;
        }

    }
}
var arr = [1,2,4,6,7,9,19,20,30,40,45,47];
alert( search(arr,45) )
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,904评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,581评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,527评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,463评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,546评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,572评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,582评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,330评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,776评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,087评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,257评论 1 344
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,923评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,571评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,192评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,436评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,145评论 2 366
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,127评论 2 352

推荐阅读更多精彩内容

  • 《ijs》速成开发手册3.0 官方用户交流:iApp开发交流(1) 239547050iApp开发交流(2) 10...
    叶染柒丶阅读 5,115评论 0 7
  • 第一章: JS简介 从当初简单的语言,变成了现在能够处理复杂计算和交互,拥有闭包、匿名函数, 甚至元编程等...
    LaBaby_阅读 1,664评论 0 6
  • @转自GitHub 介绍js的基本数据类型。Undefined、Null、Boolean、Number、Strin...
    YT_Zou阅读 1,153评论 0 0
  • 真正开始健身还是从今年5月份,在这之前一直想去健身,每次看到健身教练,匀称的身材,结实的肌肉总是羡慕不已,也一...
    一醉方休解千愁阅读 172评论 0 0
  • 闺蜜豆子看完上篇写的《她结婚了,他闪婚了》发来微信说:“大家都到了结婚的年纪,到处都是晒娃晒幸福的,你的呢? 我的...
    初之阅读 275评论 2 2