私人定制javascript中对象小知识点(Only For Me)

废话不多讲,先上笑话,然后再,。看懂这个的说明你的节操已经不再了。

晚饭后去理发店理发。。。割了吧。。。老板问我怎么剪,我悠悠的来一句往帅了剪。。。高潮往往令人想不到。。。。旁边一在焗油烫头发的大妈说到 别这样为难老板,人家赚点钱不容易。。。
首先如果你是高手那么请出门右转,如果你是菜鸟那么恭喜你,go on吧

全局对象
在javascript程序中任何位置,都可以拈来就用的这种东西,是全局对象的属性.那么属性所在的对象也就是全局对象了。
当javascript解释器启动时(或者任何Web浏览器加载新页面的时候),它将创建一个新的全局
对象,并给它一组定义的初始属性:
1.全局属性,比如undefined,Nan
2.全局函数,例如isNaN(),parseInt()
3.构造函数,比如Date(),String()
4.全局对象,比如Math和JSON()
代码中声明了一个全局变量,这个全局变量就是全局对象的一个属性
以上代码纯属占篇幅,上代码

var s="hello world!";
var tempstr=s.substring(s.indexof(" ")+1);

有没有有想过为什么s会调用substring()方法呢?

答案是只要引用了字符串s的属性,javascript就会将字符串值通过new String(s)的方式转换成对象,
这个对象继承了字符串的方法,并被用来处理属性的引用。一旦属性引用结束,这个新创建的对象就会销毁。
举例为证:

var s="test";
s.len=4; //给它设置一个属性
var temp=s.len;
console.log(temp) //undefined

解释:第二行代码创建一个临时字符串对象,并给其len属性赋值为4,但是马上就销毁这个对象。第三行试图访问临时属性,

修改只是发生在临时对象身上,但这个临时对象并未保存。
这就引出一个概念存取字符串,数字或布尔值的属性时创建的临时对象叫做包装对象。
知道了这个就可以区分什么时候字符串和字符串对象等等概念。具体有什么大的用处,我还真心不太了解。

包装对象
首先什么是包装对象,就是将普通的非对象的常规类型用某种方式包装成了一个对象
答案是可以通过某些内置构造函数String()//Number()限时创建包装对象

var S=new String("marry you");
console.log(S); //String {0: "m", 1: "a", 2: "r", 3: "r", 4: "y", 5: " ", 6: "y", 7: "o", 8: "u", length: 9} 

可以用==和===来区分是否是包装对象,==将原始值和包装对象视为相等,当"==="视为不等,也可以通过typeof

原始值和对象有着根本的区别是,原始值是不可更改的。虽然符串看上去有点例外。
比如

var s="marry me";
s=s.toUpperCase();
console.log(s); //MARRY ME 

实际上返回给s的是一个新的字符串

对象转换为原始值

那么怎么实现对象转化为原始值呢
常见的有对象到字符串和数字到字符串等等
所有对象继承了两个转换方法。
第一个是toString()
  作用是返回一个反映这个对象的字符串。
第二个是valueOf()
  作用是如果存在任意原始值,它就默认将对象转换为表示它的原始值。对象是复合值,而且大多数对象无法真正表示
一个原始值,默认返回对象本身,非原始值。(其实这个知识点还可以挖的更深,对此我只能浅尝而止啦)
例如:[1,2,4].toString();// "1,2,3"

(function(x){console.log("marry you");}).toString(); //"function (x){console.log("marry you");}"
new Date(2022,2,2).toString();//"Sat Mar 02 2222 00:00:00 GMT+0800 (中国标准时间)"

var d=new Date(2020,2,22);
d.valueOf();//1584806400000

那么为啥会出现的不太一样呢,因为很多内置类都对toString()做了修改了。

所以如果你要想使用toString()来反应这个对象的字符串类型
Object.prototype.toString().call(obj);//这样得到的就是最原始的toString()的含义
如:Object.prototype.toString.call([1,2,4]); //"[object Array]"
如果你用[1,2,4].toString();//"1,2,4" 如果你得出这个鬼东西,我就只能安慰你,哥们不哭,站起来撸

变量作用域

在此简单说说变量的作用域
首先变量的作用域是变量的作用范围区域,特别给从后端程序员转到前端的程序员说一点,此处的作用域不是用{}块级来
区分作用域的,而是用一个function函数来区分作用域的也叫做函数块级作用域。
比如for(var i=0;i<1;i++){console.log(i);} console.log("还是在这个作用域的i:",i)  //0,还是在这个作用域的i: 1

首先函数体内,局部变量的优先级高于同名的全局变量。

var a="global";
function testscope(){
var a="local";
return a;
}
testscope();//"local"

so作用域还有很多需要整理的,未完待续。如果你觉得对你有一点点帮助,求点推荐。如果没有,不要点推荐旁边的按钮。

要不然我会来找你的...

私人定制javascript中对象小知识点(Only For Me)

时间: 2024-12-19 02:28:42

私人定制javascript中对象小知识点(Only For Me)的相关文章

