js中一些怪异的写法_神奇的JavaScript

时间: 2018-04-26阅读: 2890标签: js技巧

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


站长推荐

1.云服务推荐: 国内主流云服务商,各类云产品的最新活动,优惠券领取。地址:阿里云腾讯云华为云

2.广告联盟: 整理了目前主流的广告联盟平台,如果你有流量,可以作为参考选择适合你的平台点击进入

链接: http://www.fly63.com/article/detial/722

关闭

(a ==1 && a== 2 && a==3) 有可能是 true 吗?

1. 利用松散相等运算符 == 的原理,自定义 toString 和 valueOf 返回对应值2. 利用半宽度韩文等特殊字符,玩“障眼法”,本质上其实并没有做到题设3. 劫持 JS 对象的 getter,不过这种方式对于严格相等 === 同样有效

js求数组的最大值--奇技淫巧和笨方法

js中有很多“奇技淫巧”,有时我会常常刻意去用这些“奇技淫巧”(注意,我不是在反对用它,只是有时其实没必要用)。比如,求数组中的最大值,js中Array没有原生的求最大值的方法,但是Math有呀

值得收藏的15条高效JS技巧

延迟函数delay、分割指定长度的元素数组、获取数组交集、函数柯里化、字符串前面空格去除与替换、获取当前子元素是其父元素下子元素的排位

一些 JavaScript 中的代码小技巧

一些 JavaScript 中的代码小技巧:使用函数过滤并序列化对象、用 Set 来实现数组去重、用块级作用域避免命名冲突、函数参数值校验、用解构赋值过滤对象属性、用解构赋值获取嵌套对象的属性、合并对象、使用 === 代替 ==

UglifyJS3的使用,UglifyJS3中文文档

使用UglifyJS合并/压缩JavaScript ,UglifyJS3与UglifyJS2相比API变动较大,简化较多,文档也增加了不少示例。

不用if撸代码,是件很有趣的事。

试着不用if撸代码,是件很有趣的事,而且,万一你领会了什么是“数据即代码,代码即数据”呢?

通过原生js判断网页图片是否已加载成功的方法总汇

在写网页的程序的时候,经常碰到要在网页加载完全之后再去展现页面,加载中的时候通过显示loading...的样式。这时候我们会直接想到使用window.onload的方式,或者是img对象的complete属性

JS禁止打开控制台

主要为了通过禁止打开控制台,防止别人进行代码调试。禁止右键查看源码和F12;通过页面宽度变化监测控制台;利用控制台特性改写对象toString;利用控制台特性进行监听dom属性

js方式实现手机号码隐藏中间4位

在前端开发中,遇到如下需求:隐藏手机号码,将中间几位替换为*。通过js如何实现手机号码隐藏中间4位呢?下面整理几种实现方式:使用正则、通过长度截取。

带你理解 JS 容易出错的坑和细节

本文重在列出并解释说明 JS 中各种容易出错的坑和细节,供大家更加深入理解为什么 JS 会这样

点击更多...

内容以共享、参考、研究为目的,不存在任何商业目的。其版权属原作者所有,如有侵权或违规,请与小编联系!情况属实本人将予以删除!