JS基础 不知道的JS

1.JS区分大小写,而HTML不区分大小写(XHTML区分大小写)。

2.当不书写分号时,JavaScript解释器并不会在所有换行处都填补分号,只有在缺少了分号就无法正确解析代码的时候,

JavaScript才会填补分号。(换言之,JavaScript默认使用贪婪模式匹配语句,即尽可能地将代码压缩拼接,只有当报错时,

才会填补上分号)。

所以,有些程序员喜欢保守地在语句前加上一个分号,保证语句能够正确地被解析。

;[x,x+1,x+2].forEach(console.log)

但如果是return,break,continue紧接着换行,JavaScript则会在换行处添加分号。

return
true;

浏览器会解析成

return;
true;

如果在return,break,continue后紧接着换行,程序只有在极特殊情况下才报错,且调试不方便。

说明为了不引起歧义,以及保持良好的编程习惯,都不应该省略分号。

3.在任何数字直接量添加负号可以得到它们的负值,但负号是一元求反运算符,并不是数字直接量语法的组成部分。

4.在ES6的严格解析模式下,八进制是明令禁止的。也说明在一般情况下,我们不能随意地使用八进制。

5.JavaScript不区分整数值和浮点数值,所有数字采用浮点值表示。浮点值直接量既可以采用传统的实数写法,也可以

采用指数记数法的形式来书写。JavaScript采用了IEEE-754浮点数表示法(几乎所有编程语言都是这种方法)。所以

JavaScript并不能准确地表示类似0.1的精度,即0.3 - 0.2也只是约等于0.1.

在进行金融计算时,我们更愿意使用大整数来进行计算。(先将小数变成整数,计算后再按比例换成小数)。

有关浮点数的详情可以看这里我觉得挺ok:https://segmentfault.com/a/1190000008268668

6.在ES5中,字符串直接量可以通过反斜线(\)来拆分成多行。

7.任意JavaScript的值都可以转换成布尔值。下面的这些值会转换为false。

undefined
null
0
-0
NaN
"" //空字符串

8.当o为0或""时,要跟null区分开,可以使用

if(o !== null)

的方法来显式比较。

9.布尔值包含toString()方法,可以把bool值变为字符串。

10.typeof(null)返回的是object,也就是说可以把null认为是一个特殊的对象值。

     typeof(undefined)返回的是undefined。表明这个值是这个类型的唯一成员。

 

     null 和 undefined 都不包含任何的属性和方法。

 

     返回undefined有四种情况:

     变量没有初始化。

    查询对象属性或数组元素不存在。

    函数没有任何返回值,返回undefined。

    引用没有提供实参的函数形参的值。

     

    null 和 undefined 使用"=="运算符会认为两者是相等的,所以要使用严格运算符"==="。

 

11.包装对象;

当引用字符串属性时,JS会将字符串通过调用new Strings()的方式转换对象,这个对象继承了字符串的方法,并被处理

属性的引用,一但属性引用结束,这个新的对象就会被销毁。(数字和布尔值也类似。其实在实现上不一定是创建和销毁临时

对象,但看起来是这样子。)

var s = 'test';

s.length  //4
var t = s.length //undefined

这段代码表明修改只是发生在临时对象上,而临时对象并未保留下来。

12.JavaScript中的原始值(undefined、null、布尔值、数字和字符串)与对象(包括数组和函数)有着根本区别。

原始值是不可更改的:任何方法都无法更改(或“突变”)一个原始值。

原始值的字符串不可更改,不过使用字符串的方法或属性会会创造一个包装对象,有些方法或属性会返回新的字符串。

如toUpperCase()方法。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
提供的源码资源涵盖了安卓应用、小程序、Python应用和Java应用等多个领域,每个领域都包含了丰富的实例和项目。这些源码都是基于各自平台的最新技术和标准编写,确保了在对应环境下能够无缝运行。同时,源码中配备了详细的注释和文档,帮助用户快速理解代码结构和实现逻辑。 适用人群: 这些源码资源特别适合大学生群体。无论你是计算机相关专业的学生,还是对其他领域编程感兴趣的学生,这些资源都能为你提供宝贵的学习和实践机会。通过学习和运行这些源码,你可以掌握各平台开发的基础知识,提升编程能力和项目实战经验。 使用场景及目标: 在学习阶段,你可以利用这些源码资源进行课程实践、课外项目或毕业设计。通过分析和运行源码,你将深入了解各平台开发的技术细节和最佳实践,逐步培养起自己的项目开发和问题解决能力。此外,在求职或创业过程中,具备跨平台开发能力的大学生将更具竞争力。 其他说明: 为了确保源码资源的可运行性和易用性,特别注意了以下几点:首先,每份源码都提供了详细的运行环境和依赖说明,确保用户能够轻松搭建起开发环境;其次,源码中的注释和文档都非常完善,方便用户快速上手和理解代码;最后,我会定期更新这些源码资源,以适应各平台技术的最新发展和市场需求。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值