JavaScript是一种脚本语言:

  1. 语法类似于常见的高级语言
  2. 脚本语言,不需要编译就可以由解释器直接运行
  3. 变量松散定义
  4. 面向对象

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]

闭包

  1. 定义了一个普通函数A
  2. 在A中定义了普通函数B
  3. 在A中返回B(确切的讲在A中返回B的引用)
  4. 执行A(),把A的返回结果赋值给变量C
  5. 执行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小技巧总结的更多相关文章

  1. 12个非常实用的JavaScript小技巧

    在这篇文章中将给大家分享12个有关于JavaScript的小技巧.这些小技巧可能在你的实际工作中或许能帮助你解决一些问题. 使用!!操作符转换布尔值 有时候我们需要对一个变量查检其是否存在或者检查值是 ...

  2. 11个不常被提及的JavaScript小技巧

    这次我们主要来分享11个在日常教程中不常被提及的JavaScript小技巧,他们往往在我们的日常工作中经常出现,但是我们又很容易忽略. 1.过滤唯一值 Set类型是在 ES6中新增的,它类似于数组,但 ...

  3. [转]11个教程中不常被提及的JavaScript小技巧

    原文地址: https://www.cnblogs.com/ld1024/p/10723827.html 这次我们主要来分享11个在日常教程中不常被提及的JavaScript小技巧,他们往往在我们的日 ...

  4. 11个教程中不常被提及的JavaScript小技巧

    这次我们主要来分享11个在日常教程中不常被提及的JavaScript小技巧,他们往往在我们的日常工作中经常出现,但是我们又很容易忽略. 1.过滤唯一值 Set类型是在ES6中新增的,它类似于数组,但是 ...

  5. 常用的一些javascript小技巧

    (转载)常用的一些javascript小技巧: http://bbs.blueidea.com/thread-2201069-1-1.html

  6. 12个十分实用的JavaScript小技巧

    12个非常实用的JavaScript小技巧 在这篇文章中将给大家分享12个有关于JavaScript的小技巧.这些小技巧可能在你的实际工作中或许能帮助你解决一些问题. 使用!!操作符转换布尔值 有时候 ...

  7. 12个非常有用的JavaScript小技巧

    在这篇文章中将给大家分享12个有关于JavaScript的小技巧.这些小技巧可能在你的实际工作中或许能帮助你解决一些问题. 使用!!操作符转换布尔值 有时候我们需要对一个变量查检其是否存在或者检查值是 ...

  8. 8个Javascript小技巧

    1. 使用 + 字符可以转换成数字 比如要把一个字符串数字转换成数字,你可能会这样做: var one = '1'; var two = '2'; var numberOne = Number(one ...

  9. 8个Javascript小技巧,让你写的代码有腔调

    如果你想确保你的JavaScript在大多数浏览器和移动设备中都可以工作,那么我从大漠等大神指导,原来可以使用f2etest,也可以使用Endtest,browserstack等 1. 使用 + 字符 ...

  10. javascript小技巧-js小技巧收集(转)

    本文转载自:http://blog.csdn.net/ocean20/article/details/2498699 每一项都是js中的小技巧,但十分的实用! 1.document.write(&qu ...

随机推荐

  1. C# 通俗说 内存的理解

    一.概念 堆栈是什么? 在说堆栈之前,先说说内存是神马? 内存:程序在运行的过程,电脑需要不断通过CPU进行计算,这个计算的过程会读取并产生运算的数据,这些数据需要一个存储容器存放.这个容器,这就是内 ...

  2. 如何应对SHA-1加密算法升级为SHA-256

    经过权威机构证实,sha1加密算法的不安全性越来越高,sha指纹造假成本越来越低,随即微软.谷歌等IT巨头相继发布弃用sha1加密算法声明,第三方认证机构自2016年1月1日起,将全面停止签发SHA1 ...

  3. pam_cracklib.so模块

    pam_cracklib.so中有很多参数可以选择,具体配置如下: debug此选为记录Syslog日志. type=safe输入新密码的时候给予的提示. retry=N改变输入密码的次数,默认值是1 ...

  4. nyoj_782_星期几?_201312071940

    星期几? 时间限制:500 ms  |           内存限制:65535 KB 难度:2   描述                      Acmer 小鱼儿 埋头ku算一道题 条件:已知给 ...

  5. Monthly Expense POJ 二分

    Description Farmer John is an astounding accounting wizard and has realized he might run out of mone ...

  6. Spring MVC 注解基础

    @Controller @Controller 注解用于标记在 Java 类上.被 @Controller 标记过的类就是一个 SpringMVC Controller对象.DispatcherSer ...

  7. VB.NET机房收费 &amp; 抽象工厂模式

    学习设计模式的时候,提到了一个专门訪问数据库的模式-抽象工厂模式,记得当时举样例理解的时候并未设计到数据库,仅仅是大概了了解了一下,如今对于机房收费系统涉及到了数据库的管理,借此机会好好学习一下.用常 ...

  8. Hdu oj 1012 u Calculate e

    分析:注意格式. #include<stdio.h> int main() { int i,j,k; double sum=0; printf("n e\n- --------- ...

  9. Sqlite3插入大量数据性能优化

    近期做的一个项目数据量很大.文本数据有30多M.这样就遇到一个问题.插入数据库时很慢. 这里记录下,优化方法很easy. 原文地址:http://blog.csdn.net/qqmcy/article ...

  10. OC3大回调模式使用总结(三)block回调

    OC 3大回调模式使用总结(三)block回调 block 又称 代码块,闭包等 是一个匿名的函数,它能够当做一个对象来使用,仅仅只是这个对象非常特殊,是一段代码,他能够保存你写的一段预备性质代码,待 ...