js中一些怪异的写法_神奇的JavaScript
JavaScript是一门伟大的语言,作为一门弱类型语言,它拥有非常简洁的语法,庞大的生态系统,灵活性非常强大。由于不同程序员编码的习惯不同,导致出js各种神奇的写法,所谓的神奇也就是罕见。下面就开始介绍这些怪异的写法吧。
1、this.value可以直接获取值?
<input type="range" name="range" id="r"/><br/>
<script>
r.onchange = function(){
console.log(this.value);
}
</script>请看上面的代码,没有使用document.getElementById(‘r’),这是由于在html页面中id必须是唯一的,当id名称和内置的属性、全局变量不重名的情况下,该id将以名称的形式自动成为window对象的属性,也就是说:
console.log(r===document.getElementById('r')); //返回的为true
r.onchange = function(){
console.log(this===r); //返回的为true
}2、函数前面加感叹号
!function fn(){
console.log("fly63.com") //直接就输出fly63.com
}();!在这里代表这个函数为立即执行,除了上面的感叹号,还有加+,-,~,void 这些【注意void后面需要空格哦!】,都是表示立即执行的意思,不过返回值不是正常函数返回的undefined,而是其他。这种不需要调用就直接执行了,它类似于:
(function fn(){
console.log("fly63.com")
})();3、代码前加分号
;function fn(){
console.log("fly63.com")
};在代码前加分号主要是为了和前面的代码分隔开,默认js是以换行分割代码的,但是为了防止代码上线前合并压缩,导致换行符的删掉,所以这样写更保险,避免上线后造成未知的错误。
4、return换行不报错
function fn(){
return
1
}
console.log(fn());//出现undefined上面的代码并没报错,而且返回的也不是1,这是为什么呢?这是由于js会自动在代码换行结尾的地方添加分号,也就是说上面代码等同于:
function fn(){
return;
1;
}
console.log(fn());//出现undefined是由于return并没有返回任何内容5、~~,|,!!的使用
var a=13.14;
console.log(~~a);//13
console.log(a|0);//13
console.log(a|1);//13
console.log(a|3);//15
console.log(!!a);//true说明:
~~去除小数部分,当a为字符串的时候:为'13.14'也是返回13,为'fly63'返回的就是0了。
|这个就很诡异了。经测算a|0实现的效果和~~一样,但是如果后面的值不为0的情况下,如下返回的结果好像都没有规律:
console.log(1|4); //5
console.log(4|4);//4
console.log(3|8);//11
console.log(5.3|3.1);//4这是为什么呢?简单来讲:这里“|”就是转换为2进制之后相加得到的结果,例如我们拿简单的举例:
3|8 //转换为二进制之后011 | 1000 相加得到1011=11!!这个符号一般是将后面表达式转换为布尔型的数据 ,所以结果返回就是false或者true。
6、其它
除了上面整理的,还有很多哦,这里就不举例了,有兴趣的朋友可以安装这个~~~~
$ npm install -g wtfjs本文内容仅供个人学习、研究或参考使用,不构成任何形式的决策建议、专业指导或法律依据。未经授权,禁止任何单位或个人以商业售卖、虚假宣传、侵权传播等非学习研究目的使用本文内容。如需分享或转载,请保留原文来源信息,不得篡改、删减内容或侵犯相关权益。感谢您的理解与支持!