javascript 技巧
1.将arguments转化为数组
函数中的预定义变量arguments并非一个真正的数组,而是一个类似数组的对象。 
它具有length属性,但是没有slice, push, sort等函数,那么如何使arguments具有这些数组才有的函数呢? 
也就是说如何使arguments变成一个真正的数组呢?
| 
 function args(){ return [].slice.call(arguments) } var m=args(2,5,8) // [2, 5, 8] m.push(10)//可以使用数组方法 console.log(m)// [2, 5, 8,10]  | 
2.
| 
 function add() { if(!arguments.callee.count) { //当前运行的函数的count属性。若为false,则设置为0 arguments.callee.count = 0; } return arguments.callee.count++; } add(); // 0 add(); // 1 add(); // 2 // arguments.callee指向当前正在运行的函数。 一般用于匿名函数中  | 
3数组中的最大值
var arr = [2, 3, 45, 12, 8];
Math.max.apply(null, arr);// 45
4.修改arguments
function add() {
Array.prototype.push.call(arguments, 123);
//因为arguments不是数组,是类数组,故需要调用数组方法
return arguments;
}
add(100); // [100,123]
/***1-4 数组操作**/
5.判断一个变量是否为undefined
typeof(name2) === ‘undefined’;// true
6.私有变量
var person =(function() {
var _name='1000';
return {
getName:function() { return _name || '2000'; }
}
})();
person.getName(); // "1000"
typeof(person._name); // "undefined"
7.JavaScript没有块级上下文(Scope).即函数才是作用域
for(var i = 0; i < 2; i ++) { }
i; // 2
8.If 中的假:null, undefined, NaN, 0, ‘’, false
9.0.1+0.2 != 0.3
 JavaScript将小数作为浮点数对待,所以可能会产生一些四舍五入的错误,比如:
0.1 + 0.2; // 0.30000000000000004
你可以通过toFixed方法指定四舍五入的小数位数:
(0.1 + 0.2).toFixed(); // "0"
(0.1 + 0.2).toFixed(1); // "0.3"
- encodeURI和encodeURIComponent
 
window.encodeURI函数用来编码一个URL,但是不对这些编码:“:”, “/”, “;”, “?”. 
window.encodeURIComponent则会对上述字符进行编码。
我们通过一个例子来说明:
'index.jsp?page='+encodeURI('/page/home.jsp'); // "index.jsp?page=/page/home.jsp"
'index.jsp?page='+encodeURIComponent('/page/home.jsp'); // "index.jsp?page=%2Fpage%2Fhome.jsp"
因此,在对URL进行编码时我们经常会选择 encodeURIComponent。
11.table.innerHTML在IE的table下是只读属性
<table id="table1"> </table>
// works well in Firefox, but fail to work in IE
document.getElementById('table1').innerHTML = "<tr><td>Hello</td><td>World!</td></tr>";
应该:
document.getElementById('table1').innerHTML = "<table><tr><td>Hello</td><td>World!</td></tr></table>";
12.Boolean 和 new Boolean
我们可以把Boolean看做是一个函数,用来产生Boolean类型的值(Literal):
Boolean(false) === false; // true
Boolean('') === false; // true
所以,Boolean(0)和!!0是等价的。 
我们也可以把Boolean看做是一个构造函数,通过new来创建一个Boolean类型的对象:
new Boolean(false) === false; // false
new Boolean(false) == false; // true
typeof(new Boolean(false)); // "object"
typeof(Boolean(false)); // "boolean"
13.一元操作符 +在JavaScript中,我们可以在字符串之前使用一元操作符“+”。这将会把字符串转化为数字,如果转化失败则返回NaN。【原理未知】
2 + '1'; // "21"
2 + ( +'1'); // 3
如果把 + 用在非字符串的前面,将按照如下顺序进行尝试转化:
1 调用valueOf()
2 调用toString()
3 转化为数字
+new Date; // 1242616452016
+new Date === new Date().getTime(); // true
+new Date() === Number(new Date) // true
javascript 技巧的更多相关文章
- Javascript技巧
		
Javascript数组转换为CSV格式 首先考虑如下的应用场景,有一个Javscript的字符型(或者数值型)数组,现在需要转换为以逗号分割的CSV格式文件.则我们可以使用如下的小技巧,代码如下: ...
 - (译文)12个简单(但强大)的JavaScript技巧(二)
		
原文链接: 12 Simple (Yet Powerful) JavaScript Tips 其他链接: (译文)12个简单(但强大)的JavaScript技巧(一) 强大的立即调用函数表达式 (什么 ...
 - (译文)12个简单(但强大)的JavaScript技巧(一)
		
原文连接: 12 Simple (Yet Powerful) JavaScript Tips 我将会介绍和解析12个简单但是强大的JavaScript技巧. 这些技巧所有的JavaScript程序员都 ...
 - 21个值得收藏的Javascript技巧
		
1 Javascript数组转换为CSV格式 首先考虑如下的应用场景,有一个Javscript的字符型(或者数值型)数组,现在需要转换为以逗号分割的CSV格式文件.则我们可以使用如下的小技巧,代码如 ...
 - JavaScript技巧&写法
		
原文:JavaScript技巧&写法 JavaScript技巧篇: 1>状态机 var state = function () { this.count = 0; this.fun = ...
 - 12个非常有用的JavaScript技巧
		
在这篇文章中,我将分享12个非常有用的JavaScript技巧.这些技巧可以帮助你减少并优化代码. 1) 使用!!将变量转换成布尔类型 有时,我们需要检查一些变量是否存在,或者它是否具有有效值,从而将 ...
 - 原生JavaScript技巧大收集
		
原生JavaScript技巧大收集 地址:http://itindex.net/detail/47244-javascript
 - 原生JavaScript技巧大收集100个
		
原生JavaScript技巧大收集 1.原生JavaScript实现字符串长度截取function cutstr(str, len) { var temp; var icount = 0; var p ...
 - 【转】45个实用的JavaScript技巧、窍门和最佳实践
		
原文:https://colobu.com/2014/09/23/45-Useful-JavaScript-Tips,-Tricks-and-Best-Practices/ 目录 [−] 列表 第一次 ...
 - 一些有趣的Javascript技巧
		
整理一些刷题时学会的小技巧…… 目录: 即大于0又小于0的变量 String.split() 与 正则表达式 缓存的几种方法 初始化一个数组 即大于0又小于0的变量 问题: 设计一个变量val,使得以 ...
 
随机推荐
- RDIFramework.NET ━ 9.16  案例模块━ Web部分
			
RDIFramework.NET ━ .NET快速信息化系统开发框架 9.15 案例模块 -Web部分 9.16.1.产品管理模块 产品管理模块提供了基本的增.删.改.查.导出.分页等的实现,用户可 ...
 - DuiLib学习笔记5——标题栏不能正常隐藏问题
			
我之前代码都是照着官方那个Duilib入门文档.doc来学习的.但是遇到一个问题,虽然他隐藏了windows的自带标题栏,可以自己绘画一个标题栏了,但是在这个标题栏下方,用力乱戳,就可能把系统自带的, ...
 - IOS密码加密
			
一般使用两种加密技术 1.MD5 2.以前是SHA1加密 现在流行是SHA-2加密
 - PHP读取XML文件数据
			
XML文件 <?xml version="1.0" encoding="UTF-8"?> <node> <student> ...
 - My roadway of compilers principles.
			
龙书学习过程代码记录--Python3.5(毕竟第一遍看书,书里面的例子全用python写的) One 将中缀表达式翻译成后缀表达式↓ class Parser(object): def __init ...
 - 【001:ubuntu下搭建ESP8266开发环境--编辑 编译 下载】
			
系统环境:ubuntu 16.04 TLS 64BIT 编辑器: Eclipse CDT 版本 编译器:xtensa-lx106-elf 交叉编译工具链 下载工具:esptool.py pyseria ...
 - Monkey之环境搭建完全版
			
图文版将在后期补充. 如果想要搭建好Monkey的测试环境,首先几个必要的步骤和环境不能少,分别是java相关环境.Android SDK环境,启动android虚拟机或连接真机.执行monkey测试 ...
 - Spark中文指南(入门篇)-Spark编程模型(一)
			
前言 本章将对Spark做一个简单的介绍,更多教程请参考:Spark教程 本章知识点概括 Apache Spark简介 Spark的四种运行模式 Spark基于Standlone的运行流程 Spark ...
 - win8win10以管理员身份运行cmd方法
			
win8win10以管理员身份运行cmd方法 Win7/8下提示OpenSCManager failed 拒绝访问Maven nexus 安装nexus : wrapper | OpenSCManag ...
 - windows平台(不包括ARM的CE)通用的压缩和解压缩
			
通用是相对的,这里指的是xp和win7(其他版本我没测试过,不要用不要来找我) #define CMP_FRM COMPRESSION_FORMAT_LZNT1|COMPRESSION_ENGINE_ ...