JavaScript小技巧总结
JavaScript是一种脚本语言:
- 语法类似于常见的高级语言
- 脚本语言,不需要编译就可以由解释器直接运行
- 变量松散定义
- 面向对象
JSON是一种数据交换格式,而JSONP是JSON的一种使用模式,是基于JSON的。简单说JSON是协议,而JSONP是使用这种协议的一种方法。
函数分类
函数声明: function add(a,b){}
函数表达式:
var add=function(a,b){}
(function(){})();
立即执行函数
return function(){};
var add=function foo(a,b){};
this
全局的this 指向浏览器 this===window
call/apply 修改this指向
add.call(0,5,7)
和 add.apply(0,[10,20])
中this指向0
bind与this
bind IE9及以上支持 改变this
bind({a:3}) this指向{a:3}
foo.name 函数名
foo.length 形参个数
arguments.length 实参个数
未传参数失去绑定 foo(a,b,c) foo(1,2) arguments[2]=undefined
原始操作符比函数调用快
A[A.length]=v;
好于A.push(v)
;
var min=a<b?a:b;
return min;
不要在循环内部使用
try-catch-finally
不要对数组使用
for in
避免使用with() with()可以把变量加入到全局作用域中
不要使用eval() 或者函数构造器 开销较大
JSON序列化
对象→json JSON.stringify()
JSON反序列化
json→对象 JSON.parse()
jQuery中可以临时存储整个DOM元素 ``` var navleft=document.querySelector('#left');
逗号运算符:先计算左边的参数,再计算右边的参数,返回最右边参数的值
通过for-in循环检查对象的属性,下面用法防止迭代的时候进入到对象的原型属性中
for (var name in object){
if(Object.hasOwnProperty(name)){
//do sth
}
}
toFixed把number四舍五入为指定小数位数的数字 num.toFixed()
注意:toFixed()返回的是字符串不是数字
使用length属性清空数组、截断数组
arr.lenght=0;arr.length=4;
不要直接从数组中delete或remove元素。直接使用delete其实并没有删除,只是将元素置为undefined。数组元素删除应使用splice.删除对象的属性可以使用delete.
获取数组中的最大值和最小值
var numbers=[];
var max=Math.max.apply(Math,numbers);
var min=Math.min.apply(Math,numbers);
验证是否为数组
function isArray(obj){
return Object.prototype.toString.call(obj)==='[object Array]';
}
若toString()被重写过,就行不通了。
验证是否为数字
function isNumber(n){
return !isNaN(parseFloat(n))&&isFinite(n);
}
对象转换为数组
var argArray=Array.prototype.slice.call(arguments);
能将具有length属性的对象转换为数组
var a={length:3,0:'abc',1:'def',2:'ghi'};
console.log(Array.prototype.slice.call(a));//['abc','def','ghi']
function toArr(obj){
var arr=[];
for(item in obj){
arr.push(obj[item]);
}
return arr;
}
toArr(obj);
数组之间追加
Array.prototye.push.apply(array1,array2);
字符串去空格
String.prototype.trim=function(){
return this.replace(/(^\s*)|(\s*$)/g,"");
}
或者$.trim(str);
只有function(){}内新声明的才能是局部变量,while{}、if{}、for{}之内的都是全局变量(除非本身包含在function内)
函数声明优于变量声明。如果函数名和变量名相同,函数声明就能覆盖变量声明。
给基本数据类型添加属性不报错,但取值时是undefined。
使用push()来合并数组
var arr1=[1,2,3],arr2=[4,5,6];
Array.prototype.push.apply(arr1,arr2);
arr1;
//[1,2,3,4,5,6]
闭包
- 定义了一个普通函数A
- 在A中定义了普通函数B
- 在A中返回B(确切的讲在A中返回B的引用)
- 执行A(),把A的返回结果赋值给变量C
- 执行C()
经典闭包
var lis=document.links;
for (var i=0,length=lis.length;i<length;i++){
(function(i){
lis[i].onclick=function(){
alert(i+1);
}
})(i);
}
JavaScript小技巧总结的更多相关文章
- 12个非常实用的JavaScript小技巧
在这篇文章中将给大家分享12个有关于JavaScript的小技巧.这些小技巧可能在你的实际工作中或许能帮助你解决一些问题. 使用!!操作符转换布尔值 有时候我们需要对一个变量查检其是否存在或者检查值是 ...
- 11个不常被提及的JavaScript小技巧
这次我们主要来分享11个在日常教程中不常被提及的JavaScript小技巧,他们往往在我们的日常工作中经常出现,但是我们又很容易忽略. 1.过滤唯一值 Set类型是在 ES6中新增的,它类似于数组,但 ...
- [转]11个教程中不常被提及的JavaScript小技巧
原文地址: https://www.cnblogs.com/ld1024/p/10723827.html 这次我们主要来分享11个在日常教程中不常被提及的JavaScript小技巧,他们往往在我们的日 ...
- 11个教程中不常被提及的JavaScript小技巧
这次我们主要来分享11个在日常教程中不常被提及的JavaScript小技巧,他们往往在我们的日常工作中经常出现,但是我们又很容易忽略. 1.过滤唯一值 Set类型是在ES6中新增的,它类似于数组,但是 ...
- 常用的一些javascript小技巧
(转载)常用的一些javascript小技巧: http://bbs.blueidea.com/thread-2201069-1-1.html
- 12个十分实用的JavaScript小技巧
12个非常实用的JavaScript小技巧 在这篇文章中将给大家分享12个有关于JavaScript的小技巧.这些小技巧可能在你的实际工作中或许能帮助你解决一些问题. 使用!!操作符转换布尔值 有时候 ...
- 12个非常有用的JavaScript小技巧
在这篇文章中将给大家分享12个有关于JavaScript的小技巧.这些小技巧可能在你的实际工作中或许能帮助你解决一些问题. 使用!!操作符转换布尔值 有时候我们需要对一个变量查检其是否存在或者检查值是 ...
- 8个Javascript小技巧
1. 使用 + 字符可以转换成数字 比如要把一个字符串数字转换成数字,你可能会这样做: var one = '1'; var two = '2'; var numberOne = Number(one ...
- 8个Javascript小技巧,让你写的代码有腔调
如果你想确保你的JavaScript在大多数浏览器和移动设备中都可以工作,那么我从大漠等大神指导,原来可以使用f2etest,也可以使用Endtest,browserstack等 1. 使用 + 字符 ...
- javascript小技巧-js小技巧收集(转)
本文转载自:http://blog.csdn.net/ocean20/article/details/2498699 每一项都是js中的小技巧,但十分的实用! 1.document.write(&qu ...
随机推荐
- Django——4 模板标签 模板的继承与引用
Django 模板标签 常用标签 模板的继承与引用 模板标签 标签在渲染的过程中提供任意的逻辑 标签语法: 由%}和 {% 来定义的,例如:{%tag%} {%endtag%} 这个定义是刻意模糊的. ...
- 像 IDE 一样使用 vim
本文转载自:https://github.com/yangyangwithgnu/use_vim_as_ide ##[目录] 0 vim 必知会........0.1 .vimrc 文件....... ...
- 树剖LCA讲解
LCA的类型多种多样,只说我知道的,就有倍增求LCA,tarjin求LCA和树链剖分求LCA,当然,也还有很多其他的方法. 其中最常用,速度最快的莫过于树链剖分的LCA了. 树链剖分,首先字面理解一下 ...
- boost::shared_ptr
boost::shared_ptr是boost库中用来管理指针的模板,使用它需要#include <boost/shared_ptr.hpp>.本文介绍它的一些基本用法. 第一,boost ...
- Android測试环境变量配置表
要改动的文件是~/bash_profile这个配置文件,内容例如以下: # Setting PATH for Java JAVA_HOME="/Library/Java/JavaVirtua ...
- 在shell脚本中使用函数的返回值
#!/bin/bash - function mytest() { echo "arg1 = $1" if [ $1 = "1" ] ;then return ...
- PHP5+标准函数库观察者之实现
PHP的观察者设计模式实现相对简单,可是PHP5+版本号中已经有标准库类库支持,我们仅仅需简单继承并实现就能够了. 观察者:实现标准接口类库SplSubject. 一个注冊方法:attach.一个取消 ...
- 使用百度地图API进行Android地图应用开发(Eclipse)
随着基于位置的服务的兴起,地图类App呈现爆发趋势.随着而来的是地图供应商开放大量的API.供开发人员开发基于PC或者移动端的应用程序. 如今我们研究使用百度地图SDK进行Android项目的开发. ...
- Android ListView 和 ScrollView 冲突问题
近期做一款APP,当中有一个类似微博的评论功能的界面,先是列出微博的正文内容和图片等.然后下边是评论. 一開始就想着用一个ScrollView把主要内容和评论区的ListView包起来.然后加入各个控 ...
- MySQL 日期时间函数大全 (转)
转载自:http://blog.itpub.net/29773961/viewspace-1808967 以下内容基于MySQL 5.6及更高,大部分函数5.5也基本适用,更低版本请参考对应版本手册, ...