您的位置:首页 > Web前端 > JavaScript

今天做过的一道js题目解析

2017-03-04 09:40 274 查看

今天做过的一道js题目解析

time:2017-03-03 22:11:45

今天做题的时候,无意中做到一道这样的题:

var obj = {"key":"1", "value":"2"};
var newObj = obj;
newObj.value += obj.key;
console.log(newObj);


初看的时候,感觉好简单,当时就不加思索的给出了
{"key": "1", "value":"3"}
这个答案。后来结果可想而知,当然是做错了。当时自我感觉羞愧难当,要说这本来就是个很基础的题目,正确的答案当然是这样了:
{"key": "1", "value":"21"}
;看过答案以后,稍微思索一下,就能够得出这个答案,但是为什么初看的时候做错了呢?

后来想了想,归根到底,原因还是自己对JavaScript这门语言的基础知识掌握的不扎实。要说这道题目,主要考察的就是JavaScript中的Object对象string字符串“+”操作符的作用等知识点。如果说学JavaScript这么语言,没掌握这些基础的知识,那么你压根就不敢说自己懂JavaScript了吧。

具体的这些知识点的详解,在这里也不一一列举了,有太多书籍都有介绍过。如果有不懂的读者,可以自行百度或者通过看书去查阅了解。在这里,我推荐一本我觉得不错的书——《JavaScript高级程序设计》。

重新温习过相关的知识点以后,我又自己改动了一下题目,代码变成了这样:

//demo 01
var obj = {"key":"1","value":"2"};  //属性名也可以采用字符串的设置方式
var newObj = obj;
console.log(obj.key);   //"1"
console.log(typeof newObj.value);   //string
console.log(newObj.value);  //"2"
console.log(typeof newObj.value);   //string
newObj.value += obj.key;
console.log(newObj);    //{"key":"1", "value":"21"}


再改一下,变成下面的形式:

//demo 02
var obj = {key:1,value:2};  //属性名也可以采用这种方式,将属性值变成数值
var newObj = obj;
console.log(obj.key);   //1
console.log(typeof newObj.value);   //number
console.log(newObj.value);  //2
console.log(typeof newObj.value);   //number
newObj.value += obj.key;
console.log(newObj);    //{"key":1, "value":3}


我相信,大部分入门了JavaScript这门语言的读者,看了上面两个demo变体之后,都应该一目了然,懂得了这道题的原理了。

编程语言的掌握真的不是一件易事,至少对于我这个刚入门的小白来说,的确是这样的。

本人只是一枚前端小白,以上有一些个人的拙见,若喷请轻喷,也欢迎同样跟我奋斗在前端道路上的新手童鞋跟我交流学习,我的个人邮箱是:
wuzhiqin@yahoo.com
,欢迎叨扰。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  javascript