手机
当前位置:查字典教程网 >编程开发 >Javascript教程 >JS短路原理的应用示例 精简代码的途径
JS短路原理的应用示例 精简代码的途径
摘要:在js逻辑运算中,0、""、null、false、undefined、NaN都会判为false,其他都为true.||先计算第一个运算数,如...

在js逻辑运算中,0、""、null、false、undefined、NaN都会判为false,其他都为true.

||先计算第一个运算数,如果可以被转换成true,则返回左边这个表达式的值,否则计算第二个运算数。即使||运算符的运算数不是布尔值,任然可以将它看作布尔OR运算,因为无论它返回的值是什么类型,都可以被转换为布尔值。

利用它对非布尔型的值会将其返回的特性:对非布尔型的运算数使用||,用于选取一组备选值中的第一个定义了的并且非空的值(第一个为非false的值)

例:

var max = max_width || obj.max_width || 500 ;

var attr = attr || "";这个运算经常用来判断一个变量是否已定义,如果没有定义就给他一个初始值,在给函数的参数定义一个默认值的时比较有用。

&&,它先计算第一个表达式,若为假,就不会去处理第二个表达;否则继续处理后继表达式。从左到右选取表达式的第一个为非true的表达式的值,如果一直未找到则返回最后一个表达式的值。

例:(其中的味道还需要细心琢磨)

2 && 's1' && '123' && 'sss' 表达式的值等于 'sss'

2 && 's1' && '' && 'sss' 表达式的值等于 ''

2 && 's1' && NaN && 'sss'表达式的值等于 NaN

if(a >=5){

alert("你好");

}

可以简成:

a >= 5 && alert("你好");

typeof 5和typeof !!5的区别,这是一种更严谨的写法,!!的作用是把一个其他类型的变量转成的bool类型。例如, if(!!attr) => if(attr)

js中||和&&的特性帮我们精简了代码的同时,也带来了代码可读性的降低。这就需要我们自己来权衡了。

JS中的startWith功能的巧妙实现,alert(!'asdf'.indexOf('s')) =》 !0 = true

【JS短路原理的应用示例 精简代码的途径】相关文章:

下拉菜单既可以选择,又可以自己填写

Js和JQuery获取鼠标指针坐标的实现代码分享

JavaScript数组去重的3种方法和代码实例

简介JavaScript中的setTime()方法的使用

图片分页查看 原创

JavaScript中用toString()方法返回时间为字符串

Javascript随机显示图片的源代码

js跨域请求的5中解决方式

JavaScript中fixed()方法的使用简介

一个特帅的展示图片的js+css

精品推荐
分类导航