私人定制javascript中数组小知识点(Only For Me)

先上笑话,1.刚看到一个游泳的,想起公司组织去三亚旅游,老板跳海里,各种挣扎,捞上来老板第一句话:我记得我会游泳的啊. 2.媳妇说:老公对不起,我把你新买的自行车撞散架了! 老公:没事宝贝,你若安好,便是晴天! 媳妇说:老公你太有诗意了. 老公:滚犊子,安不好我整死你! 数组的概念 javascript数组是值得有序集合,不过它实属一个javascript对象的特殊形式,这是一个很重点的定性. 创建数组 1.var a=new Array();//等同于[] 2.var a=new Array(

私人定制javascript中函数小知识点

函数的定义 首先在javascript中,函数就是对象,程序可以随意操控它们.比如,可以给它们设置属性,甚至调用它们的方法.函数使用function关键字来定义.它既可以用在函数定义表达式,也可以用在函数声明语句中.函数声明function后面必须要更上函数名称也就是所谓的函数名称标识符.如果是函数表达式函数名称标识符可有可无.这段重点是函数是对象,所以函数表现出来的种种行为你想想成对象,那么很多疑惑可能就恍如昨日初见. 函数调用 4种方式来调用javascript函数: 1.作为函数 就是函数

Javascript的一些小知识点

小弟五一回家去了,本想好好的享受下五一假期,谁知悲剧的人生不需要解释.好不容易过五关斩十将,跨千山趟万水,回到家里.吃着老妈做的好菜,第二天就莫名其妙的急性肠炎,这肚子闹腾的.NND,气死哥了,早知道就不回家了.好了,废话不多说,进入主题. ================ 关于clientHeight.offsetHeight.scrollHeight window.screen.availWidth 返回当前屏幕宽度(空白空间) window.screen.availHeight 返回当前屏

记录神经网络中一些小知识点

记录神经网络中一些小知识点 1 Caffe中的blob维度 Caffe中的blob具有4个维度,分别是num,channel,width和height: 其中我们在定义各个网络层时,常用到的一个参数numout,就是指定的channel: 比如说,维度为1*3*5*5的数据输入网络(即每次输入一张5*5大小的3通道图),经过一个stride为2,pad为1,kernel为2,numout为2的卷积层后,维度就变成了1*2*3*3: 假如输入有n个通道,计算时,caffe就会对应产生n个filte

JavaScript中对象类型的转换小结

对象到字符串和对象到数字类型的转换涉及到两个重要的方法,最终的转换结果会受到这两个方法返回结果的影响,这两个方法就是toString和valueOf.所有的对象都会从Object对象中继承到这两个方法.toString方法 用于返回对象的字符串表示(但是其实也可以不返回字符串).对于默认从Object继承而来的toString方法并不会返回太多有意义的内容.而valueOf方法目的是返回一个可以表示对象的原始类型值,但是由于对象的复杂性,大多数情况下根本不可能用一个原始类型值来表示,所以默认的v

JavaScript中对象属性的添加和删除

<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>Insert title here</title> <script type="text/javascript"> /* * 用.为对象添加属性 用关键字delete删除属性 用[]添加属性 和.的不同 r.name==r["name"]; r.

关于 JavaScript 中一个小细节问题 (在控制台中直接 {} 对象报错问题)

在 Chrome 浏览器,大家可能遇到这样一个小问题. 随便输入一个 Object 对象  ,比如 {Name:'王尼玛',Age:20} ,将会报错.之前,也从来没去考虑过到底是为啥原因. 今天,刚好看到博客园有博友文章,顺便记录一下. 在 JavaScript 中, : 有三种作用,想必大家都知道,其一  三元表达式  true? A:B,其二 在 switch case 中 case 语句中会用到,其三 就是上图中,对象直接量表达式中. 其实 ,在 JS 中,: 还有一种用法,如下所示,内

javascript中对象的深度克隆

零.寒暄 又是一个月多月没有更新博客了,这段时间回学校处理下论文的事情,实习的生活也暂时告一段落(在公司上班,才发现学校里面的生活简直如天堂一般,相信很多已经毕业的小伙伴肯定被我说中了,说中了请给本文点个赞,哈哈!).希望接下来自己的更新进度能加快,马上又是一年校招时,被虐也好.大牛虐别人也罢,总之祝福各位今年要找工作的小伙伴们好运.那么,今天就聊一下一个常见的笔试.面试题,js中对象的深度克隆.翻了下这个题目,在很多地方出现过,已经算一个老的题目了,但是每年的校招中总会考到,其实想想,这个题目

javascript中对象访问自身属性的方式

在javascript中,通过对象的方法访问对象自身属性时,必须采用this.fieldName的方式. 原因是javascript中Function是无状态的,访问对象的属性时,必须指定当前的上下文状态,即添加this关键字.如果没有指定,则上下文默认为window. 举例如下: 1 var obj = 2 { 3 name:"James", 4 showName:function(){ 5 alert(name); 6 } 7 } 通过控制台执行obj.showName() 输出为