这更像是一篇为自己而写的文章,没有过多的解释,sorray。

关于:return

function fn(num){
  var a = num;
  if(a>1){
    a = num + 1;
    return a;
  }else if(a<1){
    a = 0;
    return a;
  }
}

可以写成这样

function fn(num){
  var a = num;
  if(a>1){
    a = num + 1;
  }else if(a<1){
    a = 0;
  }
  return a;
}

利用return替代if..else..

function fn(num){
  if(num==5){
    ...........
    return;
  }
  // 否则语句
  .........
}

利用return跳出多重循环

function fn(){
  for(var i=0;i<10;i++){
    for(var j=0;j<10;j++){
      ............
      if(xx===xx){
        return;
      }
    }
  }
}

利用return this实现链式调用

var Fn = function(dom){this.dom = dom;};
Fn.prototype.click = function(fn){
  this.dom.onclick = function(){
    fn();
  };
  return this;
};

Fn.prototype.mouseover = function(fn){
  this.dom.onmouseover = function(){
    fn();
  };
  return this;
};

var fn = new Fn(box);
fn.click(function(){
  console.log('click');
}).mouseover(function(){
  console.log('mouseover');
})

合理利用 || &&

if(fn()!=='undefined'){
  .........
}

可以这样

fn()&&要执行的代码

如果需要在&&或者||中使用赋值语句需要加()

return fn() && (a = 10);

利用||替程序实现默认值

var a = name || '追梦子';

function相关性...

参数较多的情况下使用透明参数(使用对象)

function fn(obj){
  for(var k in obj){
    ..............
  }
}

fn({a:1,b:2,c:3,d:4,e:5})

-------------------------

减少函数参数,如果内部可以计算出的话。

利用函数解决变量污染问题

(function(){
  // 代码块
}())

利用函数创建私有变量

var fn = (function(){
  var name = 'xxx';
  return function(){
    .............
  };
}());

利用闭包保存上下文

for(var i=0;i<10;i++){
  (function(i){
    lis[i].onclick = function(){
      ..........
    };
  }(i))
}

合理利用apply

var arr = [2,3];
function add(a,b){
  console.log(a + b);
}

add.apply(null,arr); //5

关于:for

简写1:

var arr = [2,3,4,5];

for(var i=-1;(arr.length-1)>i++;){
  console.log(arr[i]);
}

var arr = [2,3,4,5];
var i = -1;

for(;(arr.length-1)>i++;){
  console.log(arr[i]);
}

简写2:

var arr = [2,3,4,5];

for(var i=0,c;c=arr[i++];){
  console.log(c);
}

空白

var that = this; // 可以这样

varthat = this; // 不可以这样

varthat本身就会被当成是一个变量,没有人会知道你这是在声明一个变量,就好象如果你想要使用varthat而不是声明一样。

数字

javascript没有区分数字类型所以“ 1 和 1.0 ” 是一样的。

对象属性

在低版本浏览器中对象属性如果是保留字或者关键字必须加引号,不然会报错,并且使用的时候也必须通过[]来访问这个属性,在高版本浏览器中已经不存在这个问题。

数组

javascript并没有提供真正的数组而是通过对象提供了一种类似数组的结构。因此数组在大部分情况下和对象非常相似。

因为数组也是对象我们也可以使用for in来遍历数组

var arr = [2,3];

for(var k in arr){
  console.log(k,arr[k]);
}

数组有一个length属性,这个length只包含数字,如果是其他的这个长度是不会包含进来的。比如:

var arr = [2,3];

arr.fn = function(){};

这个fn是不会包含在length里面的

只能这样

var arr = [2,3];
arr[5] = 10;

console.log(arr.length);

因此对象没有length属性也很正常。但是也说了数组就是对象,所以我们想让对象也实现数组的一些特性也是很正常不过的。

因为设计的原因数组的类型也是Object所有给了我们不少小麻烦,不过我们可以自己实现一个。

通过length = 0可以用来清空数组。

