分享9点个人认为比较重要的javascript 编程技巧_javascript技巧
1.巧用判断:
在js中,NaN,undefined,Null,0,"" 在转换为bool的时候,是false,所以,可以这样写。
if(!obj) {}
表示一个对象如果为false的时候所做的事情,因为如果obj为以上任何一个,那么就是false,!false即是true,这样,就不需要 if(obj==null || obj == NaN ....)。
2.巧用运算符:
有一个很经典的技巧,得到时间戳。
var dataspan = new Date()*1;
我们知道,js是弱类型语言,Date()会返回一个表示时间的字符串,用这个字符串进行算术运算,将得到转换,也就是结果的时间戳。
3.巧用正则表达式:
/.a/ig.exec('xsas')
//相当于创建一个reg对象,调用了exec方法,当然也能调用其他的方法,如:test(),match()等。
4.取数组最大值和最小值:
var values = [1,2,3,40,23];
var max = Math.Max.apply(Math,values);
调用Max.apply,设置对象的为Math,然后传递一个Values,就能确定最大值。
5.内存优化:
function p(){this.p='moersing'}; var p1 = new p();
p1.xx
p1.xx
.......
p1=null; //执行完操作之后,最后手动解除对p1的引用。
6.最受欢迎的创建对象方式(原型模式):
function c(){
this.name ='moersing';
this.age=18;
this.books=['javascript develop','C# develop'];
}
c.prototype={
displayBookName:function (){
foreach(var t in this.books)
{
document.write(this.books[t]);
}
}
}
原型构造模式的最大缺点在于引用类型的共享,所以,将引用类型定义在构造函数中,而将通用方法定义在原型中,使用this引用。
7.块级作用域和私有变量
在javascript中,没有块级作用域和私有变量这一说,但是,利用一些特性,则能模仿这些效果。
7.1块级作用域:
(function(){
//块级作用域
}
)();
匿名函数外面加上一个括号,我管它叫"函数标准化",也就是说,可以像标准函数那样调用,如:
var name =function(){};
(name)();//一般不会这么写;
这么做的好处就是,在()外部无法访问到函数中变量,也就成了块级作用域,这种方式一般用在编写插件的时候,不会再全局 (global)中添加额外的变量,而且,在函数执行完毕之后,其内部定义的变量就被销毁了,所以,也不会有闭包特性存在的问题。
7.2私有变量:
function private()
{
var name = 'moersing';
this.getName = function(){
return this.name;
}
}
私有变量实际上就是利用函数的作用域作为限制(外部无法访问),然后定义一个方法,这个方法返回相应的变量,仅此而已。
8.DOM之NodeList:
nodeList是一个动态的元素,这意味着,在文档中添加任何元素,nodeList都会实时更新,如:
var alldiv = document.getElementsByTagName('div');
for(var i=0;i
var div = document.createElement('div');
div.innerHTML= i.toString();
document.body.appendChild(div);
}
这段代码会造成无限循环,在循环里面创建了一个div,然后appendChild方法将其添加到body中,那么,所有alldiv会立即就更新,所以,i
var alldiv = document.getElementsByTagName('div');
var len,i;
for(i=0,len=alldiv.length;i
var div = document.createElement('div');
div.innerHTML= i.toString();
document.body.appendChild(div);
}
这里建议:最好不要频繁的对NodeList操作,因为每次操作都会执行一次DOM树的查询。
除了以上介绍的方法外,HTML5 新加入的API(selector API Level1)也能解决这个问题,它类似C#的linq及时查询,至于什么是linq及时查询,以后我会更新blog,敬请关注:
var allDiv= document.querySelectorAll('div');
for(var i=0;i
var div = document.createElement('div');
div.innerHTML= i.toString();
document.body.appendChild(div);
}
querySelectorAll需要一个参数,一个CSS选择器,类似jquery中的$(),它返回的NodeList是一个及时的,非动态的DOM集合。
另外还有一个querySelector,返回匹配的第一个元素,有关HTML5 API 详 见
http://www.w3.org/standards/techs/dom#w3c_all
或者
https://developer.mozilla.org/zh-CN/docs/Web/API
另外,本人也在酝酿一篇blog,专门讲HTML5 API的,敬请关注。
9.DOM性能:
不要做这种傻事(我做过。。。)
for(var i=0;i {
document.querySelector('ul').innerHTML="
}
给对象的innerHTML赋值,会调用内置的C++解析器解析这个字符串,虽然速度很快,但是最好不要这样操作,会有一定的性能流失。
最好这样做:
var ih=null;
for(var i=0;i
{
ih+="
}
document.querySelector('ul').innerHTML=ih;
另外的一些性能优化话题,等有时间再更新。
以上所述就是本文的全部内容了,希望大家能够喜欢。

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

热门话题

ISO文件是一种常见的光盘映像文件格式,它通常用于存储光盘的全部内容,包括文件和文件系统。当我们需要访问ISO文件中的内容时,就需要将其解压。本文章将介绍解压ISO文件的几种常见方法。使用虚拟光驱解压这是最常用的解压ISO文件的方法之一。首先,我们需要安装一个虚拟光驱软件,例如DAEMONToolsLite、PowerISO等。然后,双击虚拟光驱软件图标

如何使用WebSocket和JavaScript实现在线语音识别系统引言:随着科技的不断发展,语音识别技术已经成为了人工智能领域的重要组成部分。而基于WebSocket和JavaScript实现的在线语音识别系统,具备了低延迟、实时性和跨平台的特点,成为了一种被广泛应用的解决方案。本文将介绍如何使用WebSocket和JavaScript来实现在线语音识别系

WebSocket与JavaScript:实现实时监控系统的关键技术引言:随着互联网技术的快速发展,实时监控系统在各个领域中得到了广泛的应用。而实现实时监控的关键技术之一就是WebSocket与JavaScript的结合使用。本文将介绍WebSocket与JavaScript在实时监控系统中的应用,并给出代码示例,详细解释其实现原理。一、WebSocket技

如何利用JavaScript和WebSocket实现实时在线点餐系统介绍:随着互联网的普及和技术的进步,越来越多的餐厅开始提供在线点餐服务。为了实现实时在线点餐系统,我们可以利用JavaScript和WebSocket技术。WebSocket是一种基于TCP协议的全双工通信协议,可以实现客户端与服务器的实时双向通信。在实时在线点餐系统中,当用户选择菜品并下单

如何使用WebSocket和JavaScript实现在线预约系统在当今数字化的时代,越来越多的业务和服务都需要提供在线预约功能。而实现一个高效、实时的在线预约系统是至关重要的。本文将介绍如何使用WebSocket和JavaScript来实现一个在线预约系统,并提供具体的代码示例。一、什么是WebSocketWebSocket是一种在单个TCP连接上进行全双工

删除Go切片元素删除单个元素:使用append()方法创建新切片,排除要删除的元素。使用copy()方法移动元素并调整长度。删除多个元素:使用for循环迭代切片,从新切片中排除要删除的元素。使用reverse()方法对要删除的元素排序,从后往前删除以避免索引问题。根据您要删除的元素数量和性能要求,选择最合适的技术。

JavaScript和WebSocket:打造高效的实时天气预报系统引言:如今,天气预报的准确性对于日常生活以及决策制定具有重要意义。随着技术的发展,我们可以通过实时获取天气数据来提供更准确可靠的天气预报。在本文中,我们将学习如何使用JavaScript和WebSocket技术,来构建一个高效的实时天气预报系统。本文将通过具体的代码示例来展示实现的过程。We

用法:在JavaScript中,insertBefore()方法用于在DOM树中插入一个新的节点。这个方法需要两个参数:要插入的新节点和参考节点(即新节点将要被插入的位置的节点)。