javascript技术大全的更多相关文章

  1. javascript开源大全

    javascript开源大全 Ajax框架-jQuery 可视化HTML编辑器-CKEditor 国产jQuery-UI框架-(jUI)-DWZ 网页开发FireFox插件-Firebug 服务器端的 ...

  2. 【JS】javascript 正则表达式 大全 总结

    javascript 正则表达式 大全 总结 参考整理了一些javascript正则表达式 目的一:自我复习归纳总结 目的二:共享方便大家搜索 微信:wixf150 验证数字:^[0-9]*$ 验证n ...

  3. JavaScript资源大全中文版(Awesome最新版--转载自张果老师博客)

    JavaScript资源大全中文版(Awesome最新版)   目录 前端MVC 框架和库 包管理器 加载器 打包工具 测试框架 框架 断言 覆盖率 运行器 QA 工具 基于 Node 的 CMS 框 ...

  4. 细数Javascript技术栈中的四种依赖注入

    作为面向对象编程中实现控制反转(Inversion of Control,下文称IoC)最常见的技术手段之一,依赖注入(Dependency Injection,下文称DI)可谓在OOP编程中大行其道 ...

  5. javascript函数大全

    JavaScript函数大全 1.document.write(""); 输出语句2.JS中的注释为//3.传统的HTML文档顺序是:document->html->( ...

  6. 第61节:Java中的DOM和Javascript技术

    Java中的DOM和Javascript技术 DOM是一门技术,是文档对象模型.所需的文档只有标记型文档,如我们所学的html文档(文档中的所有标签都封装成为对象了) DOM: 为Document O ...

  7. 能说明你的Javascript技术很烂的五个原因

    Javascript在互联网上名声很臭,但你又很难再找到一个像它这样如此动态.如此被广泛使用.如此根植于我们的生活中的另外一种语言.它的低学习门槛让很多人都称它为学前脚本语言,它另外一个让人嘲笑的东西 ...

  8. JavaScript 资源大全中文版

    我想很多程序员应该记得 GitHub 上有一个 Awesome - XXX 系列的资源整理.awesome-javascript 是 sorrycc 发起维护的 JS 资源列表,内容包括:包管理器.加 ...

  9. JFreeChart生成饼形图(3) (转自 JSP开发技术大全)

    JFreeChart生成饼形图(3) (转自 JSP开发技术大全) 14.3 利用JFreeChart生成饼形图 通过JFreeChart插件,即可以生成普通效果的饼形图,也可以生成3D效果的饼形图: ...

随机推荐

  1. mysql监控和优化(2)

    mysql主从复制 3个线程完成复制:主库1个线程负责记录数据库变更日志从库1个线程负责拉取主库的变更日志从库1个线程负责执行主库的变更日志实现了获取事件和重放事件的解耦,允许异步进行.复制的瓶颈:主 ...

  2. mysql5.7 密码策略

    查看现有的密码策略 mysql> SHOW VARIABLES LIKE 'validate_password%';+-------------------------------------- ...

  3. Mysql运行SQL文件 错误Incorrect table definition;there can be only one TIMESTAMP column with CURRENT_TIMESTAMP in DEFAULT or ON UPDATE clause

    问题描述 想从服务器上DOWN下数据库.操作:先把数据库转存为SQL文件,然后在本地利用navicate运行SQL文件,出现错误信息: Incorrect table definition;there ...

  4. Linux之DNS

    DNS服务器配置 一.DNS概述:DNS 是域名系统 (Domain Name System) 的缩写,是一种组织域层次结构的计算机和网络服务命名系统.它的作用是:把域名转换成为网络可以识别的 IP ...

  5. StoryBoard 简单使用

    StoryBoard简单使用 故事版(storyboard)是一种简洁的图形界面,程序员可以采取拖的形式搭建一个界面,现在使用的xcode默认都会创建一个main.storyboard,作为app的入 ...

  6. vsftp搭建+虚拟用户

    yum安装vsfpd: [root@localhost ~]# yum -y install vsftpd db4-utils Loaded plugins: fastestmirror, refre ...

  7. JAVA学习博客---2015-8

    八月份的学习博客,今天已经是九月四号了,补上吧.现在我又回到C++了,JAVA的基本的东西都懂了,但是更好的掌握JAVA,我必须原路返回去学习C++,当初为了更快的学JAVA,其实我得C++都是跳着看 ...

  8. linux-14基础命令之-复制(cp)移动(mv),删除(rm),拷贝文件(dd)

    1.cp 命令用于复制文件或者目录 格式为:cp[选项]源文件  目标文件 复制名录有三种情况: @1.目标文件是一个目录,将源复制到该目录下:  @2.目标文件是一个文件,将源文件覆盖该文件: @3 ...

  9. Ubuntu 14.4 下安装 Tomcat + Solr5.2

    okbt.net 网站采用  Lucene.net 3.03 做数据引擎..不是很理想...后来试用了 Solr 后感觉很不错.多点同步.原子更新等很方便..抽空安装学习了下.. 1. ubuntu ...

  10. 在UWP应用中加入Cortana语音指令集

    本文介绍小娜语音指令集的使用场景,如何将UWP应用接入小娜的语音指令集,使用户直接通过小娜启动应用并使用应用中 一些轻量级的功能.文中以必应词典作为实例讲解必应词典UWP版本是如何接入小娜语音功能的. ...